守护进程

守护进程

先搞懂下面几个概念:

        守护进程是脱离于终端并且在后后台运行的进程。守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终端上显示并且进程也不会被任何终端所产生的终端信息所打断。

启动守护进程大部分是以服务的方式去启动它。
/etc/rc.d/init.d/目录下的shell脚本(我们也可以编写)去启动的。编写一个启动守护进程的脚本放在/etc/rc.d/init.d/目录下。

守护进程特点:
1,后台运行
2,与终端无关(摆脱终端的控制)
3,运行环境是独立的

session:会话

概念:从终端登录到结束退出的时候,称这个过程为一个会话(session)。在会话期里面所设置的,它的生命周期也就在会话期里面。
终端登录,建立一个会话,在会话期里面有一个SID,会话组长(权限很大),终端第一个被执行的程序为会话组长。(session)组长可以重新打开一个终端,(session)下还有进程组(第一个进程为进程组组长也是会话组组长)。

摆脱进程组:setsid()重新创建一个会话,自己称为会话组组长。

////////////////////////////////////////////////////////////////////////////////////////////代码实现////////////////////////////////////////////////////////////////////

//*****************************************守护进程********************************************************
//2013.10.16.
// 守护进程特点:
// 1:后台运行
// 2:与终端无关(摆脱终端的控制)
// 3:运行环境是独立的
// 启动守护进程大部分是以服务的方式去启动它。
// /etc/rc.d/init.d/目录下的shell脚本(我们也可以编写)去启动的。编写一个启动守护进程的脚本放在/etc/rc.d/init.d/目录下。
//*****************************************守护进程********************************************************
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include<signal.h>
#include<sys/param.h>
#include<sys/types.h>
#include <sys/stat.h>
void my_deamon()
{
 int pid ;//让进程到后台执行
 if (pid = fork())
 {
  exit(0);
 }
 else if (pid < 0)
 {
  perror("fork error!");
  exit(1);
 }
 setsid();    //摆脱原先终端的控制,称为session的组长,它的权限太大了,可以打开新的终端(这样就脱离轨道了)
       //不要让它做组长(要让它退出来)
 pid = fork();   //父进程是组长(退出),子进程不是session组长(保留)。摆脱终端控制
 if (pid = fork())
 {
  exit(2);
 }
 else if (pid < 0)
 {
  perror("fork error!");
  exit(3);
 }
 int i = 0;
 //关闭所有文件描述符:比如标准输入输出,(让程序更独立);不打扰别人和不被别人打扰
 for (i = 0; i < NOFILE; i++)
 {
  close(i);
 }
 //改变程序工作目录(程序所在的目录可能会被卸载掉,导致程序终止)
 chdir("/");    //把目录更改到根目录
 umask(0);    //重设文件掩码为0(让其它程序不能读写),使程序更独立
 return;
}

int main()
{
 my_deamon();
 while(1)
 {
  printf("Hello World!\n");
  sleep(1);
 }
 return 0;
}

 

 

【完美复现】面向配电网韧性提升的移动储能预布局与动态调度策略【IEEE33节点】(Matlab代码实现)内容概要:本文介绍了基于IEEE33节点的配电网韧性提升方法,重点研究了移动储能系统的预布局与动态调度策略。通过Matlab代码实现,提出了一种结合预配置和动态调度的两阶段优化模型,旨在应对电网故障或极端事件时快速恢复供电能力。文中采用了多种智能优化算法(如PSO、MPSO、TACPSO、SOA、GA等)进行对比分析,验证所提策略的有效性和优越性。研究不仅关注移动储能单元的初始部署位置,还深入探讨其在故障发生后的动态路径规划与电力支援过程,从而全面提升配电网的韧性水平。; 适合人群:具备电力系统基础知识和Matlab编程能力的研究生、科研人员及从事智能电网、能源系统优化等相关领域的工程技术人员。; 使用场景及目标:①用于科研复现,特别是IEEE顶刊或SCI一区论文中关于配电网韧性、应急电源调度的研究;②支撑电力系统在灾害或故障条件下的恢复力优化设计,提升实际电网应对突发事件的能力;③为移动储能系统在智能配电网中的应用提供理论依据和技术支持。; 阅读建议:建议读者结合提供的Matlab代码逐模块分析,重点关注目标函数建模、约束条件设置以及智能算法的实现细节。同时推荐参考文中提及的MPS预配置与动态调度上下两部分,系统掌握完整的技术路线,并可通过替换不同算法或测试系统进一步拓展研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值