青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大龍的博客

常用鏈接

統(tǒng)計(jì)

最新評(píng)論

LINUX最大線程數(shù)及最大進(jìn)程數(shù)

查看最大線程數(shù):

cat /proc/sys/kernel/threads-max

ulimit

User limits - limit the use of system-wide resources.

Syntax
ulimit [-acdfHlmnpsStuv] [limit]

Options

-S Change and report the soft limit associated with a resource. 
-H Change and report the hard limit associated with a resource. 

-a All current limits are reported. 
-c The maximum size of core files created. 
-d The maximum size of a process's data segment. 
-f The maximum size of files created by the shell(default option) 
-l The maximum size that may be locked into memory. 
-m The maximum resident set size. 
-n The maximum number of open file descriptors. 
-p The pipe buffer size. 
-s The maximum stack size. 
-t The maximum amount of cpu time in seconds. 
-u The maximum number of processes available to a single user. 
-v The maximum amount of virtual memory available to the process. 

ulimit provides control over the resources available to the shell and to processes started by it, on systems that allow such control.

If limit is given, it is the new value of the specified resource. Otherwise, the current value of the soft limit for the specified resource is printed, unless the `-H' option is supplied.

When setting new limits, if neither `-H' nor `-S' is supplied, both the hard and soft limits are set.

