提升openfire最大鏈接數
影響鏈接數的元素包含三種:
1) Linux的系統參數
2) 進程自身能夠建立的線程數
3) Openfire自身系統參數
Linux系統參數
1. Ulimit –n 265535
在Linux平臺上,不管編寫客戶端程序仍是服務端程序,在進行高併發TCP鏈接處理時,最高的併發數量都要受到系統對用戶單一進程同時可打開文件數量的限制(這是由於系統爲每一個TCP鏈接都要建立一個socket句柄,每一個socket句柄同時也是一個文件句柄),這個數字能夠設的更大。
此命令是臨時更改,也能夠經過修改文件/etc/security/limits.conf
2. net.ipv4.ip_conntrack_max=265535
系統容許的最大跟蹤鏈接條目。在/etc/sysctl.conf文件中增長此屬性,並運行>/sbin/sysctl.conf –p
另外在sysctl -p的時候A報error: 'net.ipv4.ip_conntrack_max' is an unknown key ,經過如下命令修正:
modprobe ip_conntrack
echo "modprobe ip_conntrack" >> /etc/rc.local
3. fs.file-max = 265535
系統級別的可以打開的文件句柄的數量,ulimit 是進程級別的
4. kernel.threads-max=265535
系統能夠生成的最大線程數
5. vm.max_map_count=265535
定義了一個進程能擁有的最多的內存區域
6. 其餘參數能夠以下設置:
net.ipv4.conf.default.rp_filter = 1
net.ipv4.conf.default.accept_source_route = 0
kernel.sysrq = 0
kernel.core_uses_pid = 1
net.ipv4.tcp_syncookies = 0
kernel.msgmnb = 265536
kernel.msgmax = 265536
kernel.shmmax = 68719476736
kernel.shmall = 4294967296
net.ipv4.tcp_max_tw_buckets = 6000
net.ipv4.tcp_sack = 0
net.ipv4.tcp_window_scaling = 1
net.ipv4.tcp_rmem = 4096 87380 4194304
net.ipv4.tcp_wmem = 4096 16384 4194304
net.core.wmem_default = 8388608
net.core.rmem_default = 8388608
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
net.core.netdev_max_backlog = 262144
net.core.somaxconn = 262144
net.ipv4.tcp_max_orphans = 3276800
net.ipv4.tcp_max_syn_backlog = 262144
net.ipv4.tcp_timestamps = 0
net.ipv4.tcp_synack_retries = 2
net.ipv4.tcp_syn_retries = 2
net.ipv4.tcp_syn_retries = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_mem = 94500000 915000000 927000000
net.ipv4.tcp_fin_timeout = 1
net.ipv4.tcp_keepalive_time = 1200
net.ipv4.ip_local_port_range = 1024 60000
net.ipv4.tcp_window_scaling=0
net.ipv4.tcp_no_metrics_save=1
JVM參數
JVM中能夠生成的最大數量由JVM的堆內存大小、Thread的Stack內存大小、系統最大可建立的線程數量三個方面影響:
(MaxProcessMemory - JVMMemory - ReservedOsMemory) / (ThreadStackSize) = Number of threads
MaxProcessMemory 指的是一個進程的最大內存
JVMMemory JVM內存
ReservedOsMemory 保留的操做系統內存
ThreadStackSize 線程棧的大小
OpenFire系統屬性
cache.username2roster.size: 12000000
cache.group.size: 40000000
cache.userCache.size: 35000000
cache.lastActivity.size: 1500000
cache.offlinePresence.size: 1500000
注:部分參數未實際檢驗
cookie