openfire压测概述

Openfire采用Java开发,基于XMPP(Jabber)协议,开源的即时通讯服务器。一直以来,对于服务器的支持最大用户数总是让人感到疑问,官方甚至还是几年前的5k。在熟悉了openfire源码后,我决定花些时间测试一下openfire的极限。经过约1个月左右的测试,总算得到预定目标(3台服务器,并发50w用户在线)

测试环境搭建

压测客户端无他-tsung,尝试了windows安装perl失败后,使用centOS6.5作为压测机

压测服务器,因为集群需要大内存,因而安装了64位的centos6.7.

所幸这些都可以使用vmware虚拟机,只要装好一台,通过简单copy就能复制出多台.实际上,一共也就使用了6台硬件设备.

设备类别        台数        系统                                     虚拟机操作系统                说明

OF服务器         3           i54570,12G,Win7              CentOS6.7 8G                 其中一台运行mysql数据库

tsung客户机    3           i54570,4G,Win7                 CentOS6.5 1G                虚拟机1G内存,运行3个实例

jvisualvm+mat使用

如果不跑集群,其实openfire还是比较稳定的,单台4G内存情况下,也有运行到25W同时在线的情况。一旦用了hazelcast,反而不稳定了,出现问题就需要使用工具进行定位,看看哪里堵住了。

运行结果与心得:

0.千万不要用OpenJdk的虚拟机,官方推荐用CMS进行GC,那就老实点用JDK7.

1.openfire使用mina作为nio底层实现.实测一秒20-25个新连接还算稳定,超过30个就会堵住.(占用大量内存存储未处理的包-经查,时offlineMessage堵住,tsung去掉发送消息的,就快了)

2.openfire使用hazelcast的缓存机制实现集群。经过实际测试,这货太消耗内存了,20w连接大概需要4G的内存(包含mina连接需要的内存),加上还要互为主备的机制,至少还要1.5G才能实现集群的使用。测试至少要8G内存才行,实际使用推荐12G以上.

3.仅仅是压测同一台服务器,与同时压测多台情况大不相同,后期改进主要集中在数据库性能.(后期改进点-)

4.Linux内核修改limits.conf和net.nf_conntrack_max参数后性能有所提升。

程序优化点:

1.JVM配置优化:

需要自己修改openfire.sh,增加虚假机参数.(hazelcast插件有推荐配置,修改一下就行)

2.offlineMessageStore+squenceManager优化:

前面说过了,mysql最多支持每秒30个的NextID,实际运行offlineMessage会很多,修改使用redis保存离线消息。

3.hazelcast和openfire优化:

hazelcast本身就很多问题,例如一台设备内存满了或者处理超时,那么整个集群就没响应了。如果还是用hazelcast作为集群的缓存,需要剥离到单独的设备上去。

openfire用的是java的序列化,内存用的多,效率慢;hazelcast是支持自定义序列化的,经过比较,我用了kryo作为序列化工具,在对ClientSessionInfo,Roster,RosterItem,User这几个类优化后,内存使用明显小了很多。

SessionManager 把所有的clientSession都放到hashmap中,当用户变得非常大量时候,sessionInfoCache的操作必然影响效率。

4.登录流程简化:

xmpp的登录报文交互太多了,虽然tsung使用最简单的iqauth登录,实际使用还是需要简化登录流程,这点需要客户端配合。

本文出自http://www.cnblogs.com/imparser/p/5156656.html

