我在 github 上新建了一个仓库 日问,天天一道面试题,有关前端,后端,devops以及软技能,促进职业成长,敲开大厂之门,欢迎交流html
更多描述: 在编写脚本时,有时会出现内存过大发生 OOM 的事情,那咱们如何得知某个进程的内存?另外又如何监控它
在 Issue 中交流与讨论: Issue 地址前端
经过 ps
能够获知一个进程所占用的内存node
$ ps -O rss -p 3506
PID RSS S TTY TIME COMMAND
3506 6984 S pts/1 00:00:00 vim
复制代码
若是要监控内存,确定使用对进程万能的命令 pidstat
(PS: 这名字一听就知道是干吗的)linux
## -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
命令git
参考: linux 各项监控指标小记github
在 Issue 中交流与讨论: Issue 地址面试
$ who
$ last
复制代码
在 Issue 中交流与讨论: Issue 地址docker
ifconfig
是最简单最经常使用,可是打印信息太多了shell
$ 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
也挺好用,特别是它们还能够打印路由表vim
$ 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行为例
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
与我交流,备注交流。另外能够关注个人公众号【全栈成长之路】