Values are in 1024-byte increments, except for `-t', which is in seconds, `-p', which is in units of 512-byte blocks, and `-n' and `-u', which are unscaled values.

The return status is zero unless an invalid option is supplied, a non-numeric argument other than unlimited is supplied as a limit, or an error occurs while setting a new limit.

ulimit is a bash built in command.

Ulimit命令
設(shè)置限制 可以把命令加到profile文件里,也可以在/etc/security/limits.conf文件中定義
限制。
命令參數(shù)
-a 顯示所有限制
-c core文件大小的上限
-d 進(jìn)程數(shù)據(jù)段大小的上限
-f shell所能創(chuàng)建的文件大小的上限
-m 駐留內(nèi)存大小的上限
-s 堆棧大小的上限
-t 每秒可占用的CPU時(shí)間上限
-p 管道大小
-n 打開(kāi)文件數(shù)的上限
-u 進(jìn)程數(shù)的上限
-v 虛擬內(nèi)存的上限
除可用Ulimit命令設(shè)置外,也可以在/etc/security/limits.conf文件中定義限制。
domino type item value
domino是以符號(hào)@開(kāi)頭的用戶名或組名,*表示所有用戶,type設(shè)置為hard or soft。item指
定想限制的資源。如cpu,core nproc or maxlogins。value是相應(yīng)的限制值。

系統(tǒng)限制默認(rèn)值

[root@flyinweb ~]# 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) 32764
max locked memory (kbytes, -l) 32
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) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 32764
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
[root@flyinweb ~]# lsb_release -a
LSB Version: :core-3.1-ia32:core-3.1-noarch:graphics-3.1-ia32:graphics-3.1-noarch
Distributor ID: CentOS
Description: CentOS release 5.2 (Final)
Release: 5.2
Codename: Final

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

這個(gè)限制可以在 /usr/include/bits/local_lim.h 中查看

對(duì) linuxthreads 這個(gè)值一般是 1024,對(duì)于 nptl 則沒(méi)有硬性的限制,僅僅受限于系統(tǒng)的資源

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

可以寫(xiě)一段簡(jiǎn)單的代碼驗(yàn)證最多可以創(chuàng)建多少個(gè)線程

int main() int i = 0; pthread_t threadwhile (1) { if (pthread_create(&thread, NULL, foo, NULL) != 0) returni ++; printf("i = %d\n", i); }


試驗(yàn)顯示,在 linuxthreads 上最多可以創(chuàng)建 381 個(gè)線程,之后就會(huì)返回 EAGAIN

在 nptl 上最多可以創(chuàng)建 382 個(gè)線程,之后就會(huì)返回 ENOMEM

這個(gè)值和理論完全相符,因?yàn)?32 位 linux 下的進(jìn)程用戶空間是 3G 的大小,也就是 3072M,用 3072M 除以 8M 得 384,但是實(shí)際上代碼段和數(shù)據(jù)段等還要占用一些空間,這個(gè)值應(yīng)該向下取整到 383,再減去主線程,得到 382。

那為什么 linuxthreads 上還要少一個(gè)線程呢?這可太對(duì)了,因?yàn)?linuxthreads 還需要一個(gè)管理線程

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

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

要注意的是,即使這樣的也無(wú)法突破 1024 個(gè)線程的硬限制,除非重新編譯 C 庫(kù)

相關(guān)內(nèi)容:

一、2.4內(nèi)核與2.6內(nèi)核的主要區(qū)別
在2.4內(nèi)核的典型系統(tǒng)上(AS3/RH9),線程是用輕量進(jìn)程實(shí)現(xiàn)的,每個(gè)線程要占用一個(gè)進(jìn)程ID,在服務(wù)器程序上,如果遇到高點(diǎn)擊率訪問(wèn),會(huì)造成進(jìn)程表溢出,系統(tǒng)為了維護(hù)溢出的進(jìn)程表,會(huì)有間歇的暫停服務(wù)現(xiàn)象,而2.6內(nèi)核就不會(huì)發(fā)生由于大量線程的創(chuàng)建和銷毀導(dǎo)致進(jìn)程表溢出的問(wèn)題
二、線程結(jié)束必須釋放線程堆棧
就是說(shuō),線程函數(shù)必須調(diào)用pthread_exit()結(jié)束,否則直到主進(jìn)程函數(shù)退出才釋放,特別是2.6內(nèi)核環(huán)境,線程創(chuàng)建速度飛快,一不小心立刻內(nèi)存被吃光,這一點(diǎn)反倒是2.4內(nèi)核環(huán)境好,因?yàn)?.4內(nèi)核創(chuàng)建的是進(jìn)程,而且線程創(chuàng)建速度比2.6內(nèi)核慢幾個(gè)數(shù)量級(jí)。特別提醒,在64位CPU,2.6內(nèi)核創(chuàng)建線程的速度更加瘋狂,要是太快的話,加上usleep ()暫停一點(diǎn)點(diǎn)時(shí)間比較好
三、不要編需要鎖的線程應(yīng)用
只有那些不需要互斥量的程序才能最大限度的利用線程編程帶來(lái)的好處,否則只會(huì)更慢,2.6內(nèi)核是搶占式內(nèi)核,線程間共享沖突發(fā)生的幾率遠(yuǎn)比2.4內(nèi)核環(huán)境高,尤其要注意線程安全,否則就算是單CPU也會(huì)發(fā)生莫名其妙的內(nèi)存不同步(CPU的高速緩存和主存內(nèi)容不一致),Intel的新CPU為了性能使用NUMA架構(gòu),在線程編程中一定要注意揚(yáng)長(zhǎng)避短。
四、單進(jìn)程服務(wù)器最大并發(fā)線程數(shù)與內(nèi)存
很有趣,在默認(rèn)的ulimit參數(shù)下,不修改內(nèi)核頭文件
AS3 512M內(nèi)存最多1000并發(fā)持續(xù)連接
CentOS4.3 512M內(nèi)存最多300并發(fā)持續(xù)連接
似乎是CentOS不如AS3,這里主要原因是ulimit的配置造成,兩個(gè)系統(tǒng)默認(rèn)的配置差距很大,要想單進(jìn)程維持更多線程接收并發(fā)連接,就要盡量縮小 ulimit -s的參數(shù),插更多的內(nèi)存條,單進(jìn)程服務(wù)器上2000并發(fā)一點(diǎn)都不難,POSIX默認(rèn)的限制是每進(jìn)程64線程,但NTPL并非純正POSIX,不必理會(huì)這個(gè)限制,2.6內(nèi)核下真正的限制是內(nèi)存條的插槽數(shù)目(也許還有買(mǎi)內(nèi)存的錢(qián)數(shù))
最近幾天的編程中,注意到在32位x86平臺(tái)上2.6內(nèi)核單進(jìn)程創(chuàng)建最大線程數(shù)=VIRT上限/stack,與總內(nèi)存數(shù)關(guān)系不大,32位x86系統(tǒng)默認(rèn)的VIRT上限是3G(內(nèi)存分配的3G+1G方式),默認(rèn) stack大小是10240K,因此單進(jìn)程創(chuàng)建線程默認(rèn)上限也就300(3072M / 10240K),用ulimit -s 修改stack到1024K則使上限升到大約3050。我手頭沒(méi)有64位系統(tǒng),不知道2.6內(nèi)核在64位上單進(jìn)程創(chuàng)建線程上限(實(shí)際上是本人懶得在同事的機(jī)器上裝fc4_x86_64)。
前些天買(mǎi)了一套廉價(jià)的64位x86系統(tǒng)(64位賽楊+雜牌915主板),安裝了CentOS4.3的x86_64版本,跑了一遍下面的小程序,得到的結(jié)果是:在ulimit -s 4096的情況下,單進(jìn)程最大線程數(shù)在16000多一點(diǎn),用top看
VIRT 的上限是64G,也就是36位, cat /proc/cpuinfo的結(jié)果是:address sizes : 36 bits physical, 48 bits virtual, 和我想象的標(biāo)準(zhǔn)64位系統(tǒng)不同, 我一直以為64位系統(tǒng)的內(nèi)存空間也是64位的
附注1:
單位里某BSD FANS用AMD64筆記本跑小程序測(cè)試線程創(chuàng)建速度(線程創(chuàng)建后立即phread_detach()然后緊跟著pthread_exit(),共計(jì) 100萬(wàn)個(gè)線程),同樣源碼OpenBSD竟然比FreeBSD快了3倍,什么時(shí)候OpenBSD也變得瘋狂起來(lái)了?
附注2:
測(cè)試單進(jìn)程創(chuàng)建線程上限C源碼(test.c):

#include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> #include <pthread.h> 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 (0 != rc) { fprintf(stderr, "pthread_create() failure\r\nMax pthread num is %d\r\n", i); exit(-1); fprintf(stdout, "Max pthread num is 65536\r\nYour system is power_full\r\n"); exit(0); void * thread_null(voidpthread_detach(pthread_self()); sleep(60); pthread_exit(NULL); }

編譯:

[root@localhost test]# gcc test.c -o test -lpthread
[root@localhost test]# ulimit -s 10240
[root@localhost test]# ./test 
pthread_create() failure
Max pthread num is 305
[root@localhost test]# ulimit -s 1024 
[root@localhost test]# ./test 
pthread_create() failure
Max pthread num is 3054

以上結(jié)果在 CentOS release 5.2 (32Bit)系統(tǒng)上測(cè)試得到

posted on 2011-10-12 09:48 大龍 閱讀(9121) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久婷婷国产麻豆91天堂| 亚洲精品国产精品乱码不99| 在线综合亚洲欧美在线视频| 亚洲主播在线观看| 国产精品扒开腿爽爽爽视频| 在线综合视频| 欧美在线啊v一区| 黄色成人精品网站| 欧美.日韩.国产.一区.二区| 国产欧美日本一区视频| 亚洲欧美韩国| 美腿丝袜亚洲色图| 一区二区久久久久| 国产女精品视频网站免费 | 亚洲与欧洲av电影| 久久国产一区| 亚洲人成网站999久久久综合| 欧美午夜不卡在线观看免费| 性欧美大战久久久久久久久| 欧美寡妇偷汉性猛交| 亚洲图片欧洲图片日韩av| 国产亚洲一区二区三区在线观看 | 亚洲一区二区三区国产| 国产一区二区成人| 欧美精品日韩一本| 午夜精品免费视频| 亚洲国产天堂久久综合网| 欧美一级一区| 亚洲精品系列| 国模精品一区二区三区| 欧美精品乱码久久久久久按摩| 亚洲欧美成人一区二区在线电影 | 欧美一区二区大片| 亚洲欧洲精品一区二区三区| 久久精品理论片| 999亚洲国产精| 狠狠噜噜久久| 国产精品久久久久久久久久免费看| 久久久久久久久久久成人| 洋洋av久久久久久久一区| 美国成人直播| 久久成人精品无人区| 日韩一级裸体免费视频| 黄色一区三区| 国产欧美日韩一区| 欧美丝袜一区二区三区| 欧美.日韩.国产.一区.二区| 久久国产高清| 亚洲欧美一区二区精品久久久| 亚洲承认在线| 久久综合影音| 久久精品人人做人人爽电影蜜月| 亚洲一线二线三线久久久| 亚洲全黄一级网站| 在线观看国产精品网站| 国产一区二区三区自拍| 国产日韩欧美中文| 国产精品久久午夜| 欧美三级日本三级少妇99| 欧美顶级少妇做爰| 欧美bbbxxxxx| 免费久久99精品国产自在现线| 久久九九热免费视频| 欧美在线www| 久久国产精品亚洲va麻豆| 亚洲综合色在线| 亚洲欧美日韩精品久久久久| 中国成人亚色综合网站| 夜夜狂射影院欧美极品| 99国产一区| 一区二区三区黄色| 洋洋av久久久久久久一区| 夜夜爽av福利精品导航 | 久久国产免费看| 欧美一站二站| 久久精品亚洲| 久久天天躁夜夜躁狠狠躁2022| 久久久久久69| 牛夜精品久久久久久久99黑人| 免费日韩成人| 亚洲高清在线播放| 亚洲日本视频| 亚洲砖区区免费| 性欧美大战久久久久久久久| 久久久久国产精品人| 噜噜噜91成人网| 欧美国产日韩在线观看| 欧美日韩另类在线| 国产精品伦一区| 狠狠狠色丁香婷婷综合激情| 91久久精品国产91久久性色| 99re这里只有精品6| 欧美在线观看一区| 国产一区二区成人久久免费影院| 国产啪精品视频| 红桃视频成人| 一本久久综合亚洲鲁鲁| 午夜激情亚洲| 麻豆精品视频在线| 亚洲国产精品va在看黑人| 日韩视频中午一区| 亚洲免费网址| 久久久久久久激情视频| 欧美劲爆第一页| 国产精品视频不卡| 在线不卡中文字幕播放| 一区二区免费在线视频| 香蕉久久国产| 欧美黄色网络| 亚洲五月六月| 男男成人高潮片免费网站| 国产精品久久久久国产精品日日| 国产亚洲福利社区一区| 亚洲精品乱码久久久久久| 亚洲在线不卡| 欧美国产日韩一区二区| 午夜精品久久久久久久久久久| 久久久久久综合| 国产精品激情电影| 亚洲福利在线看| 午夜精品美女久久久久av福利| 免费亚洲网站| 亚洲欧美日韩精品久久| 欧美美女视频| 精品动漫3d一区二区三区| 亚洲一区二区视频在线观看| 美女视频网站黄色亚洲| 亚洲影院免费观看| 欧美国产日韩a欧美在线观看| 国产无遮挡一区二区三区毛片日本| 99视频在线精品国自产拍免费观看| 久久成人精品无人区| 日韩午夜精品| 免费成人美女女| 国产主播在线一区| 亚洲欧美日韩成人高清在线一区| 欧美国产日韩精品| 久久aⅴ国产紧身牛仔裤| 欧美性一区二区| 夜夜夜久久久| 亚洲高清久久久| 久久婷婷蜜乳一本欲蜜臀| 国产欧美日韩激情| 中文精品视频| 亚洲精选一区二区| 蜜臀a∨国产成人精品| 国内成人精品2018免费看| 午夜精品婷婷| 中文日韩在线| 欧美午夜a级限制福利片| 99热精品在线| 91久久国产自产拍夜夜嗨| 亚洲一区二区三区免费视频 | 亚洲乱码精品一二三四区日韩在线 | 亚洲激情视频网| 美女精品一区| 久久久精品国产免大香伊| 国产一本一道久久香蕉| 欧美与欧洲交xxxx免费观看| 亚洲免费网址| 国产日韩综合| 久久全球大尺度高清视频| 欧美在线不卡视频| 国产在线不卡| 免费成人高清视频| 另类春色校园亚洲| 1000部精品久久久久久久久| 你懂的网址国产 欧美| 免费不卡亚洲欧美| 亚洲黄色在线观看| 亚洲人在线视频| 欧美日本簧片| 午夜日韩电影| 欧美在线国产| 亚洲激情国产| 亚洲三级电影全部在线观看高清| 欧美日韩国产天堂| 亚洲香蕉成视频在线观看| 亚洲影院免费| 国内成人精品视频| 欧美高清自拍一区| 欧美日韩国产成人在线91| 亚洲一区日韩| 欧美一区二区黄| 亚洲国产高清一区二区三区| 最新日韩在线视频| 国产精品国产亚洲精品看不卡15| 欧美在线综合| 麻豆成人精品| 一区二区三区日韩精品| 午夜久久美女| 极品少妇一区二区三区精品视频| 欧美国产日韩二区| 欧美午夜剧场| 久久嫩草精品久久久久| 欧美精品成人| 久久久久国产成人精品亚洲午夜| 美日韩精品视频| 亚洲欧美bt| 美女国内精品自产拍在线播放|