• LINUX提高openfire并发数(网上收集)


    谷歌博客地址:http://tsaiquinn.blogspot.com/2014/10/linuxopenfire.html

    影响连接数的元素包含三种:
    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系统属性

    修改openfire内存:在bin目录下面的openfire    " # INSTALL4J_ADD_VM_PARAMS= "  改为 "  INSTALL4J_ADD_VM_PARAMS="-Xms256m -Xmx3584m"   "大小可自行设置

    cache.username2roster.size: 12000000
    cache.group.size: 40000000
    cache.userCache.size: 35000000
    cache.lastActivity.size: 1500000
    cache.offlinePresence.size: 1500000

  • 相关阅读:
    两台oracle数据库相互导数据(转载)
    resin之jvm优化
    求一表中每一个类别共有几条记录数
    jQuery+Ajax+Struts2.0
    改进nginx访问resin的性能
    通过web修改squid用户上网密码
    jvm优化
    Samba通过ad域进行认证并限制空间大小
    Samba 与squid 都可以统一使用域(AD)验证
    ASP.NET 下载文件
  • 原文地址:https://www.cnblogs.com/Tsai_Quinn/p/4043906.html
Copyright © 2020-2023  润新知