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

colorful

zc qq:1337220912

 

linux signal量

轉自:http://www.dbafree.net/?p=870
http://news.cnblogs.com/n/146220/

我們可以使用kill -l查看所有的信號量解釋,但是沒有看到SIGNAL 0的解釋。

[root@testdb~]# kill -l  1) SIGHUP       2) SIGINT       3) SIGQUIT      4) SIGILL  5) SIGTRAP      6) SIGABRT      7) SIGBUS       

8)

 SIGFPE  9) SIGKILL     10) SIGUSR1     11) SIGSEGV     12) SIGUSR2 13) SIGPIPE     14) SIGALRM     15) SIGTERM     17) SIGCHLD 18) SIGCONT     19) SIGSTOP     20) SIGTSTP     21) SIGTTIN 22) SIGTTOU     23) SIGURG      24) SIGXCPU     25) SIGXFSZ 26) SIGVTALRM   27) SIGPROF     28) SIGWINCH    29) SIGIO 30) SIGPWR      31) SIGSYS      34) SIGRTMIN    35) SIGRTMIN+1 36) SIGRTMIN+2  37) SIGRTMIN+3  38) SIGRTMIN+4  39) SIGRTMIN+5 40) SIGRTMIN+6  41) SIGRTMIN+7  42) SIGRTMIN+8  43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13 48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12 53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8  57) SIGRTMAX-7  58) SIGRTMAX-6  59) SIGRTMAX-5 60) SIGRTMAX-4  61) SIGRTMAX-3  62) SIGRTMAX-2  63) SIGRTMAX-1 64) SIGRTMAX

網上搜了下,在這篇文檔中找到了signal 0的解釋,很不錯:

http://www.linuxjournal.com/content/monitoring-processes-kill-0

“signal 0″ is kind of like a moral equivalent of “ping”.

Using “kill -0 NNN” in a shell script is a good way to tell if PID “NNN” is alive or not:

signal 0 is just used to check process is exists or not.

在關其它的信號量說明,原文:http://hi.baidu.com/syqust/blog/item/cd8f6c633b8a617c0d33fa35.html

信號本質
信號是在軟件層次上對中斷機制的一種模擬,在原理上,一個進程收到一個信號與處理器收到一個中斷請求可以說是一樣的。信號是異步的,一個進程不必通過任何操作來等待信號的到達,事實上,進程也不知道信號到底什么時候到達。

信號是進程間通信機制中唯一的異步通信機制,可以看作是異步通知,通知接收信號的進程有哪些事情發生了。信號機制經過POSIX實時擴展后,功能更加強大,除了基本通知功能外,還可以傳遞附加信息。

使用kill -l就會顯示出linux支持的信號列表。
其中列表中,編號為1 ~ 31的信號為傳統UNIX支持的信號,是不可靠信號(非實時的),編號為32 ~ 63的信號是后來擴充的,稱做可靠信號(實時信號)。不可靠信號和可靠信號的區別在于前者不支持排隊,可能會造成信號丟失,而后者不會。

下面我們對編號小于SIGRTMIN的信號進行討論(下面的編號 依次對應信號 的數值為1 – 31)。

1) SIGHUP
本信號在用戶終端連接(正常或非正常)結束時發出, 通常是在終端的控制進程結束時, 通知同一session內的各個作業, 這時它們與控制終端不再關聯。

登錄Linux時,系統會分配給登錄用戶一個終端(Session)。在這個終端運行的所有程序,包括前臺進程組和后臺進程組,一般都屬于這個 Session。當用戶退出Linux登錄時,前臺進程組和后臺有對終端輸出的進程將會收到SIGHUP信號。這個信號的默認操作為終止進程,因此前臺進 程組和后臺有終端輸出的進程就會中止。不過可以捕獲這個信號,比如wget能捕獲SIGHUP信號,并忽略它,這樣就算退出了Linux登錄,wget也 能繼續下載。

此外,對于與終端脫離關系的守護進程,這個信號用于通知它重新讀取配置文件。

2) SIGINT
程序終止(interrupt)信號, 在用戶鍵入INTR字符(通常是Ctrl-C)時發出,用于通知前臺進程組終止進程。

3) SIGQUIT
和SIGINT類似, 但由QUIT字符(通常是Ctrl-\)來控制. 進程在因收到SIGQUIT退出時會產生core文件, 在這個意義上類似于一個程序錯誤信號。

