Linux命令
开启守护进程
一般后端服务,都是开启守护进程,其命令类似如下
ps aux | grep start.sh | grep -v "grep --color=auto start.sh" | awk '{print $2}' | xargs kill -9 || echo ok > log nohup start.sh &> log &
后台进程和守护进程的区别?
最大的区别有几点:
- 守护进程已经完全脱离终端控制台了,而后台程序并未完全脱离终端;
- 守护进程在关闭终端控制台时不会受影响,而后台程序会随用户退出而停止,需要在以nohup command & 格式运行才能避免影响;
- 守护进程的会话组和当前目录,文件描述符都是独立的。后台运行只是终端进行了一次 fork,让程序在后台执行。
下面的命令是用 awk 提取进程 ID
ps -aux|grep chat.js| grep -v grep | awk '{print $2}'
查看到进程 id 之后,使用 netstat 命令查看其占用的端口
netstat -nap|grep 7779
三大利器 GREP,SED,AWK
Linux 三大利器 grep,sed,awk,熟练掌握其中常见的用法,开发效率杠杠滴。
grep 匹配二进制文件
grep 如果碰到 \000 NUL 字符,就会认为文件是二进制文件,而 grep 匹配默认忽略二进制数据。
使用 grep -a 属性:不忽略二进制的数据。grep 的 -a 或 --text 参数功能:将 binary 文件以 text 文件的方式搜寻数据。
grep -a file_name
或
grep --text file_name
grep 匹配或排除多个关键字
grep -E "word1|word2|word3" file.txt #满足任意条件(word1、word2和word3之一)将匹配。
grep word1 file.txt | grep word2 |grep word3
#必须同时满足三个条件(word1、word2和word3)才匹配。
grep -v 'abc\|efg' log.txt #排除 log.txt 中的 abc efg 关键字
awk /sed 分割或去重
使用 tab 键分割文件
awk 'BEGIN{IFS='\t'}{print $1}' a.log
按分隔符去重以某列重复的行
cat ios_gupai_only_new.txt | awk -F '|' '!a[$1]++{print}' > ios_gupai_one.txt
sed 文件首尾添加引号
sed -i 's/^/"/;s/$/"/' log.txt
sed 文件尾添加逗号
Sed -i 's/$/,/' txt
输入相似文件名太麻烦
用花括号括起来的字符串用逗号连接,可以自动扩展,非常有用,直接看例子:
$ echo {one,two,three}file onefile twofile threefile $ echo {one,two,three}{1,2,3} one1 one2 one3 two1 two2 two3 three1 three2 three3
花括号中的每个字符都可以和之后(或之前)的字符串进行组合拼接,注意花括号和其中的逗号不可以用空格分隔,否则会被认为是普通的字符串对待。
这个技巧有什么实际用处呢?最简单实用的就是给 cp,mv,rm 等命令扩展参数:
$ cp /search/code/file{,.bak} # 给 file 复制一个叫做 file.bak 的副本 $ rm file{1,3,5}.txt # 删除 file1.txt file3.txt file5.txt $ mv *.{c,cpp} src/ # 将所有 .c 和 .cpp 为后缀的文件移入 src 文件夹
输入路径名称太麻烦
用 cd - 返回刚才的目录,直接看例子吧:
$ pwd /search/code/moyu $ cd # 回到家目录瞅瞅 $ pwd /home/herongwei $ cd - # 再返回刚才那个目录 $ pwd /search/code/moyu
特殊命令 !$ 会替换成上一次命令最后的路径,直接看例子:
没有加可执行权限
$ /usr/bin/script.sh zsh: permission denied: /usr/bin/script.sh $ chmod +x !$ chmod +x /usr/bin/script.sh
特殊命令 !* 会替换成上一次命令输入的所有文件路径,直接看例子:
创建了三个脚本文件
$ touch script1.sh script2.sh script3.sh
给它们全部加上可执行权限
$ chmod +x !*
chmod +x script1.sh script2.sh script3.sh
输入重复命令太麻烦
使用特殊命令!!,可以自动替换成上一次使用的命令:
[@root]# yum install python E: Could not open lock file - open (13: Permission denied) [@root]# !! yum install python
有的命令很长,一时间想不起来具体参数了怎么办?
对于 bash 终端,可以使用 Ctrl+R 快捷键反向搜索历史命令,之所以说是反向搜索,就是搜索最近一次输入的命令。
比如按下 Ctrl+R 之后,输入 cp,bash 就会搜索出最近一次包含 cp 的命令,你回车之后就可以运行该命令了:
(reverse-i-search)`': cp config/app_search_rule.json{,.bak}
但是这个方法有缺点:该功能似乎只有 bash 支持,而 zsh 作为 shell 终端,就用不了;
第二,只能查找出一个(最近的)命令,如果我想找以前的某个命令,就没办法了。
对于这种情况,常用的方法是使用 history 命令配合管道符和 grep 命令来寻找某个历史命令比如:
过滤出所有包含 yum 字段的历史命令
[@root]# history | grep 'yum' 334 2021-08-30 14:36:27 yum install devtoolset-3-gcc.x86_64 devtoolset-3-gcc-c++.x86_64 336 2021-08-30 14:44:31 yum list | grep rdkafka 337 2021-08-30 14:44:57 yum list | grep kafka 435 2021-08-31 15:50:22 yum list | grep sasl2 778 2021-09-16 16:40:55 yum install -y libffi-devel 849 2021-09-16 16:56:49 yum install pip3
一行代码验证 JSON 格式是否正确
cat a.json | python -m json.tool | wc -l
原理
- 要验证的文件 a.json
- 如果返回结果一行数字,则表示 a.json 文件格式正确
- 否则返回 a.json 文件中错误的行号及错误信息
一旦 JSON 文件格式不对,或者文件内容缺失或者其他问题,就会导致 python -m 命令无法格式化,正是利用这一点,我们可以做一个 JSON 的验证。
比如说你在线修改了一个 JSON 数据,但是又不能粘贴出来查看是否修改正确了,直接执行这个命令比较方便,或者也可以用 VIM 命令的 % 命令来匹配中括号和大括号。
删除 0 字节文件或垃圾文件
find . -type f -size 0 -delete find . -type f -exec rm -rf {} \; find . -type f -name "a.out" -exec rm -rf {} \; find . type f -name "a.out" -delete find . type f -name "*.txt" -print0 | xargs -0 rm -f
自动分割大文件为多个小文件
使用 split 命令,比如:
split -l 10000 -d -a 3 nameall.txt name
将 nameall.txt 文件按照 10000 行分割成前缀 name+数字三位的小文件。
MySQL 终端显示格式化
在 SQL 语句最后加上一个 \G , 比较推荐这个用法,把行转化成列显示。

浙公网安备 33010602011771号