Linux的一些知識(shí)

Linux OS版本

yum install -y redhat-lsb

[root@bigdata001 xxx]# lsb_release -a
LSB Version:    :core-4.1-amd64:core-4.1-noarch:cxx-4.1-amd64:cxx-4.1-noarch:desktop-4.1-amd64:desktop-4.1-noarch:languages-4.1-amd64:languages-4.1-noarch:printing-4.1-amd64:printing-4.1-noarch
Distributor ID: CentOS
Description:    CentOS Linux release 7.7.1908 (Core)
Release:    7.7.1908
Codename:   Core

vi文件保存退出命令":wq"和":x"的區(qū)別

:wq 強(qiáng)制性寫入文件并退出。即使文件沒(méi)有被修改也強(qiáng)制寫入,并更新文件的修改時(shí)間。

:x 寫入文件并退出。僅當(dāng)文件被修改時(shí)才寫入,并更新文件修改時(shí)間,否則不會(huì)更新文件修改時(shí)間。

ulimit -a 查看用戶能打開的最大進(jìn)程數(shù)

[root@bigdata001 bd_manager]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 513726
max locked memory       (kbytes, -l) unlimited
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1048576
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) 65536
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

max user processes (-u) 65536 當(dāng)前用戶(root)最多能創(chuàng)建65536個(gè)進(jìn)程

Linux Thread

線程資源限制由以下幾個(gè)系統(tǒng)參數(shù)共同決定:

/proc/sys/kernel/threads-max,有直接關(guān)系,每個(gè)進(jìn)程中最多創(chuàng)建的的線程數(shù)目
/proc/sys/kernel/pid_max,有直接關(guān)系,系統(tǒng)中最多分配的pid(進(jìn)程)數(shù)量
/proc/sys/vm/max_map_count,限制一個(gè)進(jìn)程可以擁有的虛擬內(nèi)存區(qū)域(VMA)的數(shù)量數(shù)量越大,能夠創(chuàng)建的線程數(shù)目越多

[bd@bigdata001 ~]$ cat /proc/sys/kernel/threads-max 
1027453
[bd@bigdata001 ~]$ cat /proc/sys/kernel/pid_max 
32768
[bd@bigdata001 ~]$ cat /proc/sys/vm/max_map_count 
262144

查看某個(gè)進(jìn)程狀態(tài)

//得到進(jìn)程號(hào)
ps -ef | grep nodemanager
//根據(jù)進(jìn)程號(hào)獲取指定進(jìn)程當(dāng)前的限制狀況
cat /proc/pidxxx/limits

sysctl命令

用于運(yùn)行時(shí)配置或顯示內(nèi)核參數(shù),這些參數(shù)位于/proc/sys目錄下
比如,永久修改

sysctl -w kernel.pid_max=4194303
sysctl -w kernel.threads-max=2061206
sysctl -w vm.max_map_count=4194303

unable to create new native thread

當(dāng)發(fā)現(xiàn)unable to create new native thread后,應(yīng)該先找到報(bào)錯(cuò)的進(jìn)程號(hào),然后執(zhí)行cat /proc/$pid/limits,查看Max processes參數(shù),而不是直接就去執(zhí)行ulimit -u查看max user processes。

因?yàn)椋?/h5>

修改max user processes(用戶創(chuàng)建最大線程數(shù))立即生效,是對(duì)操作系統(tǒng)而言的。

對(duì)于修改后系統(tǒng)直接創(chuàng)建的進(jìn)程這個(gè)修改是有效的;

對(duì)于在修改時(shí)是運(yùn)行狀態(tài)的進(jìn)程(稱作A),這個(gè)修改是無(wú)效的;

修改后,A再創(chuàng)建子進(jìn)程B,那么這個(gè)修改對(duì)B也是無(wú)效的,B的Max processes繼承自A而不是操作系統(tǒng)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容