我在 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
與我交流,備註交流。另外能夠關注個人公衆號【全棧成長之路】