4) SIGILL
執行了非法指令. 通常是因為可執行文件本身出現錯誤, 或者試圖執行數據段. 堆棧溢出時也有可能產生這個信號。

5) SIGTRAP
由斷點指令或其它trap指令產生. 由debugger使用。

6) SIGABRT
調用abort函數生成的信號。

7) SIGBUS
非法地址, 包括內存地址對齊(alignment)出錯。比如訪問一個四個字長的整數, 但其地址不是4的倍數。它與SIGSEGV的區別在于后者是由于對合法存儲地址的非法訪問觸發的(如訪問不屬于自己存儲空間或只讀存儲空間)。

8) SIGFPE
在發生致命的算術運算錯誤時發出. 不僅包括浮點運算錯誤, 還包括溢出及除數為0等其它所有的算術的錯誤。

9) SIGKILL
用來立即結束程序的運行. 本信號不能被阻塞、處理和忽略。如果管理員發現某個進程終止不了,可嘗試發送這個信號。

10) SIGUSR1
留給用戶使用

11) SIGSEGV
試圖訪問未分配給自己的內存, 或試圖往沒有寫權限的內存地址寫數據.

 信號 11,即表示程序中可能存在特定條件下的非法內存訪問。

12) SIGUSR2
留給用戶使用

13) SIGPIPE
管道破裂。這個信號通常在進程間通信產生,比如采用FIFO(管道)通信的兩個進程,讀管道沒打開或者意外終止就往管道寫,寫進程會收到SIGPIPE信號。此外用Socket通信的兩個進程,寫進程在寫Socket的時候,讀進程已經終止。

14) SIGALRM
時鐘定時信號, 計算的是實際的時間或時鐘時間. alarm函數使用該信號.

15) SIGTERM
程序結束(terminate)信號, 與SIGKILL不同的是該信號可以被阻塞和處理。通常用來要求程序自己正常退出,shell命令kill缺省產生這個信號。如果進程終止不了,我們才會嘗試SIGKILL。

17) SIGCHLD
子進程結束時, 父進程會收到這個信號。

如果父進程沒有處理這個信號,也沒有等待(wait)子進程,子進程雖然終止,但是還會在內核進程表中占有表項,這時的子進程稱為僵尸進程。這種情 況我們應該避免(父進程或者忽略SIGCHILD信號,或者捕捉它,或者wait它派生的子進程,或者父進程先終止,這時子進程的終止自動由init進程 來接管)。

18) SIGCONT
讓一個停止(stopped)的進程繼續執行. 本信號不能被阻塞. 可以用一個handler來讓程序在由stopped狀態變為繼續執行時完成特定的工作. 例如, 重新顯示提示符

19) SIGSTOP
停止(stopped)進程的執行. 注意它和terminate以及interrupt的區別:該進程還未結束, 只是暫停執行. 本信號不能被阻塞, 處理或忽略.

20) SIGTSTP
停止進程的運行, 但該信號可以被處理和忽略. 用戶鍵入SUSP字符時(通常是Ctrl-Z)發出這個信號

21) SIGTTIN
當后臺作業要從用戶終端讀數據時, 該作業中的所有進程會收到SIGTTIN信號. 缺省時這些進程會停止執行.

22) SIGTTOU
類似于SIGTTIN, 但在寫終端(或修改終端模式)時收到.

23) SIGURG
有”緊急”數據或out-of-band數據到達socket時產生.

24) SIGXCPU
超過CPU時間資源限制. 這個限制可以由getrlimit/setrlimit來讀取/改變。

25) SIGXFSZ
當進程企圖擴大文件以至于超過文件大小資源限制。

26) SIGVTALRM
虛擬時鐘信號. 類似于SIGALRM, 但是計算的是該進程占用的CPU時間.

27) SIGPROF
類似于SIGALRM/SIGVTALRM, 但包括該進程用的CPU時間以及系統調用的時間.

28) SIGWINCH
窗口大小改變時發出.

29) SIGIO
文件描述符準備就緒, 可以開始進行輸入/輸出操作.

30) SIGPWR
Power failure

31) SIGSYS
非法的系統調用。

