基础命令学习之ps 与 pkill 与 nohup 与 2>&1 &

查找文件的运行情况

bash 复制代码
ps aux |grep xxx

精准杀死程序

bash 复制代码
pkill -f "python check.py"

对于&来说,并不能保证它稳定在后台运行!

比如

bash 复制代码
# 后台运行ROS节点check.py,终端可继续操作
python check.py &  
# 输出示例:[1] 12345 ([1]是作业号,12345是PID)

# 查看后台运行的进程
jobs  # 列出当前终端的后台作业
# 输出示例:[1]+ Running                 python check.py &

# 将后台进程调回前台(替换作业号1)
fg 1  

# 终止后台进程(替换PID 12345)
kill 12345

如果关闭了终端,仍然是会关闭程序的。

所以怎么保证关闭了终端还能一直运行呢?通过nohup + &实现。

bash 复制代码
nohup python check.py &  # 即使关闭终端,check.py仍运行

&& ||

前一个是都执行,后一个是执行前一个,如果失败就执行后一个。

>

重定向

rosnode list > node.txt

把输出覆盖的给到node.txt

>>

追加式

rosnode list > node.txt

把输出追加的给到node.txt

2>&1

把正确或者错误的所有输出都进行输出。

结合> >>来存到文件中:

python check.py > node.txt 2>&1

注:无论是用>还是>>都只有程序结束之后才能看到输出信息。

那怎么能得到那种实时的效果呢?(原因是Python 输出缓冲:默认情况:Python 输出到文件时会启用「块缓冲」(攒够约 4KB 数据才写入文件),导致日志不会实时显示;)

加上-u的配置即可。

bash 复制代码
python -u check.py >> node.log 2>&1

终极命令:

cpp 复制代码
python -u check.py > check_$(date +%Y%m%d_%H%M%S).log 2>&1 &

tail -f xxx.log

这样就能一遍在后台运行,同时又可以随时打印log情况了

相关推荐
nhfc992 分钟前
Gitlab备份且提交Windows服务器数据
服务器·windows·gitlab
week_泽2 分钟前
第二个弱学习器的预测值由来解释说明
学习
wenyi_leo6 分钟前
强大的claude code
linux·运维·服务器
Rabbit_QL6 分钟前
【LLM原理学习】N-gram 语言模型实战教学指南(从原理到代码)
人工智能·学习·语言模型
嵌入小生0077 分钟前
数据结构基础内容 + 顺序表 + 单链表的学习---嵌入式入门---Linux
linux·数据结构·学习·算法·小白·嵌入式软件
宇钶宇夕8 分钟前
CoDeSys入门实战一起学习(二十六):功能块(FBD)运算块与EN/ENO指令精讲及计数控制案例
运维·学习·自动化·软件工程
xhbaitxl10 分钟前
算法学习day30-贪心算法
学习·算法·贪心算法
2401_8582861110 分钟前
OS55.【Linux】System V消息队列的简单了解
linux·运维·服务器
zdIdealism11 分钟前
cnPuTTY CAC 0.83 Update 1—PuTTY CAC 0.83中文版本简单说明~~
linux·运维·服务器·ssh·putty·putty-cac
会算数的⑨11 分钟前
Spring AI Alibaba学习(一)—— RAG
java·人工智能·后端·学习·spring·saa