Openfire使用上的一些技巧

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/48652745 Openfire使用上的一些技巧作者:chszs,版权所有,未经同意,不得转载。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/48652745

Openfire使用上的一些技巧

作者:chszs,版权所有,未经同意,不得转载。博主主页:http://blog.csdn.net/chszs

1、把Openfire安装为系统服务

对于RedHat、CentOS、Fedora之类的系统,可以采用RPM包安装Openfire,安装后自然有了Openfire服务。此时可以通过命令启动或停止Openfire:

# /etc/init.d/openfire stop/start/restart/reload

如果是通过.tar.gz解压安装的Openfire,那么Openfire的启动或停止可以通过命令:

# ./bin/openfire start/stop

这种方式下,要把Openfire安装为系统服务,在Openfire的bin/extra子目录下有两个脚本:

1)redhat-postinstall.sh脚本

适合RedHat系统,可以自动把Openfire安装为系统服务。它会创建一个名为“jive”的用户,并把openfired复制到init.d目录,且此脚本必须以root权限执行。

2)openfired脚本

把Openfire作为系统服务的脚本。必须手动配置此脚本。稍后详细介绍如何配置。

2、自定义参数

高级用户在运行Openfire时,可以传递一些参数给JVM,以获得更好的性能。
如果Openfire是通过RPM安装的,那么可以编辑/etc/sysconfig/openfire,找到OPENFIRE_OPTS选项进行调整。
如果是通过TAR解压安装的,那么需要自行调整启动脚本以满足所需。

3、插件

插件使得Openfire可以支持额外的功能和协议。在服务器安装Openfire后,可以下载并安装插件来增强Openfire服务器。插件可以从igniterealtime.org插件页面或直接在管理控制台下载。
插件网页:http://www.igniterealtime.org/projects/openfire/plugins.jsp

1)安装插件

如果是从服务器的管理控制台下载插件,那么插件会自动安装。
如果是手动下载的插件(jar文件),可以将此插件文件复制到Openfire的plugins子目录。Openfire的插件监视器会自动扫描到新插件并自动完成安装。Openfire的管理控制台有“上传插件”功能,可以从本地文件系统上传插件并自动完成加载。

2)管理插件

可以在Openfire的管理控制台进行管理。可以手动删除plugins子目录的插件JAR文件,Openfire会自动从内存中删除插件,并删除它的目录。

4、添加中文支持

在conf子目录编辑openfire.xml配置文件,在处添加以下内容:

?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8
即:
<driver>com.mysql.jdbc.Driver</driver>
      <serverURL>jdbc:mysql://111.111.111.11:3306/openfiredb?rewriteBatchedStatements=true?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8</serverURL>
      <username encrypted="true">08d7675ce83b8f765d0eaasdfasasdf9d8943ad4f8edf</username>
      <password encrypted="true">d1e1f004f6c252e04ab0ae6d02beb14e471e6002e0bb621</password>
      <testSQL>select 1</testSQL>

5、修改Openfire的Domain域值

与Tigase不同,Openfire安装后,它的配置属性不是写入XML文件中,而是基本上都存到数据库表里。
配置属性所在的数据表为ofProperty表

mysql> select * from ofProperty;
+--------------------------------------------+----------------------------------------------------------------------------------+
| name                                       | propValue                                                                        |
+--------------------------------------------+----------------------------------------------------------------------------------+
| adminConsole.port                          | 9090                                                                             |
| adminConsole.securePort                    | 9091                                                                             |
| connectionProvider.className               | org.jivesoftware.database.DefaultConnectionProvider                              |
| database.defaultProvider.connectionTimeout | 1.0                                                                              |
| database.defaultProvider.driver            | com.mysql.jdbc.Driver                                                            |
| database.defaultProvider.maxConnections    | 300                                                                              |
| database.defaultProvider.minConnections    | 10                                                                               |
| database.defaultProvider.password          | b10f78asdfasdda441f52345234425215eba110 |
| database.defaultProvider.serverURL         | jdbc:mysql://111.111.111.11:3306/openfiredb?rewriteBatchedStatements=true           |
| database.defaultProvider.testAfterUse      | false                                                                            |
| database.defaultProvider.testBeforeUse     | false                                                                            |
| database.defaultProvider.testSQL           | select 1                                                                         |
| database.defaultProvider.username          | df94csdfas5d71aefb9183asdfs80fbbb7                                 |
| locale                                     | zh_CN                                                                            |
| locale.timeZone                            | Asia/Taipei                                                                      |
| passwordKey                                | 0N5fddsanisYAnD                                                                  |
| provider.admin.className                   | org.jivesoftware.openfire.admin.DefaultAdminProvider                             |
| provider.auth.className                    | org.jivesoftware.openfire.auth.DefaultAuthProvider                               |
| provider.group.className                   | org.jivesoftware.openfire.group.DefaultGroupProvider                             |
| provider.lockout.className                 | org.jivesoftware.openfire.lockout.DefaultLockOutProvider                         |
| provider.securityAudit.className           | org.jivesoftware.openfire.security.DefaultSecurityAuditProvider                  |
| provider.user.className                    | org.jivesoftware.openfire.user.DefaultUserProvider                               |
| provider.vcard.className                   | org.jivesoftware.openfire.vcard.DefaultVCardProvider                             |
| setup                                      | true                                                                             |
| update.lastCheck                           | 1441615953135                                                                    |
| xmpp.auth.anonymous                        | true                                                                             |
| xmpp.domain                                | ubuntu                                                                           |
| xmpp.session.conflict-limit                | 0                                                                                |
| xmpp.socket.ssl.active                     | true                                                                             |
+--------------------------------------------+----------------------------------------------------------------------------------+
29 rows in set (0.00 sec)

可见,domain域的配置见xmpp.domain这一行。
修改它的值即可。

mysql> update ofProperty set propValue='tt.com' where name='xmpp.domain';

但是要注意,要让修改后的domain域生效,需要重启Openfire服务器。

# cd /opt/openfire/
# ./bin/openfire restart
Shutting down openfire
Stopped.
Restarting openfire

此时可以用XMPP客户端进行验证,OK!
但实际上,这一步还没真正完成。Openfire在修改Domain域值后,它相应的证书也就无效了,需要重新生成证书(哪怕是自签名的证书)。而生成自签名的证书步骤可以简单这么做:

1)停止Openfire服务
2)修改conf子目录下的openfire.xml配置文件,把true
改为false
3)启动Openfire
4)浏览器访问http://server:9090,对Openfire重新配置,会自动生成自签名证书来匹配新域值。
5)完成配置,登陆管理控制台,在Admin Console > Server > Server Settings > Server Certificates处删除所有属于旧域名的证书。如果一个证书都没有,那就需要手动产生一个新证书。

6、修改Openfire的IM端口

默认是5222端口,要修改默认的端口,同样修改上面的数据表,找到xmpp.socket.plain.port行,如果没有这一行,那就插入这一行,值改为15222即可。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
关系型数据库 MySQL 数据库
Mysql安装配置详解
Mysql安装配置详解
|
SQL 数据库 数据安全/隐私保护
|
XML Java 数据格式
openfire 插件开发
插件分类 消息等内部插件 这类插件主要用于对 openfire 内消息,状态等扩展 webUI 插件 这类插件主要用于对 openfire 控制台扩展 web接口插件 这类插件主要用于对 openfire 后台接口扩展 插件开发基本流程 实现 Plugin 类 添加 plugin.
1567 0
|
Java 应用服务中间件
|
数据库 分布式计算 Spark
|
分布式计算 数据库 Spark
|
应用服务中间件

热门文章

最新文章