一.總的來(lái)講,操作系統(tǒng)只要能實(shí)現(xiàn)以下兩點(diǎn)就可以了:
1.時(shí)間的假象和空間的假象
時(shí)間假象的作用是實(shí)現(xiàn)了多進(jìn)程/多線程;空間假象的作用是實(shí)現(xiàn)了虛擬內(nèi)存。無(wú)疑,這兩點(diǎn)是現(xiàn)代操作系統(tǒng)的基石。
2.和硬件接口以及和用戶態(tài)的接口
從硬件那里接收信息,這個(gè)用中斷實(shí)現(xiàn),和硬件互相讀寫,這個(gè)用基本IO實(shí)現(xiàn);從用戶接收請(qǐng)求,這個(gè)用系統(tǒng)調(diào)用...向用戶發(fā)送信息,這個(gè)用信號(hào)...。無(wú)疑,這樣就在接口層次滿足了上層用戶和底層硬件的要求,無(wú)疑,UNIX在這一點(diǎn)上是成功的(信號(hào),IPC,POSIX...)。
二.大內(nèi)核和微內(nèi)核
如果我們把操作系統(tǒng)內(nèi)核在其生命周期的前期按照時(shí)間分割,我們把它分為源碼階段和二進(jìn)制階段,大內(nèi)核和微內(nèi)核的區(qū)分是二進(jìn)制階段的區(qū)分。我們都知道,Linux是大內(nèi)核,然而為何大而不亂呢?實(shí)際上看看它的源碼就明白了,它的源碼組織非常好,核心文件不到100個(gè),其它的都是驅(qū)動(dòng)或者體系結(jié)構(gòu)相關(guān)的代碼。畢竟,開(kāi)發(fā)者知道,對(duì)于二進(jìn)制文件,人是看不懂的,人所看的是源碼,將二進(jìn)制文件分開(kāi),無(wú)疑會(huì)增加維護(hù)的復(fù)雜性,更何況,將問(wèn)題控制在源碼階段就節(jié)省了很多調(diào)試時(shí)間。
三.設(shè)備驅(qū)動(dòng)開(kāi)發(fā)
1.閱讀datasheet,編寫IO、中斷例程
2.和操作系統(tǒng)內(nèi)核接口,也就是插入內(nèi)核最低端
3.和用戶態(tài)接口,也就是在最上端導(dǎo)出一個(gè)用戶接口,比如ioctl
4.編寫用戶態(tài)demo和工具進(jìn)程,調(diào)用第3步的接口
5.試用,調(diào)試打包
6.總結(jié),層次結(jié)構(gòu)-從上到下:最終用戶-應(yīng)用程序員-系統(tǒng)程序員-驅(qū)動(dòng)程序員-硬件工程師
四.到底應(yīng)不應(yīng)該在內(nèi)核中解決fork×××
fork×××臭名昭著,一堆看似亂碼的字符就能耗盡你的cpu:.(){.|.&};.。如果想在內(nèi)核解決它,那是很簡(jiǎn)單的,那就是控制task_struct的層數(shù),我們知道Linux進(jìn)程是分層樹(shù)形組織的,如果限制層數(shù)最多為5層,那么該×××最多也就是炸五次就無(wú)法發(fā)揮作用了,然而這卻不是好方法,因?yàn)檫@會(huì)損害那些正好需要6層或以上的正常程序的利益。其實(shí)還有很多解決辦法:1.利用cpu組調(diào)度,限制它們可以使用的資源;2.修改oom killer的核心算法,優(yōu)先砍掉那些過(guò)于長(zhǎng),然而卻很瘦的樹(shù)枝,這也符合園藝工人的操作方式,因?yàn)檫@種枝丫會(huì)帶走過(guò)多的養(yǎng)分!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。