在以上列出的信號中,程序不可捕獲、阻塞或忽略的信號有:SIGKILL,SIGSTOP
不能恢復至默認動作的信號有:SIGILL,SIGTRAP
默認會導致進程流產的信號有:SIGABRT,SIGBUS,SIGFPE,SIGILL,SIGIOT,SIGQUIT,SIGSEGV,SIGTRAP,SIGXCPU,SIGXFSZ
默認會導致進程退出的信號有:SIGALRM,SIGHUP,SIGINT,SIGKILL,SIGPIPE,SIGPOLL,SIGPROF,SIGSYS,SIGTERM,SIGUSR1,SIGUSR2,SIGVTALRM
默認會導致進程停止的信號有:SIGSTOP,SIGTSTP,SIGTTIN,SIGTTOU
默認進程忽略的信號有:SIGCHLD,SIGPWR,SIGURG,SIGWINCH

此外,SIGIO在SVR4是退出,在4.3BSD中是忽略;SIGCONT在進程掛起時是繼續,否則是忽略,不能被阻塞

終止程序的時候在不得已的情況下不能用SIGKILL,因為SIGKILL不會對子進程進行處理,只是把對自己進行處理

 

 

Linux支持POSIX標準信號和實時信號。下面給出Linux Signal的簡表,詳細細節可以查看man 7 signal。

 

默認動作的含義如下:

Term    終止進程

 

信號 取值 默認動作 含義(發出信號的原因)
SIGHUP 1 Term 終端的掛斷或進程死亡
SIGINT 2 Term 來自鍵盤的中斷信號
SIGQUIT 3 Core 來自鍵盤的離開信號
SIGILL 4 Core 非法指令
SIGABRT 6 Core 來自abort的異常信號
SIGFPE 8 Core 浮點例外
SIGKILL 9 Term 殺死
SIGSEGV 11 Core 段非法錯誤(內存引用無效)
SIGPIPE 13 Term 管道損壞:向一個沒有讀進程的管道寫數據
SIGALRM 14 Term 來自alarm的計時器到時信號
SIGTERM 15 Term 終止
SIGUSR1 30,10,16 Term 用戶自定義信號1
SIGUSR2 31,12,17 Term 用戶自定義信號2
SIGCHLD 20,17,18 Ign 子進程停止或終止
SIGCONT 19,18,25 Cont 如果停止,繼續執行
SIGSTOP 17,19,23 Stop 非來自終端的停止信號
SIGTSTP 18,20,24 Stop 來自終端的停止信號
SIGTTIN 21,21,26 Stop 后臺進程讀終端
SIGTTOU 22,22,27 Stop 后臺進程寫終端
SIGBUS 10,7,10 Core 總線錯誤(內存訪問錯誤)
SIGPOLL Term Pollable事件發生(Sys V),與SIGIO同義
SIGPROF 27,27,29 Term 統計分布圖用計時器到時
SIGSYS 12,-,12 Core 非法系統調用(SVr4)
SIGTRAP 5 Core 跟蹤/斷點自陷
SIGURG 16,23,21 Ign socket緊急信號(4.2BSD)
SIGVTALRM 26,26,28 Term 虛擬計時器到時(4.2BSD)
SIGXCPU 24,24,30 Core 超過CPU時限(4.2BSD)
SIGXFSZ 25,25,31 Core 超過文件長度限制(4.2BSD)
SIGIOT 6 Core IOT自陷,與SIGABRT同義
SIGEMT 7,-,7 Term
SIGSTKFLT -,16,- Term 協處理器堆棧錯誤(不使用)
SIGIO 23,29,22 Term 描述符上可以進行I/O操作
SIGCLD -,-,18 Ign 與SIGCHLD同義
SIGPWR 29,30,19 Term 電力故障(System V)
SIGINFO 29,-,- 與SIGPWR同義
SIGLOST -,-,- Term 文件鎖丟失
SIGWINCH 28,28,20 Ign 窗口大小改變(4.3BSD, Sun)
SIGUNUSED -,31,- Term 未使用信號(will be SIGSYS)

 

說明:

一些信號的取值是硬件結構相關的(一般alpha和sparc架構用第一個值,i386、ppc和sh架構用中間值,mips架構用第三個值, - 表示相應架構的取值未知)。

 

藍色的是POSIX.1-1990標準信號。

