導航:首頁 > 操作系統 > linux啟動守護進程

linux啟動守護進程

發布時間:2023-03-25 13:02:48

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

Ⅱ linux同時啟動三個進程

之前發過一篇守護進程的文章,但是解析的不夠詳細,這次,詳細來解釋守護進程的一些概念和特性。

概念:

後台運行、沒有悄鏈控制端與之相連的進程。獨立於控制終端,通常周期性的執行某種任務。

Why survival:

Linux的大多數伺服器是用守護進程的方式實現,例如:Internet伺服器的inted,Web伺服器的http等。Linux守護進程類似Windowns的系統服務。

daemon特性:

1.讓進程在後台執行,方法是fork產生一個子進程,然後父進程退出。

2.調用setsid創建一個新對話期。

控制端、登錄會話和進程組通常是從父進程繼承來的。

守護進程要擺脫它們,不受它們的影響,其方法是調用setid使進程成長為一個會話組長。

註:當進程是會斗碰話組長時,調用setid會失敗,但第一點已經保證進程不是會話組長。

setid調用成功後,進程成為新的會話組長和進程組長,並與原來的登陸會話和進程組脫離,由於會話過程對控制終端的獨占性,進程同時與控制終端脫離。

3.禁止進程重新打開控制終端。

以上完成後,進程已經成為一個無終端的會話組長,但是它可以重新申請打開一個終端,為了避免這種情況的發生,可以通過使進程不再是會話組長來實現,再一次fork創建新的進程,使調用fork的進程退出。

4.關閉不再需要的文件描述符。

創建的新子進程從父進程繼承打開的文件描述符。如不關閉,將會浪費系統資源,造成進程所在的文件系統無法卸下以及引起無法預料的結果,先得到最高文件描述值,然後用一個循環程序,關閉0到最高文件描述符值的所有文件描述符。

5.將當前目錄更改為根目錄。

當守護進程當前工作目錄在一個裝配文件系統時,改文件系統不能被拆卸啟銷孫。一般需要將工作目錄改為根目錄。

6.將文件創建時使用的屏蔽字設置為0。

進程從創建它的父進程那裡繼承的文件創建屏蔽字可能會拒絕某些許可權。為防止這一點,使用umask(0)將屏蔽字清零。

7.處理SIGCHLD信號。

這一點不是必須的,但是對於某些進程,特別是伺服器進程往往在請求到來時生成子進程處理請求,如果父進程不等待子進程結束,子進程將成為僵屍進程(zombie),從而佔用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響伺服器進程的並發性能。

在Linux下可以簡單的將SIGCHLD信號的操作設為SIG_IGN,這樣子進程結束時就不會產生僵屍進程。

Ⅲ linux怎麼用守護進程和sdl

1、使用sudosupervisorctl進入supervisor管理終端。
2、使用reload重新讀取配置文件並重啟當前supoervisor管理的所有進程。
3、也可以使用update重新載入配置(默認不重啟),隨後使用startgf-app啟動指定的應用程序。

Ⅳ Linux下的守護進程的概念daemon.py是什麼意思

守護進程一般是伺服器類程序中用來無限循環等待事件發生的一個進程或線程,也就是說,它的作用是等待一個事件發生,事件發生後調用另外的進程區完成相應的工作,自己再回去等事件發生。
用ps aux查看進程的進程號,然後用kill殺掉
py是後綴名,意思是用python語言寫的。
至於如何重啟,這個沒有統一的方法。你可以查看相關的文檔,或者在google上搜索,或者man一下。。
守護進程一個或者多個都是可能的。

Ⅳ 簡述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,強行關閉此進程。

Ⅵ linux 守護進程和普通二進制命令的區別

守護進程一般系統啟動的時候可以跟著啟動,需要配置。位置:
程序位置:
/etc/init.d
相關配置文件:
/etc/rc*
守護進程,沒有控制終端,在後台運行。因此,守護進程的輸出,都會寫到日誌系統中。目錄/var/log。
守護進程的代表:inetd,iptables,sshd,atd,crond這樣的進程。
一般,命令:都會有控制終端,可以進行人機交互,可以進行作業控制,輸出都在屏幕上(脊孝灶理解成終端或者控制台)。比如:vi,sed,awk,gcc這樣的程序。
配置文件位置:/etc,如mysql是/etc/my.cnf。
守護進程一般提供當服務使用,比如我們的http,dns,dhcp這樣的網路服櫻扮務,系統日誌服務,swap虛擬交換控制進程等。
普通命令,當我們正慎歷常使用的一些應用軟體即可,其實真的就是一個應用軟體或小程序,如果你看過UNIX編程書籍會理解這句話。
當然守護進程也是程序,不過一般都是提供系統級的服務或應用。系統級典型的是atd,sshd,crond,應用級的如tomcat提供web服務,mysql提供資料庫服務。這些程序都跑在後台。

Ⅶ linux用那種方法來啟動伺服器的守護進程

2種啊 一種是答橘stand alone 還有一種是super dameon
大部分都是清御團stand alone 也就是獨立啟動的拆蠢 比如sshd named 等等

由super dameon 管理的比如說 telnet tftp swat 等等

Ⅷ linux服務需要一直啟用怎麼辦

您好,要想讓Linux服務一直啟用,您可以使用Linux的服務管理工具,它可以讓您在啟動系統時自動啟動指定的服務臘陵。此外,您還可以使用Linux的定時任務管理工具,它可以讓您按照指定的時間間隔來啟動指定的服務。另外,您還可以使用Linux的守護進程管理工具,它可以讓您在指定的時間間隔檔做內檢測指定的服務是否正常運行,如果檢測到服務已停止,它會自動重新啟動該服務。通過使用這些Linux服務輪蠢戚管理工具,您可以輕松實現Linux服務的一直啟用。

Ⅸ 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)若一守護進程有一配置文件,那麼當該守護進程啟動時,它讀該文件,但在此之後一般就不會再查看它。

Ⅹ linux下如何自動啟動自己編寫的守護進程

在你跡乎的守護進程中忽略SIGCHLD,SIGPIPE和SIGHUP信號,在rc.local中用"你的守護進首旦程姿芹悉名 &"啟動

閱讀全文

與linux啟動守護進程相關的資料

熱點內容
鴻蒙加密等級 瀏覽:802
cocos2dluapdf 瀏覽:491
假的加密鎖靠譜嗎 瀏覽:176
經營聖手伺服器怎麼調 瀏覽:749
arduino手機編程 瀏覽:481
西醫pdf下載 瀏覽:29
後浪電影學院pdf 瀏覽:813
程序員怎麼做到不被人嫉妒 瀏覽:669
cmd新建文件夾md命令 瀏覽:570
php數組中的數值排序 瀏覽:832
安卓手機怎麼避免小孩內購 瀏覽:171
聯想伺服器出現黃色嘆號怎麼辦 瀏覽:991
約翰編譯器製作教程 瀏覽:130
大地pdf 瀏覽:109
pdfplus 瀏覽:577
匯編O命令 瀏覽:970
plt轉pdf 瀏覽:366
魔獸60宏命令大全 瀏覽:480
php志願者網站源碼 瀏覽:875
貿易pdf 瀏覽:498