A. linux 守護進程運行結束會關閉嗎
任何進程結束後都會關閉。守護進程是指脫離於控御返制終端並且在後台周期性地執行某種任務或等待處理某些事件的進程,如果守護進程是非周期性的,只是執行一次後就推出,那麼它一樣會關閉。
許多人會把防止服務進程意外退出,周期性檢查服務進程並自動重啟已退出的進程的監控程序與守護進程的概念混淆,雖然大多數監控程序也被以轎源守護進程的鎮帆飢方式運行,但兩者之間的概念是不同的。
B. 簡述linux進程的啟動、終止的方式以及如何進行進程的查看
Linux系統中的進程分為:獨立守護進程和被動守護進程。 獨立守護進程由相應的獨立啟動,而被動守護進程由Xinetd服務監聽啟動。 例如:郵件伺服器配置守護進程sendmail就是獨立守護進程,可以用service命令啟動,而pop3協議就以被動守護進程方式啟動,需要修改/etc/xinetd.d目錄下的相應守護進程文件ipop3,再重新啟動xinetd的方式啟動。
查看進程可以用:ps 列出當前所有的後台進程 刪除進程則用kill命令。kill命令的語法格式正喚很簡單,大致有以下兩種方式: kill [-s 信號 | -p ] [ -a ] 進程號 ... kill -l [信號] -s 指定需要送出的信號。既可以是信號名也可以對應數字。 -p 指定kill命令只是顯示進程的pid,並不真正送出結束信號。 -l 顯示信號名稱列表,這也可以在/usr/include/linux/signal.h文件中找到。 一般用法: ps列出當前所有的後台進程 kill PID。虛清豎某個進程已經掛死或閑置,使用kill命令卻殺不掉,則必須必須發送信差大號9,強行關閉此進程。
C. Linux守護進程詳解
在Linux伺服器實際應用中,經常會有需要長時間執行的任務。這類任務若在前台運行,用戶無法進行其他操作或者斷開與伺服器的連接,否則任務將被中止。此時適合使用守護進程。為了使用守護進程,需要了解Linux前台、後台、守護進程的概念與使用,本文將對此進行講解。
可以看出,」後台任務」與」前台任務」的重要區別: 是否繼承標准輸入 。所以,執行後台任務的同時,用戶還可以輸入其他命令。
為了理解守護任務為何在結束session時也不退出,需要先了解Linux下退出session時發生的操作。
Session退出時,linux系統設計如下:
前台任務會隨著session的退出而退出是因為它收到了 SIGHUP信號 。
後台任務是否會受到SIGNUP信號,取決於shell的 huponexit 參數。可以通過 $ shopt | grep huponexit 查看該參數的值。大多數Linux系統,這個參數默認關閉(off)。因此,session退出的時候,不會把SIGHUP信號發給」後台任務」,即此時的後台任務是守護進程,但這顯然不夠安全。並不保險,因為有的系統的 huponexit 參數可能是打開的(on)狀態。
更保險的方法是使用 disown命令。它可以將指定任務從」後台任務」列表(jobs命令的返回結果)之中移除 。一個」後台任務」只要不在這個列表之中,session 就肯定不會向它發出SIGHUP信號。
執行上面的命令以後, server.js 進程就被移出了」後台任務」列表。你可以執行 jobs 命令驗證,輸出結果裡面,不會有這個進程。
但是,這樣還存在問題。因為 」後台任務」的標准 I/O 繼承自當前 session, disown 命令並沒有改變這一點 。一旦」後台任務」讀寫標准 I/O,就會發現它已經不存在了,所以就 報錯終止執行 。 為了解決這個問題,需要對」後台任務」的 標准 I/O 進行重定向 。
這樣基本上就沒有問題了。
註:
/dev/null 文件的作用
這是一個無底洞,任何東西都可以定向到這里,但是卻無法打開。
所以一般很大的stdou和stderr當你不關心的時候可以利用stdout和stderr定向到這里
nohup命令對server.js進程做了三件事。
阻止SIGHUP信號發到這個進程。
關閉標准輸入。該進程不再能夠接收任何輸入,即使運行在前台。
重定向標准輸出和標准錯誤到文件nohup.out。
也就是說,nohup命令實際上將子進程與它所在的 session 分離了。 注意,nohup命令不會自動把進程變為」後台任務」,所以必須加上&符號
守護進程創建方法:
方法一:
方法二:
方法三:
fg、bg、jobs、&、nohup、ctrl+z、ctrl+c 命令
一、&
加在一個命令的最後,可以把這個命令放到後台執行,如:
二、ctrl + z
可以將一個正在前台執行的命令放到後台,並且處於暫停狀態。
CTRL+Z 和 CTRL+C的對比
CTRL+Z 和 CTRL+C 都是中斷命令,但是他們的作用卻不一樣.
CTRL+C 是強制中斷程序的執行,而 CTRL+Z 的是將任務中斷,但是此任務並沒有結束,仍然在進程中,只是維持掛起的狀態,用戶可以使用 fg/bg 操作繼續前台或後台的任務。
三、jobs
查看當前有多少在後台運行的進程
jobs -l選項可顯示所有任務的PID,jobs的狀態可以是running, stopped, Terminated。但是如果任務被終止了(kill),shell 從當前的shell環境已知的列表中刪除任務的進程標識。
四、fg
將後台中的命令調至前台繼續運行。如果後台中有多個命令,可以用 fg %jobnumber (jobnumber是命令編號,不是進程號)將選中的命令調出。
五、bg
將一個在後台暫停的命令,變成在後台繼續執行。
如果後台中有多個命令,可以用 bg %jobnumber 將選中的命令調出。
六、kill
方法1:通過jobs命令查看job號(假設為num),然後執行
方法2:通過ps命令查看job的進程號(PID,假設為pid),然後執行
前台進程的終止:Ctrl+c
七、nohup
如果想讓程序即使在關閉當前的終端後也始終在後台執行(之前的&做不到),需要使用nohup命令。
nohup命令可以在你退出帳戶/關閉終端之後繼續運行相應的進程。
關閉終端後,在另一個終端jobs已經無法看到後台跑的程序了,此時利用ps(進程查看命令)查看進程。
http://m.2cto.com/os/201301/185701.html
http://www.cnblogs.com/kaituorensheng/p/3980334.html
http://m.blog.csdn.net/article/details?id=50766752
D. 如何正確編寫linux守護進程
1、守護進程,也就是通常說的Daemon進程,是Linux中的後台服務進程。它是一個生存期較長的進程,通常獨立於控制終端並且周期性地執行某種任務或等待處理某些發生的事件。如果想讓某個進程不因為用戶或終端或其他地變化而受到影響,那麼就必須把這個進程變成一個守護進程。
2、創建守護進程步驟
1)創建子進程,父進程退出
之後的所有工作都在子進程中完成,而用戶在Shell終端里則可以執行其他命令,從而在形式上做到了與控制終端的脫離。
在Linux中父進程先於子進程退出會造成子進程成為孤兒進程,而每當系統發現一個孤兒進程時,就會自動由1號進程(init)收養它,這樣,原先的子進程就會變成init進程的子進程。
2)在子進程中創建新會話
進程組:是一個或多個進程的集合。進程組有進程組ID來唯一標識。除了進程號(PID)之外,進程組ID也是一個進程的必備屬性。每個進程組都有一個組長進程,其組長進程的進程號等於進程組ID。且該進程組ID不會因組長進程的退出而受到影響。
會話周期:會話期是一個或多個進程組的集合。通常,一個會話開始於用戶登錄,終止於用戶退出,在此期間該用戶運行的所有進程都屬於這個會話期。
(1)pid_t setsid(void);
setsid() creates a new session if the calling process is not a process group leader. The calling process will be the only process in this new process group and in this new session.
setsid函數用於創建一個新的會話,並擔任該會話組的組長。調用setsid有下面的3個作用:
① 讓進程擺脫原會話的控制
② 讓進程擺脫原進程組的控制
③ 讓進程擺脫原控制終端的控制
有以下三個結果:
(a)成為新會話的首進程
(b)成為一個新進程組的組長進程
(c)沒有控制終端。
有些人建議在此時再次調用fork,並使父進程終止。第二個子進程作為守護進程繼續運行。這樣就保證了該守護進程不是會話首進程。
setsid函數能夠使進程完全獨立出來,從而擺脫其他進程的控制。
setsid()調用成功後,進程成為新的會話組長和新的進程組長,並與原來的登錄會話和進程組脫離。由於會話過程對控制終端的獨占性,進程同時與控制終端脫離。 子進程可以自己組成一個新的進程組,即調用setpgrp()與原進程組脫離關系,產生一個新的進程組,進程組號與它的進程號相同.這樣,父進程退出運行後就不會影響子進程的當前運行.
3)改變當前目錄為根目錄
使用fork創建的子進程繼承了父進程的當前工作目錄;進程活動時,其工作目錄所在的文件系統不能卸下。通常的做法是讓"/"作為守護進程的當前工作目錄,也可以是其他目錄,如/tmp,使用chdir。
4)重設文件許可權掩碼
文件許可權掩碼是指屏蔽掉文件許可權中的對應位。比如,有個文件許可權掩碼是050,它就屏蔽了文件組擁有者的可讀與可執行許可權。mask = mask & ~050
通常,把文件許可權掩碼設置為0,umask(0)。
5)關閉文件描述符
用fork函數新建的子進程會從父進程那裡繼承已經打開了的文件描述符。這些被打開的文件可能永遠不會被守護進程讀寫,但它們一樣消耗系統資源,而且可能導致所在的文件系統無法卸下。
在上面的第二步之後,守護進程已經與所屬的控制終端失去了聯系。因此從終端輸入的字元不可能達到守護進程,守護進程中用常規方法(如printf)輸出的字元也不可能在終端上顯示出來。所以,文件描述符為0、1和2 的3個文件(常說的輸入、輸出和報錯)已經失去了存在的價值,也應被關閉。
for(i=0;i<MAXFILE;i++)
close(i);
6)守護進程退出處理
當用戶需要外部停止守護進程運行時,往往會使用 kill命令停止該守護進程。所以,守護進程中需要編碼來實現kill發出的signal信號處理,達到進程的正常退出。
signal(SIGTERM, sigterm_handler);
void sigterm_handler(int arg)
{
_running = 0;
}
7)處理SIGCHLD信號
處理SIGCHLD信號並不是必須的。但對於某些進程,特別是伺服器進程往往在請求到來時生成子進程處理請求。如果父進程不等待子進程結束,子進程將成為僵屍進程(zombie)從而佔用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響伺服器進程的並發性能。在Linux下可以簡單地將 SIGCHLD信號的操作設為SIG_IGN。
signal(SIGCHLD,SIG_IGN);
這樣,內核在子進程結束時不會產生僵屍進程。
E. linux性能調優都有哪幾種方法
1、為磁碟I/O調整Linux內核電梯演算法
在選擇文件系統後,有一些內核和掛載選項可能會影響到它的性能表現,其中一個內核設置是電梯演算法,通過此演算法,系統可以平衡低延遲需求,收集足夠的數據,從而有效地組織對磁碟的讀和寫請求。
2、禁用不必要的守護進程
伺服器上有很多守護進程或服務不是必需的,這些服務不但沒有發揮作用,還消耗了一定的內存和CPU,因此,需要將它們從伺服器移除,這一步最大的好處就是可以加快啟動時間,釋放內存。
3、關掉GUI
一般來說,Linux伺服器是不需要GUI的,所以管理任務都可以在命令行下完成,因此最好關掉GUI。
4、清理不需要的模塊或功能
在伺服器軟體包中有太多被啟動的功能或模塊實際上是不需要的,仔細看看Apache配置文件,確定FrontPage支持或其它額外的模塊是否真的要用到,如果不需要,應該毫不猶豫地從伺服器禁用掉,這樣有助於提高系統內存可用量,騰出更多資源給那些真正需要的軟體,讓它們運行得更快。
5、禁用控制面板
在Linux中,有許多流行的控制面板,如Cpanel,Plesk,Webmin和phpMyAdmin等,但是,禁用掉這些軟體包可以釋放出大約120MB內存,它們可以通過PHP腳本(盡管有些不安全),或命令行命令啟用,這樣做後,內存使用量大約可以下降30-40%。
6、改善Linux Exim伺服器性能
7、使用AES256增強gpg文件加密安全
為了提高備份文件或敏感信息的安全,許多Linux系統管理員都會使用gpg進行加密,它是一個開放的加密演算法,沒有什麼比它更安全的了。
8、遠程備份服務安全
安全是選擇遠程備份服務最重要的因素,大多數系統管理員都害怕兩件事:(黑客)可以刪除備份文件,不能從備份恢復系統。為了保證備份文件100%的安全,備份服務公司提供遠程備份伺服器,使用scp腳本或RSYNC通過SSH傳輸數據,這樣,沒有人可以直接進入和訪問遠程系統,因此,也沒有人可以從備份服務刪除數據。在選擇遠程備份服務提供商時,最好從多個方面了解其服務強壯性,如果可以,可以親自測試一下。
F. Linux系統中的守護進程講解
守護進程daemon,是生存期較長的一種進程。它們常常在系統自舉時啟動,僅在系統關閉時才終止。因為它們沒有控制終端,所以說它們是在後台運行的。UNIX系統有很多守護進程,它們執行日常事務活動。
1、系統自舉
自舉(bootstrapping)一詞來自於人都是靠自身的自舉機構站立起來的這一思想。計算機必須具備自舉能力將自己所有的元件激活,以便能完成載入操作系統這一目的,然後再由操作系統承擔起那些單靠自舉代碼無法完成的更復雜的任務。
自舉只有兩個功能:加電自檢和磁碟引導。
加電自檢:當我們按下計算機電源開關時,頭幾秒鍾機器似乎什麼反應也沒有,其實,這時的計算機正在進行加電自檢,以斷定它的所有元件都在正確地工作。如果某個元件有故障,顯示器上就會出現報警提示信息(如果顯示器也不能正常工作,則以一串嘟嘟聲來報警)。由於大多數計算機工作非常可靠,加電自檢報警非常罕見。
磁碟引導:查找裝有操作系統的磁碟驅動器。從磁碟載入操作系統的原因有二,一是操作系統升級簡單容易,二是使用戶擁有選擇操作系統的自由。
當加電自檢和磁碟引導完成時,自舉操作就啟動一個讀寫操作系統文件和將它們復制到隨機存儲器中的過程,此時的機器才是真正意義上的計算機。計算機的啟動可以有冷啟動和熱啟動兩種方式 ,它們之間的差別是熱啟動不進行機器的自檢(機器本身配置的檢查與測試),當計算機在使用過程中由於某些原因造成死機時,可以對計算機進行熱啟動處理。
2、守護進程的概念
通過ps axj命令可以查看到守護進程:
參數a表示不僅列當前用戶的進程,也列出所有其他用戶的進程,參數x表示不僅列有控制終端的進程,也列出所有無控制終端的進程,參數j表示列出與作業控制相關的信息。
代碼如下:PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND 0 1 1 1 ? -1 Ss 0 0:01 /sbin/init 0 2 0 0 ? -1 S< 0 0:00 [kthreadd] 2 3 0 0 ? -1 S< 0 0:00 [migration/0] 2 4 0 0 ? -1 S< 0 0:00 [ksoftirqd/0]... 1 2373 2373 2373 ? -1 S<s 0 0:00 /sbin/udevd --daemon... 1 4680 4680 4680 ? -1 Ss 0 0:00 /usr/sbin/acpid -c /etc... 1 4808 4808 4808 ? -1 Ss 102 0:00 /sbin/syslogd -u syslog...
凡是TPGID一欄寫著-1的都是沒有控制終端的進程,也就是守護進程。在COMMAND一列用[]括起來的名字表示內核線程,這些線程在內核里創建,沒有用戶空間代碼,因此沒有程序文件名和命令行,通常採用以k開頭的名字,表示Kernel。init進程我們已經很熟悉了,udevd負責維護/dev目錄下的設備文件,acpid負責電源管理,syslogd負責維護/var/log下的日誌文件,可以看出,守護進程通常採用以d結尾的`名字,表示Daemon。 創建守護進程最關鍵的一步是調用setsid函數創建一個新的Session,並成為Session Leader。 例子: C/C++ Code復制內容到剪貼板 void daemonize(void) { pid_t pid; printf("into deamonizen"); if (pid=fork() < 0) { perror("fork"); exit(1); } else if (pid !=0) { exit(0); } setsid(); if (chdir("/") < 0) { perror("chdir"); exit(1); } close(0); open("/dev/null", O_RDWR); p2(0, 1); p2(0, 2); printf("out deamonizen"); }
3、編寫守護進程 在編寫守護進程程序時,需遵循一些基本規則:
(1)首先要做的是調用umask將文件模式創建屏蔽字設置為0。
(2)調用fork,然後使父進程退出。
(3)調用setsid以創建一個新會話。
(4)將當前工作目錄更改為根目錄。
(5)關閉不再需要的文件描述符。
(6)某些守護進程打開/dev/null使其具有文件描述符0、1和2,任何一個試圖讀標准輸入、寫標准輸出或標准出錯的庫常式都不會產生任何效果。 與守護進程有關的一個問題是如何處理出錯消息,需要有一個集中的守護進程出錯記錄設施,這就是syslogd進程。
4、守護進程慣例 為了正常運作,某些守護進程實現為單實例的,有就是在任一時刻只運行該守護進程的一個副本。文件鎖和記錄鎖機制是一種方法的基礎,該方法用來保證一個守護進程只有一個副本在運行。
在UNIX系統中,守護進程遵循下列公共慣例:
(1)若守護進程使用鎖文件,那麼該文件通常存放在/var/run目錄中。鎖文件的名字通常是name.pid,name是該守護進程或服務的名字。
(2)若守護進程支持配置選項,那麼配置文件通常存放在/etc目錄中。配置文件的名字通常是name.conf。
(3)守護進程可用命令行啟動,但通常它們是由系統初始化腳本啟動的。
(4)若一守護進程有一配置文件,那麼當該守護進程啟動時,它讀該文件,但在此之後一般就不會再查看它。
G. Linux後台進程
引入的原因: 用於控制向多個進程進行信號的分發,發給一個進程組是信號會發生給進程組中每一個進程
會話是一個或者多個進程組的集合,進程調用 setsid 函數建立一個會話。
進程調用setsid函數建立一個新的會話,會發生下面幾件事
守護進程是生存期長的一種進程,沒有控制終端。他們常常在系統引導裝入時啟動,系統關閉是終止。守護進程程序通常以字母 d 結尾。
用戶層的守護進程的父進程是 init 進程。內核的守護進程並非init進程。
以 & 方式運行的為後台進程
比如: ping www..com &
通過 jobs 命令查看
將後台程序放到前台
通過 control+c 命名發送』hupinit『信號kill掉進程
終端被掛斷或者用戶注銷,SIGHUP信號會被發送到該終端相關的控製程序,而SIGHUP的默認行為是終止程序的運行。
需要實現終端退出後進程依然在後台運行,有兩種途徑
如果setid函數的進程就是一個進程組的組長,則函數會返回出錯。為了解決這樣情況,通常函數需要先fork,然後父進程退出,由子進程執行setsid。由於子進程繼承的是父進程的進程組ID,而其PID是新分配的ID,因此這兩者不可能相等,即子進程不可能是進程組的組長。 這種情況下,由於父進程先於子進程退出,因此子進程的父進程會有init進程接管。 而這就是sid命令的實現原理。
設置 setsid www..com
我們對比下和nohup
我們可以看到setsid的父進程變成了init進程。由於會話和父進程和shell無關了,因此無論如何shell都無法向該進程發送SIGHUP命令
H. linux怎麼關閉所有進程
您好,方法
首先登錄linux伺服器。
方式1:輸入【pgrep 進程名稱】即可獲取到pid列表。
方式2:使用【ps】命令查看進程pid。
例如:ps -ef|grep java
-e:顯示所有進程。
-f :做一個更為完整的輸出。
| 管道
grep xxxx 篩選出xxxx的進程。
方式3:使用【top】命令查看進程pid。
在命令行輸入:top 按下回車鍵即可。
【ctrl+c】是退出top界面。
方式4:通過【ls /proc】命令查看進程pid。
Linux在啟動一個進程時,系統會在/proc下創建一個以PID命名的文件 夾。
每一個數字文件夾就是對應的一個進程pid。
查出需要關閉的進程ID後,使用命令【pkill -9 進程ID】即可刪除關閉進程。
I. 哪個命令不可以關閉linux
您好,exit命令不可以關閉,Linux是一個多用戶、多任務的操作系統,安全地關閉計算機是保障系統正常運行的重要措施。在Linux中有halt、init、shutdown等常用的關機命令。它們都可以達到關閉系統的目的,但每個命令的內舉首中部工作過程是不同的。halt是最簡單的關機命令。halt命令執行時,殺死應用進程,執行sync系統調用,文件系統寫操作完成後就會停止內核。init是所有進程的祖先,它的進程號始終為1,所以發送TERM信號給init會終止所有的用戶進程、守護進程等。shutdown就是使用這種機制。init定義了8個運行級別,init0為關機,init1為重啟等。不能使用直接斷掉電源的方式來關閉Linux系統,而應通過shutdown命令安全地關機。這是因為Linux操作系統在後台運行著許多進程,所以強制關機可能會導致進程的數據丟失,使系統處於不穩定的狀態,甚至有時會造成系統中硬體設備的損壞。而在系統關正山機前使用shutdown命令,系統管理員會通知所有登錄的用戶系統將要關閉。並且login指令會被凍結,不允許新的用戶再登錄。reboot命令的功能與工作過程和halt命令相似,區別是引起計算機系統重新啟動,而halt是單純關機。reboot命令的參數與halt相差不多。exit命令的作用是當前登錄Linux的用戶退出系統,它的使用許可權是所有用戶。exit命令沒有參數,芹肆運行後退出系統進入登錄界面,允許再以其他用戶身份登錄Linux系統。
J. linux如何刪除守護進程
之前開發的一個流媒體服務與網關服務,為了保障其可靠運行,對進程增加了守護,而且大大減低了運維難度。這里就不得不說一下Supervisor。
Supervisor是用Python開發的一套通用的進程管理程序,能將一個普通的命令行進程變為後台daemon,並監控進程狀態,異常退出時能自動重啟。它是通過fork/exec的方式把這些被管理的進程當作supervisor的子進程來啟動,這樣只要在supervisor的配置文件中,把要管理的進程的可執行文件的路徑寫進去即可。也實現當子進程掛掉的時候,父進程可以准確獲取子進程掛掉的信息的,可以選擇是否自己啟動和報警。