文档章节

Jabberd2 添加动态域名管理功能 (下)

不插电码农
 不插电码农
发布于 2014/11/21 11:34
字数 995
阅读 14
收藏 0
点赞 0
评论 0

原文出处: Jabberd2 添加动态域名管理功能 (下)

最复杂的sm部分在上篇已经讲过了, 和sm一样, c2s也维护了一个hosts的列表(其实另一个hosts列表c2s->sm_avail 在上一节已经由sm维护了)代表可用的服务域名, 在对XML配置文件修改后同样要使其生效也是在c2s/main.c里重新加载配置, 加载配置的函数大部分已经有了.

首先用同样的方法触发ReConfig:

//  reload configurations
        if(c2s_reconf) {
            log_write(c2s->log, LOG_NOTICE, "reloading some configuration items ...");
            config_t conf;
            conf = config_new();
            
            if (conf && config_load(conf, config_file) == 0) {
                // expand with new configuration
                _c2s_hosts_expand_with_config(c2s, conf);
                
                config_free(conf);
                log_write(c2s->log, LOG_NOTICE, "reconfig hosts mapping ...");
            }else {
                log_write(c2s->log, LOG_WARNING, "couldn't reload config (%s)", config_file);
                if (conf) config_free(conf);
            }
            c2s_reconf = 0;
        }

_c2s_hosts_expand_with_config是新增的函数, 其关键代码:

/* Reconfig with sepecified configuration */
static void _c2s_hosts_expand_with_config(c2s_t c2s, config_t conf)
{
    ...
    // 从config_t读取并填充到newhosts
    newhosts = xhash_new(1021);
    for(i = 0; i < elem->nvalues; i++) {
        host_t host = (host_t) pmalloco(xhash_pool(newhosts), sizeof(struct host_st));
        ...

        //此处的sx_ssl_server_addcert有点缺陷
    }
    // 以上内容和 _c2s_hosts_expand几乎一样.

    // update host pointer in sessions
    if(xhash_iter_first(c2s->sessions))
        do {
            xhv.sess_val = &sess;
            xhash_iter_get(c2s->sessions, NULL, NULL, xhv.val);

            if(sess->resources != NULL) {
                host_t currhost = xhash_get(newhosts,  sess->resources->jid->domain);
                if(currhost!= NULL){
                    // Update to new host pointer
                    sess->host = currhost;                    
                }else{
                    /* domain has been removed,  close it`s session*/
                    sess->active = 0;
                    if(sess->s) sx_close(sess->s);
                }
            }
        } while(xhash_iter_next(c2s->sessions));
    
    // replace current hosts table
    xhash_free(c2s->hosts);
    c2s->hosts = newhosts;
}

这样就更新了c2s->hosts, 最主要的是要更新c2s->sessions里的host指针值, 剩下的c2s都会自己处理.

但是这里还有一个缺点, 在sx_ssl_server_addcert添加SSL证书信息中,如果对重复即已存在的证书信息会删除原有并替换:

/** args: name, pemfile, cachain, mode */
int sx_ssl_server_addcert (...)
{
	...

	/* remove an existing context with the same name before replacing it */
    tmp = xhash_get(contexts, name);
    if(tmp != NULL)
        SSL_CTX_free((SSL_CTX *) tmp);

    xhash_put(contexts, name, ctx);

    return 0;
}

这可以自动更新证书, 但是对已经移除的domain证书却没有删除, 要实现这个并不难, 后期会修复这个bug.

————————————–分割线————————————–

目前对Jabberd2s已经有了很大的修改, 已经不再从XML配置文件里读取hosts的配置信息, 取而代之在数据库里添加了一张host表, 有更强的可控性, 不过目前只有对mysql支持, 没有照顾其它的数据库(没有更新到GitHub的原因之一).

MariaDB [jabberd2]> desc host;
+——————+————+——+—–+———+—————-+
| Field            | Type       | Null | Key | Default | Extra          |
+——————+————+——+—–+———+—————-+
| domain           | text       | NO   | PRI | NULL    |                |
| realm            | tinytext   | NO   | MUL | NULL    |                |
| object-sequence  | bigint(20) | NO   | MUL | NULL    | auto_increment |
| pemfile          | text       | YES  |     | NULL    |                |
| verify-mode      | tinyint(4) | YES  |     | 0       |                |
| cachain          | text       | YES  |     | NULL    |                |
| require-starttls | tinyint(4) | YES  |     | 0       |                |
| register-enable  | tinyint(4) | YES  |     | 0       |                |
| register-oob     | text       | YES  |     | NULL    |                |
| instructions     | mediumtext | YES  |     | NULL    |                |
| password-change  | tinyint(4) | YES  |     | 0       |                |
| status           | tinytext   | YES  |     | NULL    |                |
+——————+————+——+—–+———+—————-+

