进程组
进程的组长:
组里边的第一进程
进程组的ID==进程中的组长的ID
进程中组长的选择:
进程中的第一个进程
进程组ID的设定:
进程组的ID就是组长的进程ID
用fork函数创建父子进程,父子进程属于同一进程组,父进程为进程组的组长。
会话
创建一个会话注意事项:
不能是进程组长,
创建会话的进程成为新进程组的组长
有些lInux版本需要root权限执行此操作
创建出的新会话会丢弃原有的控制终端
一般步骤;fork ,父亲死,儿子执行创建会话操作(setid)
获取进程所属的会话ID
pid_t getsid(pid_t pid);
创建一个会话
pid_t setsid(void);
如果调用此函数的进程不是一个进程组的组长进程,那么将会发生以下三件事:
该进程成为新会话的首进程(创建会话的进程)
该进程成为一个新进程组的组长进程
新会话丢弃原有控制终端,该进程没有控制终端
后台进程和守护进程的区别
守护进程:在后台运行不会在终端显示任何东西,自动周期性维护,执行你写的事件。
后台进程:没有完全脱离终端,依赖终端运行,终端结束就死了,后台程序会随用户退出而停止。
创建守护进程
代码:
shprocess.c
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
pid_t pid;
pid=fork();
int fd;
int x;
if(pid < 0)
{
printf("fork failure\n");
return -1;
}
else if(pid > 0)
{
exit(0);
}
else
{
pid=fork();
if(pid >0)
{
exit(1);
}
else
{
setsid();
chdir("/");
umask(0);
for(fd=0;fd<65535;fd++)
{
close(fd);
}
fd=open("/lzg/process/f.c",O_RDWR|O_CREAT);
dup2(fd,STDOUT_FILENO);
if(x==-1)
{
execlp("ps","ps","aux",NULL);
}
}
}
while(1)
{
printf("this is shouhu progress\n");
sleep(1);
}
return 0;
}
执行结果: