運維工程師經常要做如下固定的命令操作已完成某個任務:
1. 頻繁登陸各種服務器,并且是同時發生
2. 頻繁使用相同的命令進入某個目錄,或者執行某個程序
3. 對比兩個文件的差異或者對比日志輸出
4. 拷貝文件到各種服務器上執行
鑒于以上需求,參考同事的經驗,我搭建了如下的工作環境。
1. 選擇一個管理宿主機作為自己的工作機器,該機器一般用不關機,并且有良好網絡連接質量。
2. 在該宿主機上要運行 tmux 程序,這樣可以保留任何工作會話,同時可以分屏做對比。
3. 因為要頻繁登陸各種服務器,而且各種服務器環境有可能不一樣,在宿主機上的命令不一定能在其他服務器上運行,這個其實可以通過使用 .bash_profile & .bashrc 文件來實現,因為每次ssh登陸bash都會重新加載.bash_profile 文件。 同時需要在登陸時同步 .bash_profile 文件到目標服務器上,這樣就需要重新定制一個登陸腳本(假設命名為go, 放在自己家目錄 $HOME/bin 下),同時把? $HOME/bin 作為自己環境變量的 $PATH 的第一個值,這樣想登陸一臺服務器直接執行? go $hostname 就可以了。? 關于 go 和 .bash_profile 的腳本源碼,參見附錄。
4. 某些產品可能需要制定一個管理機器,然后所有的生產機都root信任這臺管理機,這就產生了一個需求,我們需要從宿主機登陸到這個管理機去做生產工作,由于在這臺管理機我們不能再運行一個 tmux(否則,兩個tmux會產生熱鍵沖突),我們只能該用 screen,另一個類似的多任務管理軟件。這樣所有的工作都是運行在? 宿主機tmux 里,如果需要登陸管理機,就通過 screen 運行任何工作任務。
這里分別對tmux 和 screen 都要有相應的自定義配置,才能使他們兩和諧共處。
.tmux.conf
`
set-option -g prefix C-a
unbind-key C-b
bind-key C-a send-prefix
set -g mode-mouse on
set -g mouse-resize-pane on
set -g mouse-select-pane on
set -g mouse-select-window on
unbind r
bind r source-file ~/.tmux.conf
bind a send-prefix
unbind ^A
bind ^A select-pane -t :.+
`
.screenrc :
`
[adm1001.rm.corp.sp1 ~]$ cat .screenrc
startup_message off
escape ^Zz??????? ### ctrl+Z? and z
hardstatus alwayslastline '%{= G}[ %{G}%H %{g}][%= %{= w}%?%-Lw%?%{= R}%n*%f %t%?%{= R}(%u)%?%{= w}%+Lw%?%= %{= g}][ %{y}Load: %l %{g}][%{B}%Y-%m-%d %{W}%c:%s %{g}]'
`
5. 當你用tmux 或者 screen 新建很多窗口時,你再由各個窗口去登陸其他服務器,其實你只需要在當中的一臺服務器啟動 ssh-agent bash 和 ssh-add ,然后該窗口就會自動生成兩個環境變量:
SSH_AGENT_PID=3636
SSH_AUTH_SOCK=/tmp/ssh-SxEGBQ3635/agent.3635
然后在其他窗口的shell會話里只要export 這兩個同樣的變量便可以共享這個 agent里的 key ,從而達到每個窗口都可以自動登陸服務器。一般做法是把上面的環境變量寫入? .bashrc 文件, 然后在 .bash_profile 里添加如果發現 .bashrc 文件自動執行。這樣每次新建窗口時,.bash_profile 都會被執行一次,這兩個環境變量就會被輸出來了。
[adm1001 ~]$ cat .bashrc
export SSH_AGENT_PID=3636
export SSH_AUTH_SOCK=/tmp/ssh-SxEGBQ3635/agent.3635
[adm1001 ~]$ tail .bash_profile
if [ -z $1 ]; then
echo -n -e "\033k`hostname|sed 's/.yahoo.com//'`\033\\";
else
echo -n -e "\033k$1\033\\";
fi
[ -x ~/.bashrc ] && . ~/.bashrc