在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

LINUX中進程的最大理論數(shù)計算

科技綠洲 ? 來源:Linux開發(fā)架構(gòu)之路 ? 作者:Linux開發(fā)架構(gòu)之路 ? 2023-11-09 09:17 ? 次閱讀

LINUX中進程的最大理論數(shù)計算

  • 每個進程都要在全局段描述表GDT中占據(jù)兩個表項

每個進程的局部段描述表LDT都作為一個獨立的段而存在,在全局段描述表GDT中要有一個表項指向這個段的起始地址,并說明該段的長度以及其他一些 參數(shù)。除上之外,每個進程還有一個TSS結(jié)構(gòu)(任務(wù)狀態(tài)段)也是一樣。所以,每個進程都要在全局段描述表GDT中占據(jù)兩個表項。

  • GDT的容量有多大呢?

寄存器中用作GDT表下標的位段寬度是13位,所以GDT中可以有213=8192213=8192個描述項。

除一些系統(tǒng)的開銷(例如GDT中的第2項和第3項分別用于內(nèi)核 的代碼段和數(shù)據(jù)段,第4項和第5項永遠用于當前進程的代碼段和數(shù)據(jù)段,第1項永遠是0,等等)以外,尚有8180個表項可供使用,所以理論上系統(tǒng)中最大的 進程數(shù)量是8180/2=40908180/2=4090。

所以系統(tǒng)中理論上最大的進程數(shù)是4090

系統(tǒng)中可創(chuàng)建的進程數(shù)實際值

linux內(nèi)核通過進程標識值(process identification value)-PID來標示進程,PID是一個數(shù),類型位pid_t, 實際上就是int類型

為了與老版本的Unix或者Linux兼容,PID的最大值默認設(shè)置位32768(short int 短整型的最大值)。

  • 查看

可以使用cat /proc/sys/kernel/pid_max來查看系統(tǒng)中可創(chuàng)建的進程數(shù)實際值

圖片

  • 修改
ulimit -u 655351

設(shè)置完以后,雖然我們設(shè)置戶創(chuàng)建進程數(shù)的硬限制和軟限制都是65535,但是我們還不能使用創(chuàng)建65535個進程

我們在Linux還需要設(shè)置內(nèi)核參數(shù)kernel.pid_max,這個參數(shù)我默認安裝都是32768,

所以即使使用root帳戶,卻不設(shè)置這個內(nèi)核參數(shù),整個系統(tǒng)最多可以創(chuàng)建的進程數(shù)就是32768,所以我們需要進行如下設(shè)置:

sysctl -w kernel.pid_max=655351

最大線程數(shù)

linux 系統(tǒng)中單個進程的最大線程數(shù)有其最大的限制 PTHREAD_THREADS_MAX

這個限制可以在/usr/include/bits/local_lim.h中查看 對 linuxthreads 這個值一般是 1024,對于 nptl 則沒有硬性的限制,僅僅受限于系統(tǒng)的資源

這個系統(tǒng)的資源主要就是線程的 stack 所占用的內(nèi)存,用 ulimit -s 可以查看默認的線程棧大小,一般情況下,這個值是8M=8192KB

圖片

可以寫一段簡單的代碼驗證最多可以創(chuàng)建多少個線程

include
#include #include void func()
{}int main(void)
{ int i = 0;
pthread_t thread; while ( 1 )
{ if (pthread_create(&thread, NULL, func, NULL) != 0)
{ return;
} i++; printf("i = %dn", i);
} return EXIT_SUCCESS;
}

圖片

試驗顯示,在我們的系統(tǒng)(Ubuntu-14.04-LTS-64bit)中l(wèi)inuxthreads 上最多可以創(chuàng)建 381 個線程,之后就會返回 EAGAIN

LINUX中單個進程理論上可以創(chuàng)建的最大線程數(shù)

而32位系統(tǒng)中,可以穿件381個線程,這個值和理論完全相符,因為 32 位 linux 下的進程用戶空間是 3G 的大小,也就是 3072M,用3072M/8M=3843072M/8M=384,但是實際上代碼段和數(shù)據(jù)段等還要占用一些空間,這個值應(yīng)該向下取整到 383,再減去主線程,得到 382。

那為什么 linuxthreads 上還要少一個線程呢?這可太對了,因為 linuxthreads 還需要一個管理線程

為了突破內(nèi)存的限制,可以有兩種方法

  • 用ulimit -s 1024減小默認的棧大小
  • 調(diào)用pthread_create的時候用pthread_attr_getstacksize設(shè)置一個較小的棧大小

