当前位置: 首页 > news >正文

广东网站系统建设网站建设项目风险管理的主要内容

广东网站系统建设,网站建设项目风险管理的主要内容,原生小程序是什么,网站策划书案例展示前言 呵呵 最近帮朋友解决问题[2022.09.08] 需要启动一个 node 程序, 然后 需要一个 startUp.sh 脚本 然后 反手写了一个过去, 按道理 来说 应该是 后台启动了对应的 node 程序, 然后将 标准输出, 错误输出 输出到 logs/nohup.log 日志文件中, 然后基于 tail 命令 来查看 …前言 呵呵 最近帮朋友解决问题[2022.09.08]  需要启动一个 node 程序, 然后 需要一个 startUp.sh 脚本  然后 反手写了一个过去, 按道理 来说 应该是 后台启动了对应的 node 程序, 然后将 标准输出, 错误输出 输出到 logs/nohup.log 日志文件中, 然后基于 tail 命令 来查看 logs/nohup.log 的日志  但是 问题是 我中断了 tail 命令之后, startUp.sh 中启动的 node 程序 也被中断了??  按之前的经验, 这个 node 程序应该不会被中断才对, 但是 这个挺出乎我的意料的, 因此 当时记录了一个 todo  这里主要是 两个参照, 一个是 启动 node 程序, 另外一个是 启动一个普通的 java 程序, 然后 来作为对比  然后 这里来看一下, 当然 依然 还是存在很多 不明白的地方   以下 node 部分代码参考自 关于node.jsNodejs-进程在退出时挂起(Ctrl C) | 码农家园 测试用例 编写一个 node 程序 如下  console.log(PID: , process.pid);var http require(http); // HTTP server to keep the script up long enough http.createServer(function (req, res) {res.writeHead(200, {Content-Type: text/plain});res.end(Hello World\n); }).listen(1337, 127.0.0.1);console.log(Server running at http://127.0.0.1:1337/);新建一个 nodeStartUp.sh 如下 nohup node nodeProcess.js ./logs/nodeNohup.log 21 tail -f ./logs/nodeNohup.log 执行 nodeStartUp.sh 程序正常启动, 并打印 相关日志  master:11_singal2Parent jerry$ ./nodeStartUp.sh PID: 3612 Server running at http://127.0.0.1:1337/ 访问服务, 拿到正确的结果   问题复现效果如下  master:11_singal2Parent jerry$ ps -ef | grep node501 3612 3611 0 9:56PM ttys000 0:00.17 node nodeProcess.js501 3613 3611 0 9:56PM ttys000 0:00.00 tail -f ./logs/nodeNohup.log501 3635 515 0 9:59PM ttys001 0:00.00 grep node// 中断 tail -f 之后, 发现 node 进程也挂了 master:11_singal2Parent jerry$ ps -ef | grep node501 3638 515 0 9:59PM ttys001 0:00.00 grep node 参照的 java 程序 注册了各个 SignalHandler, 主要是因为 怀疑这个 node 进程的挂掉可能和进程之间的 信号机制 有关系  /*** Test07Signal2ParentProcess** author Jerry.X.He 970655147qq.com* version 1.0* date 2022-09-10 19:18*/ public class Test07Signal2ParentProcess {// Test07Signal2ParentProcesspublic static void main(String[] args) throws Exception {String lines HUP\n INT\n // QUIT\n // ILL\n TRAP\n ABRT\n EMT\n // FPE\n // KILL\n BUS\n // SEGV\n SYS\n PIPE\n ALRM\n TERM\n URG\n // STOP\n TSTP\n CONT\n CHLD\n TTIN\n TTOU\n IO\n XCPU\n XFSZ\n VTALRM\n PROF\n WINCH\n INFO\n // USR1\n USR2;for (String sigNo : lines.split(\n)) {Signal.handle(new Signal(sigNo), new SignalHandler() {Overridepublic void handle(Signal signal) {System.out.println(sigNo);}});}Signal.raise(new Signal(ALRM));Signal.raise(new Signal(INT));Thread.sleep(300 * 1000);}}模拟 nodeStartUp.sh 同样编写一个 startUp.sh  java -classpath /Users/jerry/IdeaProjects/HelloWorld/target/classes com.hx.test13.Test07Signal2ParentProcess ./logs/nohup.log 21 tail -f ./logs/nohup.log startUp.sh 启动程序之后, 输出如下  master:11_singal2Parent jerry$ ./startUp.sh ALRM 关于进程结构  node 进程的进程结构  491 1 0 9:51AM ?? 2:44.93 /Applications/Utilities/Terminal.app/Contents/MacOS/Terminal492 491 0 9:51AM ttys000 0:00.03 login -pf jerry// shell493 492 0 9:51AM ttys000 0:00.80 -bash// startUp.sh3651 493 0 10:01PM ttys000 0:00.00 -bash3652 3651 0 10:01PM ttys000 0:00.14 node nodeProcess.js3653 3651 0 10:01PM ttys000 0:00.00 tail -f ./logs/nodeNohup.log参照的 java 程序的进程结构  491 1 0 9:51AM ?? 2:52.94 /Applications/Utilities/Terminal.app/Contents/MacOS/Terminal527 491 0 9:52AM ttys002 0:00.02 login -pf jerry// shell528 527 0 9:52AM ttys002 0:00.19 -bash// startUp.sh 3708 528 0 10:07PM ttys002 0:00.00 -bash3709 3708 0 10:07PM ttys002 0:00.11 /usr/bin/java -classpath /Users/jerry/IdeaProjects/HelloWorld/target/classes com.hx.test13.Test07Signal2ParentProcess3710 3708 0 10:07PM ttys002 0:00.00 tail -f ./logs/nohup.log按正常情况来看, 因为 启动 node/java 程序是后台执行的  正产情况应该是 ctrl c 中止 tail -f 了之后, startUp.sh 脚本执行完成退出, 但是 node/java 程序还在才对, 但是 node 程序缺退出了, 而 java 程序没有退出   从 node 退出的现象来看, 像是 tail -f 的进程接收到了 ctrl c, 之后发送了信息到 node 进程, 或者 tail -f 进程接收到了 ctrl c, 之后发送了信息到 startUp.sh 进程, 然后 startUp.sh 进程再发送了信息到 node 进程, 来中止了 node 进程 ? 测试 node 进程 信号交互 是一种进程之间通信的方式, 这里也是我们 首先怀疑的交互方式  ctrl c 发送的是中断信号, 对应于信号变量 SIGINT  在 nodeProcess.js 最前面注册 中断信号的处理, ALRM 信号的处理, 主要是输出一下 中断信号处理的处理函数  process.on(SIGINT, function() {console.log(SIGINT);process.exit(); });process.on(SIGALRM, function() {console.log(Nice SIGINT-handler);var listeners process.listeners(SIGINT);console.log( lisetner size : listeners.length);for (var i 0; i listeners.length; i) {console.log(listeners[i].toString());}// process.exit(); });console.log(PID: , process.pid);var http require(http); // HTTP server to keep the script up long enough http.createServer(function (req, res) {res.writeHead(200, {Content-Type: text/plain});res.end(Hello World\ ); }).listen(1337, 127.0.0.1);console.log(Server running at http://127.0.0.1:1337/); 然后开始测试, 可以看到的是 ctrl c 的时候, 确实有程序向 node 进程发送了 SIGINT 的信号  但是是 哪一个进程呢?, 为什么要发送呢 ?, 对应于 参照的 java 进程又会是怎样的情况呢? ^Cmaster:11_singal2Parent jerry$ ./nodeStartUp.sh PID: 3799 Server running at http://127.0.0.1:1337/ ^Cmaster:11_singal2Parent jerry$ cat logs/nodeNohup.log PID: 3799 Server running at http://127.0.0.1:1337/ SIGINT master:11_singal2Parent jerry$ 测试 java 进程 使用 startUp.sh 启动, 并 ctrl c 中断 tail -f  可以发现 java 进程这边并没有收到 SIGINT 的信号  这是怎么回事??  master:11_singal2Parent jerry$ ./startUp.sh ALRM ^Cmaster:11_singal2Parent jerry$ cat logs/nohup.log ALRM向 java 进程发送信号, 其他的大部分信号均能够使用 代码注册的 handler 但是 SIGINT 似乎是不行  # cmd 中发送命令给 java 程序 master:11_singal2Parent jerry$ kill -20 3872 master:11_singal2Parent jerry$ kill -20 3872 master:11_singal2Parent jerry$ kill -28 3872 master:11_singal2Parent jerry$ kill -13 3872 master:11_singal2Parent jerry$ kill -22 3872 master:11_singal2Parent jerry$ kill -2 3872 master:11_singal2Parent jerry$ kill -2 3872 master:11_singal2Parent jerry$ kill -2 3872 master:11_singal2Parent jerry$ kill -2 3872# 日志文件中展示日志如下 master:11_singal2Parent jerry$ cat logs/nohup.log ALRM CHLD CHLD WINCH PIPE TTOU # 在 startUp.sh 中启动的 java 进程, 似乎对于 SIGINT 的处理有其他的转换, 没有走 handler, 但是也没有走默认的处理 在 idea 中输出如下  # cmd 中发送命令给 java 程序 master:11_singal2Parent jerry$ kill -20 3926 master:11_singal2Parent jerry$ kill -20 3926 master:11_singal2Parent jerry$ kill -28 3926 master:11_singal2Parent jerry$ kill -13 3926 master:11_singal2Parent jerry$ kill -22 3926 master:11_singal2Parent jerry$ kill -2 3926 master:11_singal2Parent jerry$ kill -2 3926 master:11_singal2Parent jerry$ kill -2 3926# idea 中显示的日志 ALRM CHLD CHLD WINCH PIPE TTOU INT INT INT# 当点击了 idea 的停止按钮, 发送了一个 SIGINT 给进程, idea 关闭了 jpda 客户端, 停止按钮变成了骷髅头 Disconnected from the target VM, address: 127.0.0.1:54296, transport: socket INT # 再次点击 idea 的停止按钮, 发送了一个 SIGKILL 给进程, 强制杀掉进程 Process finished with exit code 137 (interrupted by signal 9: SIGKILL) 假设我们去掉 java 程序中的 SIGINT 的手动注册的 handler, 使用系统默认的处理  在 cmd 中使用 startUp.sh 效果如下  # cmd 中发送命令给 java 程序 master:11_singal2Parent jerry$ kill -20 3897 master:11_singal2Parent jerry$ kill -20 3897 master:11_singal2Parent jerry$ kill -28 3897 master:11_singal2Parent jerry$ kill -13 3897 master:11_singal2Parent jerry$ kill -22 3897 master:11_singal2Parent jerry$ kill -2 3897 master:11_singal2Parent jerry$ kill -2 3897 master:11_singal2Parent jerry$ kill -2 3897# 日志文件中展示日志如下 master:11_singal2Parent jerry$ cat logs/nohup.log ALRM CHLD CHLD WINCH PIPE TTOU # 在 startUp.sh 中启动的 java 进程, 似乎对于 SIGINT 的处理有其他的转换, 没有走 handler, 但是也没有走默认的处理 在 idea 中输出如下  # cmd 中发送命令给 java 程序 master:11_singal2Parent jerry$ kill -20 3893 master:11_singal2Parent jerry$ kill -20 3893 master:11_singal2Parent jerry$ kill -28 3893 master:11_singal2Parent jerry$ kill -13 3893 master:11_singal2Parent jerry$ kill -22 3893 master:11_singal2Parent jerry$ kill -2 3893 master:11_singal2Parent jerry$ kill -2 3893 -bash: kill: (3893) - No such process# idea 中显示的日志 ALRM CHLD CHLD WINCH PIPE TTOU# 当点击了 idea 的停止按钮, 发送了一个 SIGINT 给进程, idea 关闭了目标进程, SIGINT 的默认处理是终止进程 Disconnected from the target VM, address: 127.0.0.1:53095, transport: socketProcess finished with exit code 130 (interrupted by signal 2: SIGINT)怎么解决 node 中这个问题? 很简单, 只需要注册一下 SIGINT 的自定义处理函数, 不要调用关闭进程的相关处理即可  process.on(SIGINT, function() {console.log(SIGINT); // process.exit(); });演示如下, 可以发现 ctrl c 之后, node 进程依然还在  master:11_singal2Parent jerry$ ps -ef | grep node501 3957 493 0 10:48PM ttys000 0:00.00 grep node master:11_singal2Parent jerry$ ./nodeStartUp.sh PID: 3959 Server running at http://127.0.0.1:1337/ ^Cmaster:11_singal2Parent jerry$ ps -ef | grep node501 3959 1 0 10:48PM ttys000 0:00.04 node nodeProcess.js501 3962 493 0 10:48PM ttys000 0:00.00 grep node master:11_singal2Parent jerry$ cat logs/nodeNohup.log PID: 3959 Server running at http://127.0.0.1:1337/ SIGINT master:11_singal2Parent jerry$ 遗留的问题? 呵呵 一些 还在知识盲区的问题  1. 但是是 哪一个进程呢 向 node进程 发送的 SIGINT ? 2. 这个进程 为什么要发送 SIGINT 到 node 进程呢 ? 3. java 程序这边通过 startUp.sh 启动, 进程到底收到 SIGINT 没有?  4. java 程序这边程序中注册的 SIGINT 的 handler 为什么没有生效?, 替换成了什么? 希望 后面能够解释的清楚以上的这些问题  参考  关于node.jsNodejs-进程在退出时挂起(Ctrl C) | 码农家园完
http://www.hkea.cn/news/14269146/

