python實現tail實時檢視伺服器日誌示例
阿新 • • 發佈:2020-01-09
我就廢話不多說了,直接上程式碼吧!
import paramiko from paramiko_expect import SSHClientInteraction host = your host port = your port username = your un # 自行修改輸出函式 json_list = [] def output_func(msg): sys.stdout.write(msg) json_list.append(msg) sys.stdout.flush() def conn_tail(path): try: client = paramiko.SSHClient() client.set_missing_host_key_policy(paramiko.AutoAddPolicy) key_file = 'id_rsa_2048' key = paramiko.RSAKey.from_private_key_file(key_file,'yourpwd') client.connect(host,port,username,key_filename=key_file) interact = SSHClientInteraction(client,timeout=10,display=False) interact.send('sudo su\n') interact.expect(prompt) interact.send('tail -f %s' % path) # log_name = path.split('/')[-1].split('.')[0] # interact.tail(line_prefix=log_name + ': ',output_callback=output_func) interact.tail( output_callback=output_func)
1.使用了paramiko_expect模組,安裝方式
# from pypi pip install paramiko-expect # from source pip install git+https://github.com/fgimian/paramiko-expect.git
2.採用id_rsa金鑰方式登入
3.由於公司伺服器需要切換賬號,所以需要先執行sudo xxx操作
4.如果需要同時tail幾個日誌,可以開多執行緒
5.如果需要自己對伺服器的日誌進行處理,而非簡單的控制檯展示,則需要自行修改output_callback函式
以上這篇python實現tail實時檢視伺服器日誌示例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。