Linux如何擴(kuò)大文件打開(kāi)的數(shù)量
Linux下當(dāng)你在做Tsung壓力測(cè)試的時(shí)候,可能需要建立多個(gè)tcp請(qǐng)求,但系統(tǒng)的文件打開(kāi)數(shù)是固定的,無(wú)法滿(mǎn)足需求,這是就需要修改文件打開(kāi)數(shù),下面小編就給大家介紹下如何修改Linux系統(tǒng)的文件打開(kāi)數(shù)吧。
操作系統(tǒng)版本:Redhat 5.4
問(wèn)題背景:Tsung壓力測(cè)試,想要盡可能多地建立tcp請(qǐng)求,發(fā)現(xiàn)每次只能建立1013個(gè)請(qǐng)求。
原因分析:Linux默認(rèn)的文件打開(kāi)數(shù)是1024,減掉其他地方用掉的11個(gè),剩下的就是1013個(gè)了。
解決方案:
1)先用ulimit -n或ulimit -a命令,發(fā)現(xiàn)文件打開(kāi)數(shù)是1024
復(fù)制代碼代碼如下:
[root@SamuluIndex ~]# ulimit -n
1024
2)用ulimit -n 65535把文件打開(kāi)數(shù)改為最大值65535,再用ulimit -n驗(yàn)證發(fā)現(xiàn)修改成功
代碼如下:
[root@SamuluIndex ~]# ulimit -n 65535
[root@SamuluIndex ~]# ulimit -n
65535
此時(shí)跑一下tsung start,發(fā)現(xiàn)仍然只能建立1013個(gè)請(qǐng)求。另外,重新登錄后,發(fā)現(xiàn)文件打開(kāi)數(shù)重置回默認(rèn)的1024。說(shuō)明此方案不通。
3)在/etc/security/limits.conf最后增加如下兩行記錄
代碼如下:
* soft nofile 65535
* hard nofile 65535
重新驗(yàn)證,成功。
補(bǔ)充資料:
修改linux系統(tǒng)最大打開(kāi)文件數(shù)
當(dāng)前設(shè)置最大打開(kāi)文件數(shù)可以通過(guò)如下命令查看。
ulimit -n
這個(gè)數(shù)字說(shuō)明了一個(gè)普通用戶(hù)能夠在一個(gè)單獨(dú)會(huì)話(huà)中所能打開(kāi)最大的文件數(shù)目。
注意。如果是root,以下操作不能使ulimit -n的輸出增加。因?yàn)橛脩?hù)root用戶(hù)不受這個(gè)ulimit限制。只有普通用戶(hù)才會(huì)受這個(gè)限制。
為了提高最大打開(kāi)文件數(shù)到默認(rèn)值1024以上, 需要在系統(tǒng)上修改2個(gè)地方。
在這個(gè)案例中, 我們將最大打開(kāi)文件數(shù)增加到2048。 所有的步驟需要root用戶(hù)操作。普通用戶(hù)需要重新登錄才能使設(shè)置生效。
1. 按照最大打開(kāi)文件數(shù)量的需求設(shè)置系統(tǒng),并且通過(guò)檢查/proc/sys/fs/file-max文件來(lái)確認(rèn)最大打開(kāi)文件數(shù)已經(jīng)被正確設(shè)置。
# cat /proc/sys/fs/file-max
如果設(shè)置值太小, 修改文件/etc/sysctl.conf的變量到合適的值。 這樣會(huì)在每次重啟之后生效。如果設(shè)置值夠大,跳過(guò)下步。
# echo 2048 》 /proc/sys/fs/file-max編輯文件/etc/sysctl.conf,插入下行。
fs.file-max = 2048
2. 在/etc/security/limits.conf文件中設(shè)置最大打開(kāi)文件數(shù), 下面是一行提示:
#《domain》 《type》 《item》 《value》添加如下這行。
* - nofile 2048
這行設(shè)置了每個(gè)用戶(hù)的默認(rèn)打開(kāi)文件數(shù)為2048。
注意“nofile”項(xiàng)有兩個(gè)可能的限制措施。就是《type》項(xiàng)下的hard和soft。
要使修改過(guò)得最大打開(kāi)文件數(shù)生效,必須對(duì)這兩種限制進(jìn)行設(shè)定。
如果使用“-”字符設(shè)定《type》, 則hard和soft設(shè)定會(huì)同時(shí)被設(shè)定。
硬限制表明soft限制中所能設(shè)定的最大值。
soft限制指的是當(dāng)前系統(tǒng)生效的設(shè)置值。
hard限制值可以被普通用戶(hù)降低。但是不能增加。
soft限制不能設(shè)置的比hard限制更高。
只有root用戶(hù)才能夠增加hard限制值。
當(dāng)增加文件限制描述,可以簡(jiǎn)單的把當(dāng)前值雙倍。
例子如下, 如果你要提高默認(rèn)值1024, 最好提高到2048, 如果還要繼續(xù)增加, 就需要設(shè)置成4096。
3.Add the following line to the /etc/pam.d/login and /etc/pam.d/xdm file, if it does not already exist:
session required /lib/security/pam_limits.so
4. logout and logon
或者在shell配置文件里面動(dòng)態(tài)加載。
如.bashrc里加:
ulimit -HSn 2048
二、安裝
tar zxvf mysql-5.1.50-linux-i686-glibc23.tar.gz
cp -rf mysql-5.1.50-linux-i686-glibc23 /usr/local/
cd /usr/local/
mv mysql-5.1.50-linux-i686-glibc23/ mysql
安裝為默認(rèn)的路徑,這樣就不用為程序目錄做軟鏈接了
groupadd mysql
useradd -g mysql mysql
cd mysql/
cp support-files/my-medium.cnf /etc/my.cnf
sed -i ‘s/log-bin=mysql-bin/#log-bin=mysql-bin/g’ /etc/my.cnf
sed -i ‘s/binlog_format=mixed/#binlog_format=mixed/g’ /etc/my.cnf
sed -i ‘s/skip-locking/skip-locking/nmax_connections = 1000/nwait_timeout = 5/g’ /etc/my.cnf
接下來(lái)初始化數(shù)據(jù)庫(kù)
scripts/mysql_install_db --user=mysql
安裝mysql服務(wù)控制
cp support-files/mysql.server /etc/rc.d/init.d/mysqld
chmod 755 /etc/rc.d/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld on
service mysqld start
bin/mysqladmin -u root password 123654
上面就是Linux下修改文件打開(kāi)數(shù)的方法介紹了,通常文件的打開(kāi)數(shù)是絕對(duì)夠用的,如果你確實(shí)需要修改文件打開(kāi)數(shù)的話(huà)可以試試本文介紹的方法,您還在等什么?