sm和c2s都会读取该表, 但该表由c2s维护负责删改,最后一个字段表明状态, 可以有normal, add, mod, offline, delete. 正常是normal, 切换状态可以直接修改其status值, 然后发送SIGUSR1信号触发ReConfig. 由于router的机制缘故, 无法从offline状态切换到delete, 要删除的话得先切换到normal状态, 然后再delete. 我也在想或许不需要delete状态, 直接从表删除条目也是可以更新的(没有更新到GitHub的原因之二), 或许待更完善或者有空了会更新到git上.

更多参考:

Jabberd2 内存池模型

Jabberd2 哈希表设计(xhash源码)

Jabberd2 安装配置及调试

Jabberd2 通信框架(mio)模型(上)

Jabberd2 通信框架(mio)模型 (下)

Jabberd2 添加动态域名管理功能 (上)

Jabberd2 添加动态域名管理功能 (下)

© 著作权归作者所有

共有 人打赏支持
不插电码农
粉丝 4
博文 3
码字总数 6745
作品 1
其他
开源XMPP服务器--Jabberd2s

Jabberd2s 是根据开源XMPP服务器项目Jabberd2修改而来. 基于Jabberd-2.3.2稳定版源码修改,主要添加以下功能: 1.通过直接修改配置文件动态配置XMPP服务器的离线与上线功能; 2.重新加载配置文件...

不插电码农 ⋅ 2014/08/26 ⋅ 0

Jabberd 2.2.8 版本发布

Jabberd2 是一个 XMPP 的服务器端软件,是新一代的 Jabberd 项目。 Jabberd2 并不是 Jabberd 1.x 的新版本,而是一个新的分支。 新版本的改进内容包括: 1. Users can message or query thei...

红薯 ⋅ 2009/04/28 ⋅ 0

Jabberd2 2.2.15 发布,即时消息服务器

Jabberd2 2.2.15 发布,该版本包含大量的 bug 修复和新特性,特别是包含 Apple ChatServer 。 Jabberd2 是一个 XMPP 的服务器端软件,是新一代的 Jabberd 项目。 Jabberd2 并不是 Jabberd 1....

红薯 ⋅ 2012/05/01 ⋅ 0

Jabberd2 2.2.16 发布,即时消息服务器

Jabberd2 2.2.16 发布,该版本主要是 bug 修复,修复了 2.2.15 移植到 Git 上的一些问题,改进了源码和文档,同时实现了将调试信息写到文件的功能。 Jabberd2 是一个 XMPP 的服务器端软件,是...

红薯 ⋅ 2012/05/05 ⋅ 4

Jabber服务器Jabberd安装

Jabberd到现在经历了多个版本,是比较稳定的,下面为安装过程 mysql安装 rpm -i MySQL-server-4.0.18-0.i386.rpm rpm -i MySQL-shared-4.0.18-0.i386.rpm rpm -i MySQL-client-4.0.18-0.i38......

红薯 ⋅ 2009/01/20 ⋅ 0

Jabberd 2.2.17 发布,XMPP 聊天服务器

Jabberd 2.2.17 是一个安全补丁版本,主要是 XMPP 服务器回拨实现中的安全漏洞修复。 Jabberd2 是一个 XMPP 的服务器端软件,是新一代的 Jabberd 项目。 Jabberd2 并不是 Jabberd 1.x 的新版...

oschina ⋅ 2012/08/27 ⋅ 8

jabberd windows平台下源码编译以及使用gaim客户端运行方法

请知晓的朋友不要占据知识; 希望您能够将该技术架构以及这样一个完整性的流程倾囊相授; 非常感谢: 我在这个网站 :http://codex.xiaoka.com/svn/jabberd2/trunk/ 以及这个号称能够实现win...

O_NONBLOCK ⋅ 2010/08/13 ⋅ 1

Jabberd2 2.2.11 发布,即时消息服务器

Jabberd2 是一个 XMPP 的服务器端软件,是新一代的 Jabberd 项目。 Jabberd2 并不是 Jabberd 1.x 的新版本,而是一个新的分支。 该版本修复了在 XML 解析和连接处理上的一些主要bug。...

