前言
- Openfire 是免费的、开源的、基于可拓展通讯和表示协议(XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 安装和使用都非常简单,并利用 Web 进行管理。单台服务器可支持上万并发用户。可以使用它轻易的构建高效率的即时通信服务器。由于是采用开放的XMPP协议,您可以使用各种支持XMPP协议的IM客户端软件登陆服务.
1、配置准备工作
-
1)配置服务器准备工作
-
下载相关软件
jdk-8u91-macosx-x64.dmg
openfire_4_1_1.dmg
spark_2_8_3.dmg
-
Openfire 服务器配置软件下载地址
- Openfire v4.1.2 for Mac,密码:p5gv。
- Spark v2.8.3 for Mac,密码: fvw6。
-
-
2)配置服务器注意事项
提前下载好相关软件,且安装目录最好安装在全英文路径下。如果路径有中文名,那么可能会出现一些莫名其妙的问题。
-
在安装配置 Openfire 或其他 xmpp 服务器前,需要先安装 MySQL 数据库。
- MySQL 安装具体讲解见 MySQL 数据库配置。
-
3)示例配置环境
- macOS 10.11.6
- macOS 10.13.3
2、下载安装 Openfire
-
在 Openfire 官网下载最新的 Mac 版本 Openfire 安装包。
-
下载完后双击安装包,点击 pkg 文件,在安装引导下进行傻瓜式安装。安装完成后,进入系统偏好设置,点击 Openfire 图标。
-
进入 Openfire 偏好设置界面。点击 Start Openfire,让 OpenFire 服务开始启动(默认是启动的),启动完毕后,我们就可以点击 Administration 下的按钮 Open Admin Console,进入服务器后台,然后会要求输入管理员账号密码。
-
Openfire 服务启动不了问题解决
安装好之后,第一次是可以启动 openfire 服务器的,但是电脑重启后,就再也不能启动服务器了,每次一点击 “Start Openfire”,然后加载一下,状态还是 “Start Openfire” 没变化,有时甚至还会跳出错误提示框,提示 “Could not start the Openfire server”。
-
解决方案如下:
-
1)首先需要确认是否已经安装了 Java 的运行环境,以及 JAVA jdk 是否与当前 macOS 系统版本,Openfire 版本成对应,如果不是,就请先安装相匹配对应的软件。
- 在终端中输入
java -version
,就可以查看电脑有没有安装 JAVA 运行环境。
- 在终端中输入
-
2)如果软件,环境对应的,最终的解决办法是
-
1> 打开终端,输入以下命令:
# 获取 Openfire 目录的访问权限
$ sudo chmod -R 777 /usr/local/openfire/bin # 以超级管理员的权限运行脚本
$ sudo su # 打开 openfire 路径
cd /usr/local/openfire/bin # 设置 Java 的环境变量
export JAVA_HOME=`/usr/libexec/java_home` # 输出检验环境变量的值
echo $JAVA_HOME-
输入上面的命令后回车,就会出现后面的这些语句
/Library/Java/JavaVirtualMachines/jdk1.8.0_121.jdk/Contents/Home
-
-
2> 接着在终端,输入以下命令:
cd /usr/local/openfire/bin # 运行 Openfire shell 脚本
./openfire.sh-
输入上面的命令后回车,就会出现后面的这些语句
Openfire 4.1.2 [2016-2-21 2:47:51]
管理平台开始监听:
http://qianchia-macbookair.local:9090
https://qianchia-macbookair.local:9091
Successfully loaded plugin 'admin'.
-
3> 执行完这些命令之后,服务器就可以启动了,每次开机后,都启动不了的话,都试下这个方法。
-
-
3、配置 Openfire 服务器
- 在 Openfire 偏好设置界面中,点击 Open Admin Console,进入 web 配置页面,开始配置 Openfire 服务器。
3.1 选择语言
-
简体中文
3.2 服务器设置
域:如果只是本地机器上登录,可以设置为本地的域 127.0.0.1。需要远端登录的话,设置为相应的 IP 地址或域名即可。此处设置为 Mac 的机器名。
-
Server Host Name (FQDN):服务器名,不能为 IP 地址。
3.3 数据库设置
-
1)选择数据库
-
前期 MySQL 数据库准备工作
MySQL 安装具体讲解见 MySQL 数据库配置。
-
1> 设置 /usr/local/openfire 文件夹的访问权限为可读写
-
方法 1:在 finder 中前往文件夹 /usr/local/,右键 openfire 文件夹,显示简介,点击如图右下角中的锁图标解锁,并设置权限为可以读写。
-
方法 2:打开终端,输入如下命令,其中 777 表示授权可读写权限,000 表示无访问权限。
$ sudo chmod 777 /usr/local/openfire
-
-
2> 在终端中登陆 MySQL,输入以下命令,然后输入数据库的 root 密码登录
# 登录 mysql
$ mysql -u root -p-
输入原 root 账户密码,登录成功后终端会输出:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 946
Server version: 5.7.17 MySQL Community Server (GPL) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. -
如果终端输出以下提示,需将 mysql 添加到系统环境变量。
-bash: mysql: command not found
-
-
3> 在终端输入以下命令,创建数据库 openfire
create database openfire;
-
回车后,终端输出
Query OK, 1 row affected (0.03 sec)
-
-
4> 在终端输入以下命令,导入 openfire 资源文件夹 resources/database 下的数据表
use openfire; source /usr/local/openfire/resources/database/openfire_mysql.sql
-
在终端出现一排导入过程
Query OK, 1 row affected (0.00 sec) Query OK, 1 row affected (0.00 sec) Query OK, 1 row affected (0.00 sec) mysql>
-
* 5> 在终端输入以下命令,刷新权限 ```objc
flush privileges;-
回车后,终端输出
Query OK, 0 rows affected (0.07 sec)
-
6> 在终端输入以下命令,退出 MySQL
exit
-
如果要设置外部数据库(推荐,比如:MySQL),选择标准数据库连接。
-
-
2)设置数据库连接
-
设置标准数据库连接
-
1> 数据库驱动选项
- 选择 MySQL,前提是已安装 MySQL。
-
2> JDBC 驱动程序类
-
默认不变,默认为:
com.mysql.jdbc.Driver
-
-
3> 数据库 URL
-
形式如下:
jdbc:mysql://你的主机名:端口号/数据库名称 jdbc:mysql://[host-name]:3306/[database-name]?rewriteBatchedStatements=true
- [host-name] :主机名
- [database-name]:数据库名称
-
这里设置为:
jdbc:mysql://localhost:3306/openfire
- 其中主机名 [host-name] 改为 localhost。
- 其中数据库名称 [database-name] 改为 openfire。
-
解决数据库字符编码问题,可以在后面加
?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8
-
最终的 url 形式是
jdbc:mysql://localhost:3306/openfire?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8
-
注意:前提是已存在一个名为 openfire 的数据库,否则会报如下错误,连接配置不成功。openfire 数据库的创建具体见前面所讲的 “前期 MySQL 数据库准备工作”。
- The Openfire database schema does not appear to be installed. Follow the installation guide to fix this error.
-
-
4> 用户名和密码
-
这里的用户名密码,是访问 MySQL 数据库时使用的帐号和密码。
- 用户名:root
- 密码:root 账户密码
-
-
3.4 配置文件设置
-
如果不打算使用 LDAP,则保持默认设置即可。
-
特性设置时出错问题解决
-
解决方法
- 在 OpenFire 偏好设置中重启 OpenFire,然后重新进入 OpenFire web 配置页面,重新开始配置 Openfire 服务器即可。
-
3.5 管理员账户设置
-
可以随便填写一个管理员邮箱,输入要设置的密码即可。管理员账号默认为 "admin",如果不设置密码,则默认密码为 "admin"。
-
自定义管理员账户名方法
-
在终端输入以下命令,输入数据库的 root 密码,登陆具体的数据库(openfire)
$ mysql -u root -p openfire
-
删除表 “ofUser” 中的 admin 帐户
delete from ofUser where username = 'admin';
-
创建自定义管理员(用户名:qianchia,密码:123456)
insert into ofUser (username, plainPassword, encryptedPassword, name, email, creationDate, modificationDate) values('qianchia','123456','123456','Administrator','qianchia@icloud.com','0','0');
-
查看用户
select * from ofUser;
-
如果可以往数据库里插入用户但是在用户摘要却没有数据,这是因为 openfire 的数据库驱动包太旧了,而安装的数据库太新了,把 openfire 里的驱动包换成新的就行了,路径:/usr/local/openfire/lib。
-
-
3.6 登陆管理控制台
-
完成安装后可以输入用户名和密码登陆管理控制台
-
默认的管理员帐号是 “admin”,默认管理员密码 “admin”,如果上面设置了新密码,则管理员密码是新密码。如果重设了用户名,必须重启 openfire 服务器。
-
无法登录管理控制平台问题解决
安装 Openfire 后 admin 无法登录管理控制平台。登录时提示:Login failed:make sure your username and password are correct and that you’re an admin or moderator。
-
解决方案如下:
-
1)使用 MySQL 管理工具(如 MySQL Workbench)进入数据库,进入表 “ofuser”,将该表清空
-
然后执行该 SQL
INSERT INTO ofUser (username, plainPassword, name, email, creationDate, modificationDate) VALUES ('admin', 'admin', 'Administrator', 'admin@example.com', '0', '0');
-
2)关闭 Openfire 服务,就是从其控制台 stop 然后再 start,再用用户名:admin,密码:admin 登录即可。
-
4、测试 Openfire 服务器
4.1 添加测试账户
-
服务器配置完成之后,我们可以创建几个用户,然后客户端可以使用这些用户信息登录,互相传输消息。
4.2 XMPP 客户端设置与使用
有许多通信聊天客户端可以支持 XMPP 协议,比如,Mac 电脑就自带了一个 “信息” app,“信息” app 就支持 jabber 通信协议(XMPP 的别名)。
-
打开 Mac 的 “信息” app,点击菜单 信息 -> 添加账户,选择其他 “信息” 账户...
-
选择 jabber 账户类型,填写相关信息
- 账户类型:Jabber
- 用户名:上边添加的测试账户名,格式必须为:
名称@openfire服务器名称
- 密码:用户名对应的密码
- 服务器:openfire 服务器地址,可以使用自动查找服务器和端口
- 端口:openfire 服务器客户端端口
-
然后,提示验证证书,选择继续。
-
登录成功。
-
登录成功后在 openfire 服务器端可以看到用户的登录状态。
5、卸载 Openfire 服务器
-
1)卸载之前首先要停止 Openfire 服务。
-
系统偏好中点击 Openfire 图标,如下图
-
在 Openfire 偏好设置界面中,点击 Stop Openfire。
-
-
2)删除 Openfire 文件。
-
在终端里,输入以下三条命令执行即可。
$ sudo rm -rf /Library/PreferencePanes/Openfire.prefPane
-
以上执行后需要输入管理员密码。
$ sudo rm -rf /usr/local/openfire $ sudo rm /Library/LaunchDaemons/org.jivesoftware.openfire.plist
-
6、常见问题
-
1)每次重启 Mac 电脑都需要重新配置 Openfire 问题
-
解决方法:
- 打开 /usr/local/openfire/conf/ 文件夹。
- 将 openfire.xml 和 security.xml 两个文件的权限设置为读与写。
- 重新完成 Openfire 配置。
-