创建一个会话:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
int main(){
pid_t pid;
if((pid=fork())<0){
perror("fork error");
exit(1);
}else if(pid==0){
printf("child process PID IS %d\n",getpid());
printf("Group ID of child %d\n",getpgid(0));
printf("Session ID of child is %d\n",getsid(0));
sleep(10);
setsid();//子进程非组长进程, 成为新会话首进程,且成新会话组长进程,会长
printf("changed:\n");
printf("child process PID IS %d\n",getpid());
printf("Group ID of child %d\n",getpgid(0));
printf("Session ID of child is %d\n",getsid(0));
sleep(20);
}
return 0;
}
输出:
[dev@192 session]$ child process PID IS 10720
Group ID of child 10719
Session ID of child is 3540
changed:
child process PID IS 10720
Group ID of child 10720
Session ID of child is 10720
守护进程:
daemon(精灵进程,是linux中的后台服务进程, 通常运行于操作系统后台,脱离控制终端。一般不与用户直接交互。周期性的等待某个事件发生或周期性执行某一动作。
不受用户登录注销影响。通常采用 d 结尾的命名方式。
守护进程创建步骤:
1.fork子进程,让父进程终止(所有工作在子进程中进行形式上脱离了控制终端)
2.子进程调用 setsid()创建新会话 (使子进程完全独立出来,脱离终端控制)
3.通常根据需要,改变工作目录位置 chdir() (防止占用可卸载的文件系统)
4.通常根据需要,重设 umask 文件权限掩码 (防止继承的文件创建屏蔽字拒绝某些权限 增加守护进程灵活性)
5.通常根据需要,关闭/重定向 文件描述符
6. 守护进程 业务逻辑 while()
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
#include<fcntl.h>
#include<sys/stat.h>
void sys_err(const char* str){
perror(str);
exit(1);
}
int main(){
pid_t pid;
int ret;
pid =fork();
if(pid>0){
exit(0);
}
pid = setsid();//创建新会话
if(pid==-1){
sys_err("setsid error");
}
ret=chdir("/home/dev/workspaceblack/");//改变工作目录位置
if(ret==-1){
sys_err("chdir error");
}
umask(0022);//改变文件访问权限掩码
close(STDIN_FILENO);//关闭文件描述符0
int fd = open("/dev/null",O_RDWR);// fd--》0
dup2(fd,STDOUT_FILENO);//重定向
dup2(fd,STDERR_FILENO);
while(1);//模拟守护进程业务
return 0;
}