红薯 ⋅ 2010/08/09 ⋅ 0

Jabberd 2.2.12 发布

Jabberd2 是一个 XMPP 的服务器端软件,是新一代的 Jabberd 项目。 Jabberd2 并不是 Jabberd 1.x 的新版本,而是一个新的分支。 该版本修复了不少bug,更加稳定,解决了内存泄漏的问题和连接...

红薯 ⋅ 2011/02/12 ⋅ 1

jabberd 2.3.0 发布,XMPP 聊天服务器

jabberd 2.3.0 包含很多新特性和 bug 修复,包括一个语义的版本化模式以及 TLS 支持。 Jabberd2 是一个 XMPP 的服务器端软件,是新一代的 Jabberd 项目。 Jabberd2 并不是 Jabberd 1.x 的新版...

oschina ⋅ 2013/11/19 ⋅ 7

没有更多内容

加载失败,请刷新页面

加载更多

下一页

JavaScript零基础入门——(十一)JavaScript的DOM操作

JavaScript零基础入门——(十一)JavaScript的DOM操作 大家好,欢迎回到我们的JavaScript零基础入门。最近有些同学问我说,我讲的的比书上的精简不少。其实呢,我主要讲的是我在开发中经常会...

JandenMa ⋅ 24分钟前 ⋅ 0

volatile和synchronized的区别

volatile和synchronized的区别 在讲这个之前需要先了解下JMM(Java memory Model :java内存模型):并发过程中如何处理可见性、原子性、有序性的问题--建立JMM模型 详情请看:https://baike.b...

MarinJ_Shao ⋅ 50分钟前 ⋅ 0

深入分析Kubernetes Critical Pod(一)

Author: xidianwangtao@gmail.com 摘要:大家在部署Kubernetes集群AddOn组件的时候,经常会看到Annotation scheduler.alpha.kubernetes.io/critical-pod"="",以表示这是一个关键服务,那你知...

WaltonWang ⋅ 58分钟前 ⋅ 0

原子性 - synchronized关键词

原子性概念 原子性提供了程序的互斥操作,同一时刻只能有一个线程能对某块代码进行操作。 原子性的实现方式 在jdk中,原子性的实现方式主要分为: synchronized:关键词,它依赖于JVM,保证了同...

dotleo ⋅ 今天 ⋅ 0

【2018.06.22学习笔记】【linux高级知识 14.4-15.3】

14.4 exportfs命令 14.5 NFS客户端问题 15.1 FTP介绍 15.2/15.3 使用vsftpd搭建ftp

lgsxp ⋅ 今天 ⋅ 0

JeeSite 4.0 功能权限管理基础(Shiro)

Shiro是Apache的一个开源框架,是一个权限管理的框架,实现用户认证、用户授权等。 只要有用户参与一般都要有权限管理,权限管理实现对用户访问系统的控制,按照安全规则或者安全策略控制用户...

ThinkGem ⋅ 昨天 ⋅ 0

python f-string 字符串格式化

主要内容 从Python 3.6开始,f-string是格式化字符串的一种很好的新方法。与其他格式化方式相比,它们不仅更易读,更简洁,不易出错,而且速度更快! 在本文的最后,您将了解如何以及为什么今...

阿豪boy ⋅ 昨天 ⋅ 0

Python实现自动登录站点

如果我们想要实现自动登录,那么我们就需要能够驱动浏览器(比如谷歌浏览器)来实现操作,ChromeDriver 刚好能够帮助我们这一点(非谷歌浏览器的驱动有所不同)。 一、确认软件版本 首先我们...

blackfoxya ⋅ 昨天 ⋅ 0

线性回归原理和实现基本认识

一:介绍 定义:线性回归在假设特证满足线性关系,根据给定的训练数据训练一个模型,并用此模型进行预测。为了了解这个定义,我们先举个简单的例子;我们假设一个线性方程 Y=2x+1, x变量为商...

wangxuwei ⋅ 昨天 ⋅ 0

容器之查看minikue的environment——minikube的环境信息

执行如下命令 mjduan@mjduandeMacBook-Pro:~/Docker % minikube docker-envexport DOCKER_TLS_VERIFY="1"export DOCKER_HOST="tcp://192.168.99.100:2376"export DOCKER_CERT_PATH="/U......

汉斯-冯-拉特 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部