博客
关于我
进程列表、协程与后台
阅读量:593 次
发布时间:2019-03-11

本文共 1047 字,大约阅读时间需要 3 分钟。

Shell命令执行模式解析

命令列表

在shell环境中,用户可以通过命令列表一次性执行多个命令。命令列表的形式如下:

pwd ; ls ; cd /etc ; ls -l ; pwd

执行该命令会依次输出当前工作目录、列表文件夹内容、进入/etc目录并列出详细信息以及最终的当前工作目录。

注意:命令列表采用;分隔,命令执行顺序依次进行。

进程列表

为了生成一个子shell并执行一组命令,可以使用进程列表的方式。子shell的启动可以通过将命令列表包裹在圆括号()中实现:

(pwd ; ls ; cd /etc ; ls -l ; pwd)

在执行上述命令后,可以通过echo $BASH_SUBSHELL查询子shell的PID,通常会发现子shell是一个独立的进程。

后台模式

在shell中,后台模式可以将一组命令或单个命令放入后台执行。命令分组的方式如下:

pwd ; ls ; cd /etc ; ls -l ; pwd &

注意:使用&符号表示后台执行,只有最后一个命令会被放入后台。

后台进程示例

在将命令列表放入后台执行时,执行过程会输出后台作业号和PID。例如:

(pwd ; ls ; cd /etc ; ls -l ; pwd )

执行后会立即输出类似信息:

[1] 6734

随后,当子进程完成执行时,终端会显示完成状态,并输出最终结果。

后台作业管理

可以通过jobs命令查看所有后台进程,使用-l参数可以列出详细信息:

jobs -l

注意jobs命令会列出所有当前终端的后台作业。

子进程

在shell中,可以通过生成子进程的方式执行命令。子进程的方式与进程列表类似,但需要使用{}包裹命令:

coproc name { pwd ; ls }

子进程示例

通过上述命令可以看到子进程的PID。可以通过echo $name查看子进程的名字。

子进程终止

可以通过kill -s name终止子进程。例如:

coproc foo { sleep 10 }kill -s foo

注意:子进程的终止需要确保子进程已启动。

总结

通过以上方法,可以在shell环境中灵活管理命令的执行方式。无论是单一命令还是多个命令组,可以通过命令列表、进程列表或后台模式进行操作。通过合理使用jobscoproc命令,可以有效管理后台进程和子进程。

提示:使用jobs -l可以查看当前终端的后台作业,coproc命令适用于需要在子进程中执行命令且不影响当前终端会话的场景。

转载地址:http://yfatz.baihongyu.com/

你可能感兴趣的文章
Nginx用户认证
查看>>
Nginx的Rewrite正则表达式,匹配非某单词
查看>>
Nginx的使用总结(一)
查看>>
Nginx的可视化神器nginx-gui的下载配置和使用
查看>>
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>
nginx负载均衡的5种策略(转载)
查看>>
nginx负载均衡的五种算法
查看>>
Nginx运维与实战(二)-Https配置
查看>>
Nginx配置ssl实现https
查看>>
Nginx配置TCP代理指南
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>