Ejabberd源码解析前奏--概述
一、绪论
Ejabberd是一个用Erlang/OTP写的开源即时通讯服务器,其是跨平台、分布式、容错且基于开放标准的实时通讯系统。Ejabberd是一个功能丰富的XMPP服务器,同时适合小规模和超大估摸部署,无论是否需要可伸缩性。
二、关键功能
1、跨平台
Ejabberd可以运行在Microsoft Windows和类Unix系统,例如Linux、FreeBSD和NetBSD。
2、分布式
可以在一个集群的机器上运行Ejabberd,并且所有的机器都服务于同一个或一些Jabbe域,当你需要更大容量的时候,你可以简单地增加一个廉价节点到集群里, 因此,不需要买一个昂贵的高端机器来支持上万个并发用户。
3、容错
可以布署一个Ejabberd集群,这样一个正常运行的服务的所有必需信息将被复制到所有节点. 这意味着如果其中一个节点崩溃了, 其它节点将无中断的继续运行. 另外, 也可以‘不停机’增加或更换节点。
4、易于管理
Ejabberd建立于开源的Erlang,所以不需要安装外部服数据库、外部web服务器, 除此以外,因为每个东西都已经包含在里面且处于开箱可用状态. 其管理上的好处包括:
(1)详尽的文档;
(2)便捷的安装程序,包括在Linux、Mac OS X以及Windows系统下;
(3)Web管理;
(4)共享名册组;
(5)命令行管理工具;
(6)可外部集成的验证机制;
(7)发送匿名消息的能力。
5、国际化
Ejabberd领导国际化,非常适合全球化,相关功能包括:
(1)翻译成25种语言;
(2)支持IDNA。
6、开放标准
Ejabberd是一个完全支持XMPP标准的开源Jabber服务器:
(1)完全兼容XMPP;
(2)基于XML的协议;
(3)支持的协议很多。
三、额外功能
1、模块化
(1)只装载你想要的模块;
(2)用自定义模块扩展Ejabberd。
2、安全性
(1)支持c2s和s2s连接的SASL和STARTTLS;
(2)支持s2s连接的STARTTLS和Dialback;
(3)通过HTTPS安全访问进行Web管理。
3、数据库
(1)快速布署的内部数据库(Mnesia);
(2)原生的MySQL支持;
(3)原生的PostgreSQL支持;
(4)支持ODBC数据存储;
(5)支持Microsoft SQL Server。
4、验证
(1)内部验证;
(2)PAM、LDAP 和 ODBC;
(3)外部验证脚本。
5、其他
(1)支持虚拟主机;
(2)XML流压缩 (XEP-0138);
(3)统计 (XEP-0039);
(4)支持IPv6的c2s和s2s连接;
(5)支持集群和HTML日志的多用户聊天模块;
(6)基于用户vCards的用户目录;
(7)支持基于PubSub的个人事件的发行-订阅组件;
(8)支持web客户端: HTTP轮询和HTTP绑定(BOSH)服务;
(9)IRC网关;
(10)组件支持:安装特定网关之后和外部网络的接口,如 AIM, ICQ 和 MSN。
别看上面列的功能多,实际使用中你会发现都很好用。