date: 2017-10-13 16:17:28
title: 「理解Unix進(jìn)程」讀書筆記
百度腦圖 - 理解UNIX進(jìn)程: http://naotu.baidu.com/file/8945ac178c9961cda97a17a44de511ad?token=1447b9bed19693b2
圖靈社區(qū) - 理解UNIX進(jìn)程: http://www.ituring.com.cn/book/1081
知道如何使用計(jì)算機(jī),但對于計(jì)算機(jī)的工作原理卻一無所知; 對工作原理有了深入的了解之后,可以更快地理解并診斷出現(xiàn)的問題
能力越大,責(zé)任也越大
用戶空間(userland)和內(nèi)核
系統(tǒng)調(diào)用
manpages
所有的代碼都是在進(jìn)程中執(zhí)行的
進(jìn)程皆有標(biāo)識 pid
常常會在日志文件中發(fā)現(xiàn)pid
進(jìn)程皆有父 ppid
進(jìn)程皆有文件描述符
文件描述符代表打開的文件
Unix哲學(xué):在Unix世界中,萬物皆為文件
文件描述符只是用來跟蹤打開的資源
每個Unix進(jìn)程都有三個打開的資源,它們是標(biāo)準(zhǔn)輸入(STDIN)、標(biāo)準(zhǔn)輸出(STDOUT)和標(biāo)準(zhǔn)錯誤(STDERR)
進(jìn)程皆有資源限制
內(nèi)核為進(jìn)程施加了某些資源限制
軟限制與硬限制
sysctl(8)
進(jìn)程皆有環(huán)境
環(huán)境變量
系統(tǒng)調(diào)用不能直接操作環(huán)境變量
進(jìn)程皆有參數(shù)
argv是argument vector
ENV并不是Hash
ARGV只是一個Array
進(jìn)程皆有名
兩種運(yùn)作在進(jìn)程自身層面上的機(jī)制可以用來互通信息。一個是進(jìn)程名稱,另一個是退出碼。
進(jìn)程皆有退出碼
另一種結(jié)束進(jìn)程的方法是使用一個未處理的異常
進(jìn)程皆可衍生
進(jìn)程從父進(jìn)程處繼承了其所占用內(nèi)存中的所有內(nèi)容,以及所有屬于父進(jìn)程的已打開的文件描述符
竟然同時(shí)執(zhí)行了if語句的if和else代碼塊
其實(shí)也可以通過block來使用fork
守護(hù)進(jìn)程
與脫離終端會話的進(jìn)程進(jìn)行通信
Unix信號
寫時(shí)復(fù)制(copy-on-write,CoW)
進(jìn)程可待
即發(fā)即棄(fire and forget)
看顧(Babysitting)
競爭條件(race conditions)
master/worker
僵尸進(jìn)程
Good Things Come to Those Who Wait。
進(jìn)程皆可獲得信號
信號投遞是不可靠的。
任何一行代碼都能夠被信號中斷
信號是一種異步通信。
(1) 忽略該信號 (2) 執(zhí)行特定的操作 (3) 執(zhí)行默認(rèn)的操作
信號由內(nèi)核發(fā)送
重定義信號
忽略信號
捕獲一個信號有點(diǎn)像使用一個全局變量
如果進(jìn)程在接收到一個信號的同時(shí)還在處理其他的信號
進(jìn)程皆可互通
進(jìn)程間通信(簡稱IPC)
管道和套接字對(socket pairs)。
共享管道
有自己的文件描述符以及其他的一切,因此也可以與子進(jìn)程共享。
流與消息: 沒有開始和結(jié)束的概念。
之后跟著一些特定協(xié)議的分隔符(delimiter)
遠(yuǎn)程IPC: TCP RPC 分布式系統(tǒng)
管道和套接字都是對進(jìn)程間通信的有益抽象。
守護(hù)進(jìn)程是在后臺運(yùn)行的進(jìn)程,不受終端用戶控制
首個進(jìn)程
進(jìn)程組和會話組
會話組是更高一級的抽象,它是進(jìn)程組的集合
/dev/null
生成終端進(jìn)程
除非你真的需要,通常我們都會避免傳遞字符串,而是盡可能地傳遞數(shù)組。
與Unix進(jìn)程打交道事關(guān)兩件事:抽象和通信。