要注意的是,即使這樣的也無法突破1024 個線程的硬限制,除非重新編譯 C 庫

最大打開文件數(shù)

file-max系統(tǒng)最大打開文件描述符數(shù)

/proc/sys/fs/file-max中指定了系統(tǒng)范圍內(nèi)所有進程可打開的文件句柄的數(shù)量限制(系統(tǒng)級別, kernel-level).

The value in file-max denotes the maximum number of file handles that the Linux kernel will allocate).

當收到”Too many open files in system”這樣的錯誤消息時, 就應(yīng)該曾加這個值了.

對于2.2的內(nèi)核, 還需要考慮inode-max, 一般inode-max設(shè)置為file-max的4倍. 對于2.4及以后的內(nèi)核, 沒有inode-max這個文件了.

查看實際值

可以使用cat /proc/sys/fs/file-max來查看當前系統(tǒng)中單進程可打開的文件描述符數(shù)目 186405

圖片

設(shè)置

  • 臨時性

echo 1000000 > /proc/sys/fs/file-max

  • 永久性:在/etc/sysctl.conf中設(shè)置

fs.file-max = 1000000

nr_open是單個進程可分配的最大文件數(shù)

內(nèi)核支持的最大file handle數(shù)量,即一個進程最多使用的file handle數(shù)

the maximum number of files that can be opened by process。

A process cannot use more than NR_OPEN file descriptors.
一個進程不能使用超過NR_OPEN文件描述符。12

圖片

nofile進程最大打開文件描述符數(shù)

查看實際值

ulimit -n

圖片

當然默認查看的是軟資源限制值soft limit,如果想要查看系統(tǒng)硬件所能支持的單進程最大打開文件描述符號的數(shù)目,可以使用ulimit -Hn

圖片

設(shè)置

  • 臨時性

通過ulimit -Sn設(shè)置最大打開文件描述符數(shù)的soft limit,注意soft limit不能大于hard limit(ulimit -Hn可查看hard limit)

另外ulimit -n默認查看的是soft limit,但是ulimit -n 1800000則是同時設(shè)置soft limit和hard limit。

對于非root用戶只能設(shè)置比原來小的hard limit。

  • 永久性

上面的方法只是臨時性的,注銷重新登錄就失效了,而且不能增大hard limit,只能在hard limit范圍內(nèi)修改soft limit。

若要使修改永久有效,則需要在/etc/security/limits.conf中進行設(shè)置(需要root權(quán)限),可添加如下兩行,表示用戶chanon最大打開文件描述符數(shù)的soft limit為1800000,hard limit為2000000。以下設(shè)置需要注銷之后重新登錄才能生效:

chanon soft nofile 102400
chanon hard nofile 40960012

設(shè)置nofile的hard limit還有一點要注意的就是hard limit不能大于/proc/sys/fs/nr_open,假如hard limit大于nr_open,注銷后無法正常登錄。

圖片

可以修改nr_open的值:

echo 2000000 > /proc/sys/fs/nr_open

file-max, nr_open, onfile之間的關(guān)系

針對用戶打開最大文件數(shù)的限制, 在limits.conf對應(yīng)的nofile,不管是man手冊還是文件中說明都只是一句話

“maximum number of open files”,

它其實對應(yīng)是單個進程能打開的最大文件數(shù),通常為了省事,我們想取消它的限制

根據(jù)man手冊中,“values -1, unlimited or infinity indicating no limit”,-1、unlimited、infinity都是表明不做限制

可是當你實際給nofile設(shè)置成這個值,等你重啟就會發(fā)現(xiàn)無法登錄系統(tǒng)了。

由此可見,nofile是有一個上限的,同時用ulimit測試:

ulimit -n unlimited1

bash: ulimit: open files: cannot modify limit: 不允許的操作

圖片

寫一個簡單的for循環(huán)得出:

for V in `seq 100000 10000000`;do ulimit -n $V;[[ $? != 0 ]]&&break;done1

再執(zhí)行ulimit -n ,可以看到1048576就是nofile的最大值了,但為什么是這個值?

1024?1024=10485761024?1024=1048576,當然這并沒有什么卵用。

再跟蹤一下我們就會發(fā)現(xiàn)這個值其實是由內(nèi)核參數(shù)nr_open定義的:

cat /proc/sys/fs/nr_open 1

圖片

到此我們就要說起nr_open,與file-max了,網(wǎng)上在說到設(shè)置最大文件數(shù)時偶爾有些帖子也說到要修改file-max,字面上看file-max確實像是對應(yīng)最大文件數(shù),而在linux內(nèi)核文檔中它們兩的解釋是:

  • file-max:The value in file-max denotes the maximum number of file- handles that the Linux kernel will allocate. When you get lots of error messages about running out of file handles, you might want to increase this limit