openfire java集群_优化openfire服务器,达到单机20万,集群50万相关推荐

  1. mysql在ibm上安装教程_在ibm服务器上安装配置MySQL集群的方法

    在ibm服务器上安装配置MySQL集群的方法 2014-07-13 16:45来源:中国存储网 导读:本文只是介绍安装和配置,关于一些名词和原理,请参考MySQL手册.一.环境:IBM x3560Vm ...

  2. java分布式全文检索_分布式全文检索服务器——ElasticSearch(1)

    写在前面 Elaticsearch,简称为es,es是一个开源的高扩展的分布式全文检索引擎,它可以近乎实时的存储.检索数据:本身扩展性很好,可以扩展到上百台服务器,处理PB级别的数据.es也使用Jav ...

  3. 服务器的单机防御与集群防御是什么意思,有什么区别

    只要是互联网覆盖到的地方,基本上都会存在网络攻击,面对网络攻击,最好的办法就是使用高防服务器,在选用高防服务器时我们经常会听到单机防御多少G,集群防御多少G,但是很多人都不知道单机与集防的区别. 1. ...

  4. python aiompq集群_国内首款基于AIO(异步IO)支持集群的高性能开源WebSocket服务器 宝贝鱼 CshBBrain V4.0 发布...

    国内首款基于AIO的开源WebSocket服务器 宝贝鱼 (CshBBrainAIO)正式发布.基于AIO的开源WebSocket服务器 宝贝鱼 依然采用分层的体系结构,协议层和业务层 与 基于NIO ...

  5. 多台电脑集群运算_一个分布式服务器集群架构方案

    深圳市添越智创科技有限公司 店铺链接:shop114963t53p883.1688.com 移动互联应用的快速发展和云计算.大数据应用的拓展和深化,数据中心已由传统的大型机.小型机逐步转移到x86服务 ...

  6. java 应用是单机集群_【架构】Tomcat单机部署多应用Windows

    Tomcat单机部署多应用-Windows 1.添加新增的Tomcat相关环境变量 CATALINA_BASE = C:\tomcat1 CATALINA_HOME = C:\tomcat1 TOMC ...

  7. couchbase集群_使用CLI扩展和重新平衡Couchbase集群

    couchbase集群 Couchbase通过多种方式提供高可用性和灾难恢复 : 同质簇 复写 集群内复制 备份还原 机架区意识 该博客将展示如何使用Couchbase命令行界面(CLI)创建Couc ...

  8. java动画闪烁_优化Java动画编程中的显示效果

    Java动画编程有多种实现方法,但它们实现的基本原理是一样的,即在屏幕上画出一系列的帧来造成运动的感觉.Java多线程技术是Java动画编程中普遍运用的技术,它在控制动画程序的流程和动画的显示效果方面 ...

  9. k8s 手动恢复redis 集群_二进制手动部署k8s-1.14高可用集群(二、集群部署)

    1. CA证书(任意节点) 1.1 安装cfssl cfssl是非常好用的CA工具,我们用它来生成证书和秘钥文件 安装过程比较简单,如下: # 下载 $ mkdir -p ~/bin $ wget h ...

最新文章

  1. logback:用slf4j+logback实现多功能日志解决方案
  2. java基础知识之循环结构与数组
  3. python读取excel表格-python xlrd读取excel(表格)详解
  4. A* 寻路 +寻路演示(js)
  5. oracle创建主键开并行,Oracle并行添加主键
  6. linux下面java配置,linux下面配置java环境变量
  7. Git命令集之六——查看仓库状态
  8. 3月11日Linux课程笔记
  9. 优秀的 Spring Boot 语言开源项目
  10. CentOS+Subversion 配置Linux 下 SVN服务器
  11. Rhadoop集群搭建
  12. c语言基础--ASCII码表
  13. Python读取视频方法
  14. 为什么边缘概率密度是联合概率密度的积分_解读奥运积分排名:石宇奇为何第13 林丹谌龙未入前16...
  15. Es,N0,EsN0,EbN0,SNR关系详解
  16. 如何一键生成字幕,如何快速处理生肉资源?借助whisper语音识别系统生成.srt字幕文件 手把手教学在Windows、CPU版本下whisper的安装与使用,快速上手!
  17. iptables防火墙
  18. Java实习面试重点基础知识
  19. 已解决TypeError: Descriptors cannot not be created directly.
  20. CVX工具包(for matlab)

热门文章

  1. tar压缩解压缩命令详解
  2. 扩展系统功能——装饰模式
  3. C语言 双向链表的增删改查
  4. Libra教程之:来了,你最爱的Move语言
  5. python声明数组_在Python中如何声明动态数组
  6. 揪出XXL-JOB中的细节
  7. free和top显示可用内存不一致
  8. 09.multi-get api操作
  9. IDEA 2020.3版本中的lombok失效问题
  10. 1017 Queueing at Bank (25 分)_27行代码AC