linux下如何創(chuàng)建守護進程的步驟
這兩天學(xué)習(xí)了linux 守護進程這個地方知識點挺多的,而且很重要,所以,今天添加一點小筆記。
1,進程的概念:程序的一次動態(tài)執(zhí)行過程。
進程存在于內(nèi)存當中,存在著 創(chuàng)建,調(diào)度,執(zhí)行和消亡,進程號是進程的唯一標志,每一個進程都有自己獨立的內(nèi)存空間,在32位操作系統(tǒng)中,進程擁有0-4G的內(nèi)存空間,其中0-3G屬于用戶,3G-4G屬于內(nèi)核,所以就出現(xiàn)了進程的執(zhí)行模式:用戶模式和內(nèi)核模式。
2,進程的類型:交互進程,批處理進程,守護進程
3,守護進程:Linux中的后臺服務(wù)進程,daemon進程
4,守護進程的創(chuàng)建步驟:
(1)創(chuàng)建子進程,父進程退出。
經(jīng)過這步以后,子進程就會成為孤兒進程(父進程先于子進程退出, 此時的子進程,成為孤兒進程,會被init進程收養(yǎng))。使用fork()函數(shù),如果返回值大于0,表示為父進程,exit(0),父進程退出,子進程繼續(xù)。
(2)在子進程中創(chuàng)建新會話,使當前進程成為新會話組的組長。
使用setsid()函數(shù),如果當前進程不是進程組的組長,則為當前進程創(chuàng)建一個新的會話期,使當前進程成為這個會話組的首進程,成為這個進程組的組長。
(3)改變當前目錄為根目錄。
由于守護進程在后臺運行,開始于系統(tǒng)開啟,終止于系統(tǒng)關(guān)閉,所以要將其目錄改為系統(tǒng)的根目錄下。進程在執(zhí)行時,其文件系統(tǒng)不能被卸下。
(4)重新設(shè)置文件權(quán)限掩碼。
進程從父進程那里繼承了文件創(chuàng)建掩碼,所以可能會修改守護進程存取權(quán)限位,所以要將文件創(chuàng)建掩碼清除,umask(0);
(5)關(guān)閉文件描述符。
子進程從父進程那里繼承了打開文件描述符。所以使用close即可關(guān)閉。
在這里要用到getdtablesize()函數(shù)得到這個進程打開文件的數(shù)目。
按照上面的步驟即可完成守護進程的創(chuàng)建。
具體的代碼如下,守護進程的功能寫的較為簡單,往文件里寫東西:
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <stdlib.h>
int main()
{ // 1創(chuàng)建子進程 ,父進程退出
pid_t pid = fork();
if(pid<0)
{
perror("fork error");
return -1;
}
else if(pid>0)
{
exit(0);
}
else
{
while(1)
{
//2 組長
setsid();
// 改變路徑至根目錄
chdir("/tmp");
//重設(shè)文件掩碼
umask(0);
//關(guān)閉文件描述符
int des=getdtablesize();
int i=0;
for(i=0;i<des;i++)
{
close(i);
}
}
char buf[]="bat xld come!\n";
int fd=open("xld.txt",O_WRONLY|O_CREAT |O_APPEND,0666);
write(fd,buf,sizeof(buf));
sleep(2);
}
return 0;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
APACHE 配置文件中文版 httpd.conf FOR Apache 2.2.13
APACHE配置文件中文版 httpd.conf FOR Apache 2.2.13 ,綜合網(wǎng)上2.0版本的翻譯,加入自己的理解,補充完善。2009-11-11
詳解linux為阿里云ECS(CentOS7)配置IPv6地址
這篇文章主要介紹了詳解linux為阿里云ECS(CentOS7)配置IPv6地址,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
linux下使用Docker和OSS輕松搭建ownCloud專屬網(wǎng)盤(網(wǎng)盤關(guān)閉不用怕)
本文將利用阿里云容器服務(wù)在幾分鐘內(nèi)輕松搭建一個基于Docker的ownCloud專屬網(wǎng)盤,并使用阿里云提供的OSS(Object Storage Service,對象存儲服務(wù))作為高可靠、低成本的云存儲后端,需要的朋友可以參考下2017-04-04
2018即將推出的Apache Spark 2.4都有哪些新功能
即將發(fā)布的 Apache Spark 2.4 版本是 2.x 系列的第五個版本。 本文對Apache Spark 2.4 的主要功能和增強功能進行了概述,需要的朋友可以參考下2018-09-09