執(zhí)行:grep -r MemTotal /proc/meminfo | awk ‘{printf(“%d”,$2/10)}’,可以看到與file-max是相近的;

圖片

  • nr_open:
    This denotes the maximum number of file-handles a process can allocate. Default value is 1024*1024 (1048576) which should be enough for most machines. Actual limit depends on RLIMIT_NOFILE resource limit.

file-handles(即文件句柄),然后相比而言在UNIX/LINUX中我們接觸更多是file discriptor(FD,即文件描述符),似乎file-handle在windows中是一個類似file discrptor的東東,但是我們討論的是linux,再google一下,我們可以精確到c語言中這兩個概念的區(qū)別,

據(jù)他們的討論file-handle應(yīng)該是一個高層的對象,使用fopen,fread等函數(shù)來調(diào)用,而FD是底層的一個對象,可以通過open,read等函數(shù)來調(diào)用。

到此,我們應(yīng)該可以下一個大致的結(jié)論了,file-max是內(nèi)核可分配的最大文件數(shù),nr_open是單個進程可分配的最大文件數(shù),所以在我們使用ulimit或limits.conf來設(shè)置時,如果要超過默認的1048576值時需要先增大nr_open值(sysctl -w fs.nr_open=100000000或者直接寫入sysctl.conf文件)。當然百萬級別的單進程最大file-handle打開數(shù)應(yīng)該也夠用了吧。。

  1. 所有進程打開的文件描述符數(shù)不能超過/proc/sys/fs/file-max
  2. 單個進程打開的文件描述符數(shù)不能超過user limit中nofile的soft limit
  3. nofile的soft limit不能超過其hard limit
  4. nofile的hard limit不能超過/proc/sys/fs/nr_open

其他

2.4內(nèi)核與2.6內(nèi)核的主要區(qū)別

在2.4內(nèi)核的典型系統(tǒng)上(AS3/RH9),線程是用輕量進程實現(xiàn)的,每個線程要占用一個進程ID,在服務(wù)器程序上,如果遇到高點擊率訪問,會造成進程表溢出,系統(tǒng)為了維護溢出的進程表,會有間歇的暫停服務(wù)現(xiàn)象,而2.6內(nèi)核就不會發(fā)生由于大量線程的創(chuàng)建和銷毀導致進程表溢出的問題

線程結(jié)束必須釋放線程堆棧

就是說,線程函數(shù)必須調(diào)用pthread_exit()結(jié)束,否則直到主進程函數(shù)退出才釋放,特別是2.6內(nèi)核環(huán)境,線程創(chuàng)建速度飛快,一不小心立刻內(nèi)存被吃光,這一點反倒是2.4內(nèi)核環(huán)境好,因為2.4內(nèi)核創(chuàng)建的是進程,而且線程創(chuàng)建速度比2.6內(nèi)核慢幾個數(shù)量級。特別提醒,在64位CPU,2.6內(nèi)核創(chuàng)建線程的速度更加瘋狂,要是太快的話,加上usleep ()暫停一點點時間比較好

不要編需要鎖的線程應(yīng)用

只有那些不需要互斥量的程序才能最大限度的利用線程編程帶來的好處,否則只會更慢,2.6內(nèi)核是搶占式內(nèi)核,線程間共享沖突發(fā)生的幾率遠比2.4內(nèi)核環(huán)境高,尤其要注意線程安全,否則就算是單CPU也會發(fā)生莫名其妙的內(nèi)存不同步(CPU的高速緩存和主存內(nèi)容不一致),Intel的新CPU為了性能使用NUMA架構(gòu),在線程編程中一定要注意揚長避短。

單進程服務(wù)器最大并發(fā)線程數(shù)與內(nèi)存