SIGKILL和SIGSTOP信號不能被掛鉤、阻塞或忽略。

 

青色的是SUSv2和POSIX.1-2001定義的信號。

在Linux 2.2(包括)內核之前,SIGSYS、SIGXCPU、SIGXFSZ和SIGBUS (SPARC和MIPS架構除外)的默認動作是終止進程,但沒有 core dump。Linux 2.4遵循POSIX.1-2001要求,這些信號的默認動作改為:終止進程同時做core dump。

 

橙色的是其他常見的信號。

信號29在Alpha上為SIGINFO / SIGPWR ,在Sparc上為SIGLOST。

SIGEMT沒有在POSIX.1-2001中說明,但是在大多數的Unices中仍然能見到,典型的默認動作是終止進程并做core dump。

SIGPWR沒有在POSIX.1-2001中說明,在使用它的一些Unices中典型的默認動作是忽略。

SIGIO沒有在POSIX.1-2001中說明,在使用它的一些Unices中典型的默認動作是忽略。

 

進程可以通過使用sigaction和signal系統調用來改變信號的默認處理方式(使用signal的可移植性差)。進程可以選擇下列3種信號處理方式中的一種:

1、執行默認操作;

2、忽略該信號;

3、捕獲該信號,但是通過信號句柄來調用自定義的處理函數。

 

信號可能被阻塞。進程中的每個線程擁有獨立的信號掩碼,用來表示本線程的信號被阻塞。線程通過pthread_sigmask來設置它的信號掩碼。單線程程序可以用sigprocmask來操作信號掩碼。在多線程程序中,所有線程處理一個指定信號的默認行為都是一樣的。

 

 

補充:

SIG_DFL,SIG_IGN 分別表示無返回值的函數指針,指針值分別是0和1,這兩個指針值邏輯上講是實際程序中不可能出現的函數地址值。

SIG_DFL:默認信號處理程序
SIG_IGN:忽略信號的處理程序

posted on 2013-08-12 09:09 多彩人生 閱讀(473) 評論(0)  編輯 收藏 引用 所屬分類: linux program

導航

