工作中經常會遇到,在執行一個腳本時后,覺得有些地方要補充,而這個腳本又已經運行了一段時間,如果從頭再來很浪費時間,這時如果能修改這個運行中的腳本就方便多了。
如:
cat test.sh
#!/bin/bash
echo 1111
sleep 60
echo 2222
當開始運行后,如果想修改第二個echo的輸出值,怎么辦?
直接打開test.sh修改肯定是不行的,這就好比,一個運行中的腳本,你把文件刪除了之前,腳本依然可以運行下去一樣。這是因為,此時的腳本已經放在了內存里。所以要想修改腳本只能去內存里修改。linux很方便的可以看到內存里的文件(/proc目錄下)。
通過:
[root@en tmp]# ps aux |grep test.sh
root 27887 0.0 0.4 4492 1100 pts/0 S 10:20 0:00 sh test.sh
找到進程的pid,然后查看pid所對應的文件描述符:
[root@en tmp]# cd /proc/27887/fd
[root@en fd]# ll
total 0
lrwx------ 1 root root 64 May 8 10:21 0 -> /dev/pts/0
lrwx------ 1 root root 64 May 8 10:21 1 -> /dev/pts/0
lrwx------ 1 root root 64 May 8 10:20 2 -> /dev/pts/0
lr-x------ 1 root root 64 May 8 10:21 255 -> /var/tmp/test.sh
這里的255對應的文件就是我們的腳本,在這里直接編輯255這個文件
[root@en fd]# vi 255
#!/bin/bash
echo 111111
sleep 60
echo 333333
修改后保存退出,此時就會執行修改后的腳本了。
要注意一點,如果是直接修改原腳本文件會出現什么結果呢?
當改完后,再看fd下的文件,會發現:
[root@en fd]# ll
total 0
lrwx------ 1 root root 64 May 8 10:27 0 -> /dev/pts/0
lrwx------ 1 root root 64 May 8 10:27 1 -> /dev/pts/0
lrwx------ 1 root root 64 May 8 10:27 2 -> /dev/pts/0
lr-x------ 1 root root 64 May 8 10:27 255 -> /var/tmp/test.sh~ (deleted)
被標記了已經刪除,系統會認為原來的腳本文件已經找不到了,所有修改后是不會執行的。
如果是一個for循環就不會生效了,如:
for i in 1 2 3 4;do
echo $i
sleep 60
done
類似這樣的腳本,執行中要加一些元素到循環中是做不到的,如想修改為:
for i in 1 2 3 4 5 6 7;do
echo $i
sleep 60
done