很有趣,在默認的ulimit參數(shù)下,不修改內(nèi)核頭文件 AS3 512M內(nèi)存最多1000并發(fā)持續(xù)連接 CentOS4.3 512M內(nèi)存最多300并發(fā)持續(xù)連接 似乎是CentOS不如AS3,這里主要原因是ulimit的配置造成,兩個系統(tǒng)默認的配置差距很大,要想單進程維持更多線程接收并發(fā)連接,就要盡量縮小 ulimit -s的參數(shù),插更多的內(nèi)存條,單進程服務(wù)器上2000并發(fā)一點都不難,POSIX默認的限制是每進程64線程,但NTPL并非純正POSIX,不必理會這個限制,2.6內(nèi)核下真正的限制是內(nèi)存條的插槽數(shù)目(也許還有買內(nèi)存的錢數(shù)) 最近幾天的編程中,注意到在32位x86平臺上2.6內(nèi)核單進程創(chuàng)建最大線程數(shù)=VIRT上限/stack,與總內(nèi)存數(shù)關(guān)系不大,32位x86系統(tǒng)默認的VIRT上限是3G(內(nèi)存分配的3G+1G方式),默認 stack大小是10240K,因此單進程創(chuàng)建線程默認上限也就300(3072M / 10240K),用ulimit -s 修改stack到1024K則使上限升到大約3050。我手頭沒有64位系統(tǒng),不知道2.6內(nèi)核在64位上單進程創(chuàng)建線程上限(實際上是本人懶得在同事的機器上裝fc4_x86_64)。前些天買了一套廉價的64位x86系統(tǒng)(64位賽楊+雜牌915主板),安裝了CentOS4.3的x86_64版本,跑了一遍下面的小程序,得到的結(jié)果是:在ulimit -s 4096的情況下,單進程最大線程數(shù)在16000多一點,用top看 VIRT 的上限是64G,也就是36位, cat /proc/cpuinfo的結(jié)果是:address sizes : 36 bits physical, 48 bits virtual, 和我想象的標準64位系統(tǒng)不同, 我一直以為64位系統(tǒng)的內(nèi)存空間也是64位的

附注1

單位里某BSD FANS用AMD64筆記本跑小程序測試線程創(chuàng)建速度(線程創(chuàng)建后立即phread_detach()然后緊跟著pthread_exit(),共計 100萬個線程),同樣源碼OpenBSD竟然比FreeBSD快了3倍,什么時候OpenBSD也變得瘋狂起來了?

附注2

測試單進程創(chuàng)建線程上限C源碼(test.c)

#include
#include
#include #include #include void * thread_null(void);int main(int argc, char *argv[])
{ unsigned int i; int rc; pthread_t pool_id[65536]; //線程ID
sleep(1);
//創(chuàng)建線程 for(i = 0; i < 65536; i++)
{ rc = pthread_create(pool_id + i, 0, (void *)thread_null, NULL);
if (rc != 0)
{ fprintf(stderr, "pthread_create() failurernMax pthread num is %drn", i);
exit(-1);
} } fprintf(stdout, "Max pthread num is 65536rnYour system is power_fullrn");
exit(0);
}void * thread_null(void){ pthread_detach(pthread_self()); sleep(60);
pthread_exit(NULL);}
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11316

    瀏覽量

    209812
  • PID
    PID
    +關(guān)注

    關(guān)注

    35

    文章

    1472

    瀏覽量

    85603
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4798

    瀏覽量

    68728
  • gdt
    gdt
    +關(guān)注

    關(guān)注

    0

    文章

    49

    瀏覽量

    10625