統計

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久天堂国产精品| 国产精品福利av| 欧美国产日韩一区二区三区| 欧美一区二区三区免费观看视频| 亚洲精品欧美极品| 亚洲国产日韩一区| 亚洲国产日韩欧美综合久久| 最新日韩在线| 在线亚洲成人| 亚洲免费小视频| 黄色在线成人| 亚洲欧洲日产国产网站| 一区二区三区四区在线| 亚洲综合色婷婷| 久久精品国产免费观看| 欧美成人免费大片| 99国产精品久久| 欧美一区二区大片| 美女在线一区二区| 欧美视频三区在线播放| 国产精品女人网站| 一区精品在线| 亚洲天堂男人| 久久久综合精品| 最新高清无码专区| 99在线热播精品免费| 亚洲一级黄色片| 玖玖国产精品视频| 国产精品av久久久久久麻豆网| 国产情人节一区| 亚洲精品黄色| 久久久久.com| 亚洲人成久久| 欧美在线亚洲在线| 欧美日本韩国一区| 激情一区二区三区| 香蕉尹人综合在线观看| 亚洲国产精品黑人久久久 | 国产拍揄自揄精品视频麻豆| 亚洲高清视频中文字幕| 亚洲与欧洲av电影| 奶水喷射视频一区| 午夜精品久久久久99热蜜桃导演| 欧美高潮视频| 韩国福利一区| 欧美一二三区精品| 亚洲精品一品区二品区三品区| …久久精品99久久香蕉国产| 亚洲深爱激情| 亚洲国产成人一区| 久久久久久久久久久久久女国产乱 | 久久国产欧美精品| 国产精品久久久99| 一本色道久久精品| 亚洲第一福利视频| 久久久久国产精品午夜一区| 国产精品日韩久久久| 99精品视频免费全部在线| 免费久久精品视频| 久久精品亚洲一区| 国产在线国偷精品产拍免费yy| 亚洲永久在线观看| 亚洲免费av网站| 欧美电影在线播放| 99伊人成综合| 91久久久国产精品| 嫩模写真一区二区三区三州| 有码中文亚洲精品| 麻豆精品一区二区av白丝在线| 久久福利视频导航| 国产一区二区三区在线观看网站 | 国产精品一区二区三区成人| 亚洲一区二区三区精品在线观看 | 一区二区av| 欧美视频精品一区| 亚洲欧美日韩在线不卡| 亚洲午夜在线视频| 国产欧美一区二区精品性| 欧美一区二区成人6969| 午夜欧美大片免费观看 | 欧美国产欧美亚州国产日韩mv天天看完整| 国产一区二区三区久久久| 久久一区二区三区四区五区| 久久婷婷麻豆| 一区二区毛片| 亚洲午夜精品久久久久久浪潮 | 亚洲小视频在线观看| 一本久道久久综合婷婷鲸鱼| 国产精品v欧美精品v日本精品动漫| 亚洲影院色无极综合| 午夜亚洲性色福利视频| 亚洲大胆人体在线| 99国产精品国产精品毛片| 国产日韩欧美麻豆| 欧美激情按摩| 国产精品青草综合久久久久99 | 蜜臀av性久久久久蜜臀aⅴ| 久久国产精品一区二区| 久久精品一区二区国产| 国产一区在线观看视频| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产精品网站在线观看| 免费观看久久久4p| 欧美日韩大陆在线| 欧美主播一区二区三区美女 久久精品人| 亚洲综合色自拍一区| 在线精品视频免费观看| 在线视频欧美日韩| 伊人一区二区三区久久精品| 亚洲精品综合精品自拍| 午夜精品免费视频| 亚洲国产99| 一区电影在线观看| 亚洲国产一区二区三区高清| 亚洲在线一区| 亚洲三级色网| 欧美激情欧美激情在线五月| 国产精品免费看片| 亚洲欧洲一区二区三区| 国产综合久久久久久| 一区二区三区精品视频| 亚洲国产乱码最新视频| 午夜精品免费视频| 亚洲综合色噜噜狠狠| 欧美韩国一区| 欧美顶级少妇做爰| 国产一区二区三区视频在线观看| 一区二区三区.www| 亚洲最新视频在线| 欧美成人精品一区| 亚洲欧美久久| 欧美日韩一区二区三区四区五区| 欧美激情片在线观看| 亚洲福利视频二区| 久久久久久久999| 乱人伦精品视频在线观看| 国产精品一区二区久激情瑜伽| a4yy欧美一区二区三区| 一区二区日本视频| 亚洲精品欧美日韩专区| 一本在线高清不卡dvd | 亚洲第一伊人| 国产午夜精品美女视频明星a级| 亚洲色图自拍| 久久久综合免费视频| 国产真实乱偷精品视频免| 亚洲午夜久久久| 亚洲综合国产激情另类一区| 欧美性jizz18性欧美| 宅男66日本亚洲欧美视频| 亚洲影院免费观看| 国产日韩欧美| 久久精品一区二区三区中文字幕| 久久久五月婷婷| 在线免费不卡视频| 欧美国产一区二区| 亚洲一本大道在线| 久久精品一区| 亚洲国产精品一区二区久| 欧美电影专区| 亚洲少妇在线| 狼人社综合社区| 99亚洲精品| 国产亚洲欧美aaaa| 久久理论片午夜琪琪电影网| 亚洲第一黄网| 亚洲午夜高清视频| 国产午夜亚洲精品理论片色戒| 久久精品国产清高在天天线| 欧美亚洲一区二区在线| 国产偷自视频区视频一区二区| 亚洲性av在线| 美女脱光内衣内裤视频久久网站| 激情综合网激情| 麻豆freexxxx性91精品| 亚洲电影免费在线观看| 一本久久精品一区二区| 欧美剧在线免费观看网站| 亚洲精品婷婷| 亚洲欧美视频| 免费国产一区二区| 亚洲精品裸体| 午夜视频久久久| 亚洲第一主播视频| 欧美区二区三区| 亚洲欧美日韩国产一区二区| 亚洲激情一区二区| 国产欧美日韩一区二区三区| 久久精品女人| 亚洲人成人一区二区三区| 亚洲麻豆视频| 欧美午夜在线一二页| 亚洲欧美清纯在线制服| 欧美风情在线| 久久狠狠亚洲综合| 亚洲人成在线观看网站高清| 欧美日韩国产不卡在线看| 亚洲精品国产拍免费91在线| 久久成人资源| 亚洲精品国产无天堂网2021|