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