位置: 编程技术 - 正文

详解node中创建服务进程(node 创建文件夹)

编辑:rootadmin

推荐整理分享详解node中创建服务进程(node 创建文件夹),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node 创建文件,node 创建文件夹,node创建服务器的方式,node创建项目,创建nodejs项目的步骤,node *create,node *create,node创建接口,内容如对您有帮助,希望把文章链接给更多的朋友!

背景

在node工程部署中,常常涉及到三方:本地客户端、跳板机和服务器(集群)。在通过git触发gitlab hook脚本后,需要在跳板机中执行相应的ssh命令执行shell文件启动node服务器,这需要使用一个常用的命令setsid,这样当ssh命令执行完毕shell退出后,node服务器仍正常运行,此时node服务进程就是一个最典型的daemon进程(后台服务进程)。

那么,在node项目中,如何创建一个daemon进程呢?最简单的方式,其实就是采用类似上文中介绍的方式:

这样可以通过执行shell的方式实现daemon进程。不过本文的重点并不是介绍这种“命令行”的方式实现daemon进程,而且本文会详细讲述daemon进程的创建原理,且看下文。

目标

在当前业务中,之所以需要创建daemon进程就是为了保证中断创建该进程的父进程(ctrl+c)或者父进程执行完毕后并不影响daemon进程的执行。下文介绍两种实现方式,实现原理细节上有些出入。

下文中的所有讨论都是在linux环境下进行。

实现一

在linux系统中,父进程创建出子进程,此时父进程若退出,此时子进程则变为孤儿进程,其ppid变为1,即成为init进程的子进程。在node环境下,如果不针对子进程的stdio做一些特殊处理父进程其实不会真正退出,而是直到子进程执行完毕后再退出。之所以出现这种情况是由于node创建子进程时默认会通过pipe方式将子进程的输出导流到父进程的stream中(childProcess.stdout、childProcess.stderr),提供在父进程中输出子进程消息的能力。

因此,解决此种问题可给子进程的stdio重新赋值:

通过在parent.js中设置子进程的stdio为当前终端(其实继承了父进程的stdio),这样父进程在5s后退出,此时子进程的ppid变为1,s后子进程退出。

详解node中创建服务进程(node 创建文件夹)

上述实现只满足“父进程正常退出,子进程成为守护进程”的情况,一旦通过“ctrl+c”的方式终端父进程,子进程仍会退出,这还是与node底层实现有关。默认“ctrl+c”触发SIGINT信号,父进程接受信号后发送给子进程,如果子进程存在SIGINT侦听函数,则会执行该函数,否则执行exit系统调用子进程退出。因此,如果要让子进程在接收到SIGINT信号不退出,只需要不作处理即可:

以上实现,可以满足我们最初指定的目标:“父进程退出或者中断,子进程仍正常运行”。

实现二

node官方提供了创建daemon进程的相关API,如果不仔细阅读文档还真不容易发现该特性。在child_process模块中有个spawn函数,通过spawn可以执行shell命令及其相关选项,同时spawn提供了创建子进程的一些选项,其中“detached”选项则与我们的需求密切相关。

detached选项可以让node原生帮我们创建一个daemon进程,设置datached为true可以创建一个新的session和进程组,子进程的pid为新创建进程组的组pid,这与setsid起到相同的作用。此时的子进程已经和其父进程属于两个session,因此父进程的退出和中断信号不会传递给子进程,子进程不会接受到父进程的中断信号自然也不会退出。当父进程结束之后,子进程变为孤儿进程从而被init进程接收,ppid设置为1。

此时,c.js文件并未设置SIGINT事件侦听函数,在父进程中断后仍会正常运行,正是由于其和父进程分属于两个session。

在parent.js文件中设置了sp.unref()函数,目的是“避免父进程等待子进程退出”。那么为何会出现上述情况呢?这与node的事件循环有关,让父进程的事件循环排除对ChildProcess子进程对象的引用,可以使父进程单独退出。

总结

为什么上文介绍的两个方法都可以实现daemon进程呢?这还得回到系统层面进行分析。在linux系统创建一个daemon进程需要几个步骤:

1.父进程创建子进程,父进程退出,让子进程成为孤儿进程,ppid=1

