溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Linux系統(tǒng)中操作文件數(shù)過(guò)多導(dǎo)致錯(cuò)誤的解決方法

發(fā)布時(shí)間:2021-09-15 15:49:24 來(lái)源:億速云 閱讀:213 作者:chen 欄目:系統(tǒng)運(yùn)維

這篇文章主要講解了“Linux系統(tǒng)中操作文件數(shù)過(guò)多導(dǎo)致錯(cuò)誤的解決方法”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Linux系統(tǒng)中操作文件數(shù)過(guò)多導(dǎo)致錯(cuò)誤的解決方法”吧!

linux 打開(kāi)文件數(shù) too many open files 解決方法

too many open files出現(xiàn)這句提示的原因是程序打開(kāi)的文件/socket連接數(shù)量超過(guò)系統(tǒng)設(shè)定值。
查看每個(gè)用戶(hù)最大允許打開(kāi)文件數(shù)量

代碼如下:


ulimit -a
fdipzone@ubuntu:~$ ulimit -a  
core file size          (blocks, -c) 0  
data seg size           (kbytes, -d) unlimited  
scheduling priority             (-e) 20  
file size               (blocks, -f) unlimited  
pending signals                 (-i) 16382  
max locked memory       (kbytes, -l) 64  
max memory size         (kbytes, -m) unlimited  
open files                      (-n) 1024  
pipe size            (512 bytes, -p) 8  
POSIX message queues     (bytes, -q) 819200  
real-time priority              (-r) 0  
stack size              (kbytes, -s) 8192  
cpu time               (seconds, -t) unlimited  
max user processes              (-u) unlimited  
virtual memory          (kbytes, -v) unlimited  
file locks                      (-x) unlimited  


其中 open files (-n) 1024 表示每個(gè)用戶(hù)最大允許打開(kāi)的文件數(shù)量是1024

查看當(dāng)前系統(tǒng)打開(kāi)的文件數(shù)量

代碼如下:


lsof | wc -l  
watch "lsof | wc -l"  


查看某一進(jìn)程的打開(kāi)文件數(shù)量

代碼如下:


lsof -p pid | wc -l  
lsof -p 1234 | wc -l  


設(shè)置open files數(shù)值方法

代碼如下:


ulimit -n 2048
fdipzone@ubuntu:~$ ulimit -n 2048  
fdipzone@ubuntu:~$ ulimit -a  
core file size          (blocks, -c) 0  
data seg size           (kbytes, -d) unlimited  
scheduling priority             (-e) 20  
file size               (blocks, -f) unlimited  
pending signals                 (-i) 16382  
max locked memory       (kbytes, -l) 64  
max memory size         (kbytes, -m) unlimited  
open files                      (-n) 2048  
pipe size            (512 bytes, -p) 8  
POSIX message queues     (bytes, -q) 819200  
real-time priority              (-r) 0  
stack size              (kbytes, -s) 8192  
cpu time               (seconds, -t) unlimited  
max user processes              (-u) unlimited  
virtual memory          (kbytes, -v) unlimited  
file locks                      (-x) unlimited


這樣就可以把當(dāng)前用戶(hù)的最大允許打開(kāi)文件數(shù)量設(shè)置為2048了,但這種設(shè)置方法在重啟后會(huì)還原為默認(rèn)值。

永久設(shè)置方法

代碼如下:


vim /etc/security/limits.conf  


在最后加入 

代碼如下:


* soft nofile 4096  
* hard nofile 4096  


最前的 * 表示所有用戶(hù),可根據(jù)需要設(shè)置某一用戶(hù),例如

代碼如下:


fdipzone soft nofile 8192  
fdipzone hard nofile 8192


改完后注銷(xiāo)一下就能生效。

linux Argument list too long錯(cuò)誤解決方法

上一次需要?jiǎng)h除/tmp目錄下的所有文件,文件數(shù)量比較多。

代碼如下:


ls -lt /tmp | wc -l  
385412  


使用 rm * 后,系統(tǒng)提示錯(cuò)誤 Argument list too long
原因是在linux下,試圖傳太多參數(shù)給一個(gè)系統(tǒng)命令(ls *; cp *; rm *; cat *; etc..)時(shí),就會(huì)出現(xiàn) Argument list too long錯(cuò)誤。

解決方法如下:
使用find -exec 遍歷,然后執(zhí)行刪除便可。

代碼如下:


sudo find /tmp -type f -exec rm {} \;  

感謝各位的閱讀,以上就是“Linux系統(tǒng)中操作文件數(shù)過(guò)多導(dǎo)致錯(cuò)誤的解決方法”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Linux系統(tǒng)中操作文件數(shù)過(guò)多導(dǎo)致錯(cuò)誤的解決方法這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI