我在 github 上新建了一个仓库 日问,天天一道面试题,有关前端,后端,devops以及软技能,促进职业成长,敲开大厂之门,欢迎交流html
而且记录个人面试经验前端
<blockquote> 更多描述: 在编写脚本时,有时会出现内存过大发生 OOM 的事情,那咱们如何得知某个进程的内存?另外又如何监控它 </blockquote>node
在 Issue 中交流与讨论: Issue 地址
经过 ps
能够获知一个进程所占用的内存linux
$ ps -O rss -p 3506 PID RSS S TTY TIME COMMAND 3506 6984 S pts/1 00:00:00 vim
若是要监控内存,确定使用对进程万能的命令 pidstat
(PS: 这名字一听就知道是干吗的)git
## -r 显示内存信息 ## -p 指定 pid ## 1: 每一个一秒打印一次 $ pidstat -r -p 3506 1 Linux 3.10.0-957.21.3.el7.x86_64 (shanyue) 11/04/19 _x86_64_ (2 CPU) 20:47:35 UID PID minflt/s majflt/s VSZ RSS %MEM Command 20:47:36 0 3506 0.00 0.00 139940 6984 0.18 vim 20:47:37 0 3506 0.00 0.00 139940 6984 0.18 vim 20:47:38 0 3506 0.00 0.00 139940 6984 0.18 vim 20:47:39 0 3506 0.00 0.00 139940 6984 0.18 vim 20:47:40 0 3506 0.00 0.00 139940 6984 0.18 vim 20:47:41 0 3506 0.00 0.00 139940 6984 0.18 vim
固然,也可使用万能的 htop
命令github
参考: linux 各项监控指标小记面试
在 Issue 中交流与讨论: Issue 地址
$ who $ last
在 Issue 中交流与讨论: Issue 地址
ifconfig
是最简单最经常使用,可是打印信息太多了docker
$ ifconfig cni0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1450 inet 10.244.0.1 netmask 255.255.255.0 broadcast 0.0.0.0 ether 9e:f3:9e:47:9d:55 txqueuelen 1000 (Ethernet) RX packets 14733665 bytes 1007493238 (960.8 MiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 15040396 bytes 4534954611 (4.2 GiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 docker0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500 inet 172.18.0.1 netmask 255.255.0.0 broadcast 172.18.255.255 ether 02:42:09:fe:1d:e5 txqueuelen 0 (Ethernet) RX packets 0 bytes 0 (0.0 B) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 0 bytes 0 (0.0 B) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
netstat
与 ip
也挺好用,特别是它们还能够打印路由表shell
$ netstat -i Kernel Interface table Iface MTU RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flg cni0 1450 14733471 0 0 0 15040202 0 0 0 BMRU docker0 1500 0 0 0 0 0 0 0 0 BMU eth0 1500 42833038 0 0 0 40961577 0 0 0 BMRU flannel.1 1450 4761436 0 0 0 4091581 0 0 0 BMRU lo 65536 376447249 0 0 0 376447249 0 0 0 LRU veth2052e2d6 1450 7358995 0 0 0 7518642 0 0 0 BMRU veth3190806e 1450 7363232 0 0 0 7510100 0 0 0 BMRU
$ ip link $ ip addr
在 Issue 中交流与讨论: Issue 地址
$ printenv XDG_SESSION_ID=10536 HOSTNAME=shanyue TERM=xterm-256color SHELL=/bin/bash HISTSIZE=1000 SSH_CLIENT=124.200.184.74 16003 22 SSH_TTY=/dev/pts/0
在 Issue 中交流与讨论: Issue 地址
使用 sed
或者 head
/tail
,以要输出第100行为例vim
sed -n 100p Readme.md head -100 Readme.md | tail -1
关于 sed
更多的用法能够参考个人文章: sed 命令详解及示例
在 Issue 中交流与讨论: Issue 地址
天天十点,每分钟都会执行一次
在 Issue 中交流与讨论: Issue 地址
天天十点半执行一次
在 Issue 中交流与讨论: Issue 地址
在 centos
中,查看日志文件
$ tail -f /var/log/cron Dec 5 19:30:01 8 CROND[24068]: (root) CMD (echo hello, world) Dec 5 19:31:01 8 CROND[24084]: (root) CMD (echo hello, world) Dec 5 19:31:01 8 CROND[24083]: (root) CMD (echo hello) Dec 5 19:32:01 8 CROND[24094]: (root) CMD (echo hello, world) Dec 5 19:32:01 8 CROND[24093]: (root) CMD (echo hello) Dec 5 19:33:01 8 CROND[24104]: (root) CMD (echo hello, world) Dec 5 19:33:01 8 CROND[24103]: (root) CMD (echo hello) Dec 5 19:34:01 8 CROND[24113]: (root) CMD (echo hello) Dec 5 19:34:01 8 CROND[24114]: (root) CMD (echo hello, world)
在 Issue 中交流与讨论: Issue 地址
可使用 ls
或者 stat
$ stat hello.txt File: ‘hello.txt’ Size: 30 Blocks: 8 IO Block: 4096 regular file Device: fd01h/64769d Inode: 917526 Links: 1 Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root) Access: 2019-12-10 16:15:55.253325208 +0800 Modify: 2019-12-10 16:15:52.740653330 +0800 Change: 2019-12-10 16:15:52.742653069 +0800 $ ls -i hello.txt 917526 hello.txt
在 Issue 中交流与讨论: Issue 地址
在 linux
中,
mtime
:modified time
指文件内容改变的时间戳ctime
:change time
指文件属性改变的时间戳,属性包括 mtime
。而在 windows 上,它表示的是 creation time
因此 ctime
会比 mtime
要大一些,使用 stat
查看文件属性以下
$ stat hello.txt File: ‘hello.txt’ Size: 30 Blocks: 8 IO Block: 4096 regular file Device: fd01h/64769d Inode: 917526 Links: 1 Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root) Access: 2019-12-10 16:15:55.253325208 +0800 Modify: 2019-12-10 16:15:52.740653330 +0800 Change: 2019-12-10 16:15:52.742653069 +0800 Birth: -
而 http 服务选择 Last_Modified
时通常会选择 mtime
在 Issue 中交流与讨论: Issue 地址
${}
变量$()
命令在 Issue 中交流与讨论: Issue 地址
使用 nc
,-z
指测试接口连通性
nc -vz localhost 443
我是山月,能够加我微信
shanyue94
与我交流,备注交流。另外能够关注个人公众号【全栈成长之路】