2.通过setsid命令或函数在子进程中创建新的会话和进程组

3.设置当前目录

4.设置文件权限,并关闭父进程继承打开的fd

所谓会话和进程组,则是在linux多任务多用户下的概念。不同会话的进程无法通过通信,因此父子进程相隔离。而执行setsid命令则让子进程有了新的特性:

子进程脱离父进程所在的session控制,两者独立存在互不影响 子进程脱离父进程所在的进程组 子进程脱离原先的命令行终端,终端退出不影响子进程

下面再回顾方法一与方法二的区别,发现方法一其实并不是真正的daemon进程,只是通过侦听相关中断信号并设置nop函数(不执行默认的中断行为)保证子进程继续运行而已;而方法二则是标准的deamon进程创建方式,优先使用!

标签: node 创建文件夹

本文链接地址:https://www.jiuchutong.com/biancheng/379462.html 转载请保留说明!

上一篇:nodejs处理图片的中间件node-images详解(nodejs image)

下一篇:利用forever和pm2部署node.js项目过程

  • 递延所得税资产会计处理全过程
  • 进口货物增值税纳税人是谁
  • 房产契税是怎样计算的
  • 增值税税负率是含税还是不含税
  • 减免税额和抵免的区别
  • 减免税控盘增值税纳税申报
  • 运输公司支付的运输费计入什么科目
  • 体检怎么写公司抬头
  • 给员工购买意外险进项税能不能抵扣
  • 现金折扣为什么计入主营业务收入
  • 小企业营业外支出
  • 企业基本保险
  • 工会筹备金税率
  • 企业自建房转让如何交土地增值税
  • 发票红冲钱怎么退给对方
  • 报价表含税点是什么意思?
  • 以公允价值模式后续计量的投资性房地产无须计提减值
  • 待转销项税额结转分录
  • 职工教育经费列支范围及标准
  • 个人承包劳务合法吗?
  • 退休职员工伤补助金放哪个科目?
  • windows登录提示
  • macos dock栏
  • 小规模纳税人增值税3%减按1%
  • 利润分配属于什么科目
  • 电脑管家lol修复
  • php存储过程是什么
  • 自产产品用于业务招待,成本10万,售价20万
  • 业务招待费汇算清缴扣除标准
  • 给外部人员发奖状怎么说
  • 免抵退税会计分录怎么写
  • echarts引入地图
  • 阿尔卑斯山城市
  • php浮点数
  • 机票报账行程单怎么打印
  • 大前端需要掌握什么技能
  • 小规模企业做账表格
  • 财税2016年12号文件解读
  • 存货盘亏的账务处理进项税额转出
  • vant weapp官方文档
  • 超市电子发票怎么开
  • 公司对其他公司的投资怎么做账
  • 股权转让实缴资本4000万如何缴纳
  • 非限定性净资产和限定性净资产的区别
  • 合同印花税怎么做会计分录
  • 中小企业投标费怎么算
  • 航天信息的发票以什么形式导入开票信息
  • 计提医疗保险费的会计分录
  • 开出银行承兑汇票
  • 企业取得的跨期业务
  • 赠送产品会计分录怎么写
  • 支付技术转让费所得税处理
  • 现金折扣和商业折扣怎么确定收入
  • 个别会计报表和合并会计报表
  • mysql 5.1.6
  • centos7.0镜像下载
  • 如何安装vmware10
  • android-x86安装
  • win10系统家庭组如何关闭家庭组访问用户名密码
  • windows8.1crazy error
  • 设置cmd命令
  • perl计算时间差
  • 如何创建node项目
  • 简述图像批处理的操作过程
  • 不通过肾门的结构都有什么
  • python网络爬虫程序
  • jquery$符号
  • rsa 密钥格式
  • jquery代码实例
  • 安卓如何实现图片上传功能
  • javascript学习指南
  • python消息队列感知消息被消费
  • php jquery教程
  • 重庆市电子发票样式
  • 怎么查询企业的联系方式
  • 收到虚开增值税专用发票怎么处理
  • 经信委和科技局的区别
  • 出口退税备案表享受增值税优惠政策
  • 企业应交个人所得税分录
  • 消费税,资源税,城市建设维护税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设