收藏 人收藏

    評論

    相關(guān)推薦

    Linux中進程和線程的深度對比

    關(guān)于進程和線程,在 Linux 中是一對兒很核心的概念。但是進程和線程到底有啥聯(lián)系,又有啥區(qū)別,很多人還都沒有搞清楚。
    發(fā)表于 10-14 16:47 ?1322次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>中進程</b>和線程的深度對比

    干貨分享:基于嵌入式Linux中進程調(diào)度實現(xiàn)方法

    和網(wǎng)絡(luò)協(xié)議。 1. 前言處理機(CPU)是整個計算機系統(tǒng)的核心資源,在多進程的操作系統(tǒng)中,進程數(shù)往往多于處理機數(shù),這將導致各
    發(fā)表于 12-10 14:17

    Linux系統(tǒng)中進程如何查看及控制

    Linux系統(tǒng)中進程的查看及控制
    發(fā)表于 06-09 08:34

    WiFi5理論速率是如何計算出來的?

    率采用3/4,調(diào)制方式為64QAM調(diào)制,雙流MIMO數(shù)為2,因此最大理論速率為:84×2×6×3/4×100/0.5ms=151.2Mps。  TDD模式  蜂窩LTE工作在TDD模式下理論速率
    發(fā)表于 03-22 14:57

    Linux進程管理

    Linux進程管理 本章主要介紹進程的概念、狀態(tài)、構(gòu)成以及Linux進程的相關(guān)知識。 掌握進程
    發(fā)表于 04-28 14:57 ?0次下載

    Linux源碼分析系列的進程

    概述:相關(guān)概念,進程在整個內(nèi)核中的功能位置,源代碼中進程相關(guān)的文件源代碼中進程相關(guān)的文件。 Linux核心是多任務(wù)的,運行的程序稱作進程 (
    發(fā)表于 11-03 22:26 ?32次下載

    Linux和UNIX可以用什么命令查看運行中進程的相關(guān)信息

      你可以使用ps命令。它能顯示當前運行中進程的相關(guān)信息,包括進程的PID。Linux和UNIX都支持ps命令,顯示所有運行中進程的相關(guān)信息。ps命令能提供一份當前
    發(fā)表于 01-20 09:42 ?6475次閱讀

    Linux/Unix ulimit命令詳解

    Linux對于每個用戶,系統(tǒng)限制其最大進程數(shù)。為提高性能,可以根據(jù)設(shè)備資源情況,設(shè)置各linux 用戶的
    發(fā)表于 05-06 15:41 ?1154次閱讀

    關(guān)于嵌入式Linux中進程調(diào)度的內(nèi)容淺析

    處理機(CPU)是整個計算機系統(tǒng)的核心資源,在多進程的操作系統(tǒng)中,進程數(shù)往往多于處理機數(shù),這將導致各進程
    發(fā)表于 04-03 09:02 ?864次閱讀
    關(guān)于嵌入式<b class='flag-5'>Linux</b><b class='flag-5'>中進程</b>調(diào)度的內(nèi)容淺析

    嵌入式Linux中進程調(diào)度怎樣來解析

    處理機(CPU)是整個計算機系統(tǒng)的核心資源,在多進程的操作系統(tǒng)中,進程數(shù)往往多于處理機數(shù),這將導致各進程
    發(fā)表于 11-06 11:54 ?723次閱讀

    Linux進程間通信方式——管道

    管道是Linux中進程間通信的一種方式,它把一個程序的輸出直接連接到另一個程序的輸入。Linux的管道主要包括兩種:無名管道和有名管道。
    發(fā)表于 06-01 09:13 ?1461次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>進程</b>間通信方式——管道

    虛擬機:linux 進程最大線程個數(shù)

    虛擬機:linux 進程最大線程個數(shù)
    的頭像 發(fā)表于 06-22 15:56 ?2770次閱讀
    虛擬機:<b class='flag-5'>linux</b> <b class='flag-5'>進程</b>的<b class='flag-5'>最大</b>線程個數(shù)

    深度剖析Linux中進程控制(上)

    Linux中,fork函數(shù)是非常重要的函數(shù),它從已存在進程中創(chuàng)建一個新進程。新進程為子進程,而原進程
    的頭像 發(fā)表于 05-12 10:49 ?560次閱讀
    深度剖析<b class='flag-5'>Linux</b><b class='flag-5'>中進程</b>控制(上)

    深度剖析Linux中進程控制(下)

    Linux中,fork函數(shù)是非常重要的函數(shù),它從已存在進程中創(chuàng)建一個新進程。新進程為子進程,而原進程
    的頭像 發(fā)表于 05-12 10:49 ?519次閱讀
    深度剖析<b class='flag-5'>Linux</b><b class='flag-5'>中進程</b>控制(下)

    Linux中進程、線程和協(xié)程的基礎(chǔ)概念

    進程計算機中運行的程序的實例,它是操作系統(tǒng)中最基本的執(zhí)行單元之一。每個進程都有自己的獨立內(nèi)存空間、系統(tǒng)資源和代碼執(zhí)行流。這意味著一個進程的崩潰通常不會影響其他
    的頭像 發(fā)表于 12-06 09:22 ?902次閱讀
    主站蜘蛛池模板: 激情五月在线| 免费人成网ww777kkk手机| 97影院理论午夜论不卡| 高清毛片aaaaaaaaa片| 丁香花在线| 一级片在线免费| 天天做爽夜夜做爽| 中文字幕亚洲天堂| 国产精品久久久久久久人热| 国内夫妇交换性经过实录| 九九热免费在线观看| 97人人揉人人捏人人添| 亚洲电影在线| 色婷婷精品视频| 欧美高清免费一级在线| 国产色秀视频在线观看| 99日精品欧美国产| 天堂最新版在线www在线| 黄 色 成 年人在线| 男操女视频网站| 很黄很暴力 很污秽的小说| 性色a| 你懂的亚洲| xxx亚洲日本| 秋霞麻豆| 亚洲haose在线观看| 亚洲天堂免费看| 在线亚洲日产一区二区| 色婷婷亚洲十月十月色天| 美女网色站| 最近免费hd| 毛片在线不卡| 888午夜不卡理论久久| 中文在线最新版天堂| 色免费观看| 国产精品视频网站你懂得| 天天操狠狠干| 国产视频h| 亚洲无色| 久久男人精品| 天天干天天上|