用mysql+openfire+spark搭建开源IM系统
mysql是数据库,用于存储信息。
openfire是XMPP协议服务器,实现了XMPP协议。
spark是客户端。编译方法详见:http://blog.csdn.net/kl222/article/details/7080471
环境:
root@ubuntu:~# uname -a
Linux ubuntu 3.0.0-12-generic #20-Ubuntu SMP Fri Oct 7 14:50:42 UTC 2011 i686 i686 i386 GNU/Linux
jdk7
openfire3.7.1
mysql:Server version: 5.1.58-1ubuntu1 (Ubuntu)
服务器搭建:
下载openfire源码,解压后的目录结构:
帮助文档在:documentation\docs\index.html
1、安装 openfire
1.1、安装数据库(以mysql为例)
ubuntu默认没有安装mysql.你只要 apt-get install mysql.就可以下载和安装了。你可以下载mysql源码进行编译安装。
安装后常见的问题:
A、防火墙打开,解决方法是关闭防火墙,或者打开相应的端口(见后面端口列表)
B、给用户设置密码
修改mysql密码的方法
use mysql
update user set Password=password('newpassword') where User='root';
flush privileges;
1.通过修改MYSQL数据库中MYSQL库的USER表
就用普通的UPDATE、INSERT语句就可以
2.在命令行中使用如下命令
MYSQLADMIN -u root -p PASSWORD mypasswd
3.可以修改MYSQL文件夹中的MY.INI文件
4.使用SET PASSWORD语句,
mysql> SET PASSWORD FOR myuser@localhost = PASSWORD('mypasswd');
5.使用GRANT ... IDENTIFIED BY语句
mysql>GRANT USAGE ON *.* TO root@"%" IDENTIFIED BY"root";
GRANT ALL privileges ON *.* TO root@"%" IDENTIFIED BY "root";
C、其它机器不能访问mysql,解决方法,新增加用户,让此用户能从其它机器访问。
其一:
mysql>GRANT ALL PRIVILEGES ON root.* TO root@"%" IDENTIFIED BY "password";
允许root用户可以从任意机器上登入MySQL。
其二:
$sudo gedit /etc/mysql/my.cnf
老的版本中
>skip-networking => # skip-networking
新的版本中
>bind-address=127.0.0.1 => bind-address= 你机器的IP 或者去掉此行。
这样就可以允许其他机器访问MySQL了。
1.1.1、建立库表:
#mysqladmin create [databaseName]
databaseName:是数据库名。
例如:如果数据库有账户root,密码为password,则:
#mysqladmin -u root -ppassword create openfire
1.1.2、导入库表,数据库脚本位于安装目录 src/database 。
Unix/Linux: cat openfire_mysql.sql | mysql [databaseName];
Windows: type openfire_mysql.sql | mysql [databaseName];
例如:
cat openfire_mysql.sql | mysql -h HOST_IP -P PORT -u root -ppassword openfire;
注意:-p与密码中间没有空格
1.2、编译openfire(linux下)
1.2.1、安装并设置 jdk,本人用的是 jdk7
export $JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386
1.2.2、安装并设置 ant
1.2.3、开始编译openfire
进入源码目录下的/build
#ant
搞定编译完成。openfire核心编译完成。
程序会产生在源码目录下的 target 目录下
如果要插件的话(比如IM网关),则要编译插件:
#ant plugins
编译完成,所有插件被放到源码目录下的target/openfire/plugins
windows下用eclipse编译,可参照 eclipse编译spark 的方法进行。 http://blog.csdn.net/kl222/article/details/7080471
1.2.4、可能出现的问题。
由于我用的是jdk7的版本,openfire3.7是只支持jdk5和jdk6,所以在编译时会提示jdk错误。你只要在build.xml文件中增加下面红色部分就可以解决。
1.2.5、配置
配置文件位于源码目录下的 target/conf 目录下。
主要配置文件:openfire.xml
配置管理控制台:
配置数据库。这一步也可以编译完openfire后,运行openfire,然后再从管理控制台进行配置。
1.3、运行
1.3.1、未安装运行
在源码目录下的/build 下运行
#ant run
就可以运行openfire了
root@ubuntu:~/openfire_src/build# ant run
Buildfile: /root/openfire_src/build/build.xml
run:
[java] Listening for transport dt_socket at address: 8000
[java] Openfire 3.7.1 [2011-12-13 2:47:08]
[java] 管理平台开始监听:
[java] http://127.0.0.1:9090
[java] https://127.0.0.1:9091
1.3.2、安装后运行
# /etc/init.d/openfire
Usage /etc/init.d/openfire {start|stop|restart|status|condrestart|reload}
# /etc/init.d/openfire start
Starting openfire:
1.3.3、用eclipse运行
详见:http://blog.csdn.net/kl222/article/details/22404079
1.4、配置
访问openfire服务器地址: http://192.168.0.128:9090 ,初始账户:admin,密码admin;就可以配置 openfire
如果是第一次启动,则会出现下面配置界面:http://127.0.0.1:9090/setup/index.jsp
网关配置:
现在可以支持msn、gtalk、icq等,qq、人人网等属于试验型的。但我测试没有通过。
选中你要的网关类型,点测试,看是否能成功,如果成功,则表示可以通信。我测试msn可以测试通过,但是客户端不能在msn注册。测试gtalk可以成功,也可以登录。好象gtalk服务器也是基于xmpp的,端口也是用的5222
建立一个账户 a
2、安装spark
windows7旗舰版
jdk7
spark2.6.3
2.1、spark下载
spark安装包有两种,一个带jdk的,一个不带jdk的,下载带jdk的,双击安装即可
登录后在工具栏上会出现gtalk的图标
把a账户与gtalk账户进行绑定
输入gtalk账户
gtalk账户登录成功
好了,现在可以自由的与gtalk通信了。