这些天捣鼓了下ejabberd,准备研究它的代码,做为榜样~ 我这儿用的是1.1.3的代码,而svn上面的代码有些地方做了比较大的改动.
在Linux平台安装很简单
- ./configure
- make && make install
就ok了.
- ejabberd 会安装在var/lib/ejabberd目录, 配置文件在/etc/ejabberd目录,默认是ejabberd.cfg, 日志放在/var/log/ejabberd目录下.
若现在 像ejabberd的指南所说的那样执行
- erl -pa /var/lib/ejabberd/ebin -name ejabberd -s ejabberd
就会出错,没有定义配置文件的路径。最简单的方法就是先设置一个环境变量
- export EJABBERD_CONFIG_PATH=/etc/ejabberd/ejabberd.cfg
然后再执行刚才的erl命令,这儿节点名称用全称.
erl -pa /var/lib/ejabberd /ebin -name ejabberd@192.168.0.98 -s ejabberd 当然也可以用
- erl -pa /var/lib/ejabberd/ebin \
- -sname ejabberd \ -s ejabberd \
- -ejabberd config \“/etc/ejabberd/ejabberd.cfg\” \ log_path \”/var/log/ejabberd/ejabberd.log\” \
- -sasl sasl_error_logger \{file,\”/var/log/ejabberd/sasl.log\”\} \ -mnesia dir \”/var/lib/ejabberd/spool\”
来详细地定义启动参数.
下面是ejabberdctl工具来注册一个用户admin.
ejabberdctl 实际上是一个shell文件,具体内容是
- #!/bin/sh
- exec erl -noinput -sname ejabberdctl -s ejabberd_ctl -extra $@
可以看出,它实际上是调用ejabberd_ctl模块,对应的文件就是 ejabberd_ctl.beam. 这工具原本在ejabberd源码下的tools文件夹下,但它找不到ejabberd_ctl.beam.你可以将它copy至/var/lib /ejabberd/ebin下面方方便使用.
当你执行
- # ./ejabberdctl ejabberd@192.168.0.98 register admin 192.168.0.98 password
时它会出现如下错误
- RPC failed on the node ‘ejabberd@192.168.0.98’: nodedown
- =ERROR REPORT==== 6-Jul-2007::05:27:33 ===
- ** System NOT running to use fully qualified hostnames ** ** Hostname 192.168.0.98 is illegal **
开始以为是192.168.0.98非法, 后面用它的源码检查了一番发现是rpc:call调用有问题。因为ejabberctl这个shell文件中定义了
- -sname ejabberdctl
调 用sname定义的短节点名与长节点名,两者所定义的结点不能通信.连net_adm:ping都失败.
我这儿把./ejabberdctl改成 下面的样子:
- 1. #!/bin/sh
- 2. 3. exec erl -noinput -name ejabberdctl@192.168.0.98 -s ejabberd_ctl -extra $@
这样rpc:call就没有问题了.但再执行那个注册命令就会出现:
Can’t register user “admin@192.168.0.98” at node ‘ejabberd@192.168.0.98’: not_allowed
检查源码发现是由于配置文件ejabberd.cfg中没有此host. 我这儿98加到hosts里面就可以了:
- % Host name:
- {hosts, [“localhost”,“192.168.0.98”]}.
再执行一下,就没问题了。admin用户已经注册成功!
接下来,就是登陆管理页面了. 我这儿默认是在 http://192.168.0.98:5280/admin
换台有浏览器的 机器登陆这个页面. 这时admin登录总是出现401错误。我将源代码web/ejabberd_web.erl代码中的密码验证难取消了,就可以看到管理页面啦. 有空再研究一下到底是哪儿出了错,查了下代码,可能又是配置方面 🙂