相关文章:

  • 绍兴市住房与城乡建设厅网站西宁做网站君博优选
  • 商城网站的主要模块网站图片的像素
  • 齐齐哈尔网站seo开发企业网站多少钱
  • 视频发布播放网站建设南宁网站优化公司哪家好
  • 如何用VS2017做网站wordpress网站360搜索收录
  • 电子商务是学什么seo平台是什么
  • 网站文件夹名石家庄新钥匙建站
  • 上海门户网站建设公司搜索引擎市场份额2023
  • 宣传网站建设的步骤网站建设新闻中心
  • 河北省建设厅官方网站做企业网站后期还需要费用吗
  • 一个新网站要怎么做seo营销云产品
  • 虚拟主机做网站展厅宣传片
  • 丹东建设工程信息网站羽毛球赛事
  • 如何自己建设淘宝网站首页wed网站开发是什么
  • 宁晋网站建设公司信息咨询公司注册要求
  • 吉林整站优化.net网站开发岗位
  • 如何建设网站学校网站建设内容设计
  • 成都网站优化方案重庆网站seo设计
  • 南平网站开发u钙网logo设计官网
  • 叫别人做网站要多久山西做杂粮的网站
  • 网站建设与推广策划书wordpress 热门文章调用
  • 如何在企业版社保网站做增员自助免费建站
  • 建设网站的appphp做直播类型的网站
  • 免费商城app邢台seo一站式
  • 广东卫视你会怎么做网站php网站制作报价
  • 免费网站建设培训广州个人网站备案要多久
  • 浙江建设继续教育网站WordPress网站动漫你在
  • 佛山网站建设wantsun甘肃谷歌seo
  • 新公司网站建设费用怎么入账怎么开店铺
  • 商业网站建设案例课程视屏下载青岛抖音seo