您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Linux中C后臺服務程序單進程控制的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
介紹
通常后臺服務器程序都必須有且只有一個進程,那么如何單進程呢?
本例子是通過flock函數對/var/run/myserver.pid記錄pid文件的進行加鎖
若加鎖不正常,說明后臺服務進程已經在運行了,這時則直接報錯退出
若加鎖成功,說明后臺服務進程沒有在運行,這時可以正常啟用進程
后臺服務程序單進程控制
代碼
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <errno.h> #include <fcntl.h> #define PID_BUF_LEN (20) #define RUN_PID_FILE "/var/run/myserver.pid" //服務進程單實例運行 //返回值: 1--正在運行,0--未運行,-1--出錯 int server_is_running() { int fd = open(RUN_PID_FILE, O_WRONLY|O_CREAT); if(fd < 0) { printf("open run pid err(%d)! %s\n", errno, RUN_PID_FILE); return -1; } // 加鎖 // LOCK_SH 建立共享鎖定。多個進程可同時對同一個文件作共享鎖定。 // LOCK_EX 建立互斥鎖定。一個文件同時只有一個互斥鎖定。 if(flock(fd, LOCK_EX|LOCK_NB) == -1) { //加不上鎖,則是服務正在運行,已上鎖了 printf("server is runing now! errno=%d\n", errno); close(fd); return 1; } // 加鎖成功,證明服務沒有運行 // 文件句柄不要關,也不要解鎖 // 進程退出,自動就解鎖了 printf("myserver is not running! begin to run..... pid=%ld\n", (long)getpid()); char pid_buf[PID_BUF_LEN] = {0}; snprintf(pid_buf, sizeof(pid_buf)-1, "%ld\n", (long)getpid()); // 把進程pid寫入到/var/run/myserver.pid文件 write(fd, pid_buf, strlen(pid_buf)); return 0; } int main(void) { //進程單實例運行檢測 if(0 != server_is_running()) { printf("myserver process is running!!!!! Current process will exit !\n"); return -1; } while(1) { printf("myserver doing ... \n"); sleep(2); } return 0; }
運行結果
運行程序,可知進程pid是6965
[root@lincoding singleprocess]# ./myserver server is not running! begin to run..... pid=6965 myserver doing ... myserver doing ... myserver doing ... myserver doing ... myserver doing ... myserver doing ... myserver doing ... myserver doing ...
/var/run/myserver.pid 也記錄此進程的pid號,ps auxf | grep myserver可知mysever進程一直運行著
[root@lincoding singleprocess]# cat /var/run/myserver.pid 6965 [root@lincoding singleprocess]# [root@lincoding singleprocess]# ps auxf | grep myserver root 6965 0.0 0.0 3924 460 pts/0 S+ 00:32 0:00 | \_ ./myserver root 9976 0.0 0.0 103256 856 pts/1 S+ 00:35 0:00 \_ grep myserver [root@lincoding singleprocess]#
此時,再運行myserver程序,這時會報錯退出,因為檢測到myserver程序已經在運行中,不可以起另外一個進程,從而達到了后臺服務程序單進程控制
[root@lincoding singleprocess]# ./myserver server is runing now! errno=11 myserver process is running!!!!! Current process will exit !
關于“Linux中C后臺服務程序單進程控制的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。