2014年10月22日星期三

LINUX 安装JDK (rpm格式和tar.gz格式)

JDK rpm方式:
我使用的是SecureCRT,先下载了然后再上传的,也可以直接在linux中下载安装。首先安装上传文件的工具,使用FTP上传也可以
 yum  install   lrzsz
安装完成后,输入rz,选择文件然后确定开始上传:




然后在usr文件夹下创建java文件夹,并移动到此文件夹,解压,稍后可以 在/usr/java 路径中输入 rm -rf jdk-7u65-linux-x65.rpm进行删除









输入 vim  /etc/profile 进行编辑,在后面加入路径
先按esc键,然后输入:wq保存退出,为了使其生效,输入 source /etc/profle ,然后输入java -version 进行验证









 tar.gz 解压文件方式
使用tar.gz解压文件的方式,解压文件到usr/java文件夹下,没有java文件夹则新建一个java文件夹
在usr 路径下执行  mkdir java
解压文件到java文件夹下   我的压缩文件是在home文件夹下
tar -zxvf jdk-7u65-linux-x64.tar.gz -C /usr/java 





设置环境变量
vim /etc/profile  
在最后面添加











保存退出,执行
source /etc/profile  使刚刚的设置生效
查看java 是否设置好了
输入 java -version

2014年10月15日星期三

LINUX提高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