運(yùn)維開發(fā):pythonwebsocket網(wǎng)頁實(shí)時顯示遠(yuǎn)程服務(wù)器日志信息_第1頁
運(yùn)維開發(fā):pythonwebsocket網(wǎng)頁實(shí)時顯示遠(yuǎn)程服務(wù)器日志信息_第2頁
運(yùn)維開發(fā):pythonwebsocket網(wǎng)頁實(shí)時顯示遠(yuǎn)程服務(wù)器日志信息_第3頁
運(yùn)維開發(fā):pythonwebsocket網(wǎng)頁實(shí)時顯示遠(yuǎn)程服務(wù)器日志信息_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

運(yùn)維開發(fā):pythonwebsocket?頁實(shí)時顯?遠(yuǎn)程服務(wù)器?志信息功能:?websocket技術(shù),在運(yùn)維?具的瀏覽器上實(shí)時顯?遠(yuǎn)程服務(wù)器上的?志信息?般我們在運(yùn)維?具部署環(huán)境的時候,需要實(shí)時展現(xiàn)部署過程中的信息,或者在瀏覽器中實(shí)時顯?程序?志給開發(fā)?員看。你還在?ajax每隔段時間去獲取服務(wù)器?志?out了,試試?websocket?式吧我?bottle框架,寫了個websocket服務(wù)端,瀏覽器連接到websocketserver,再?pythonsubprocess息,subprocess,就是?Popen調(diào)?shell的shell命令?已,這樣可以獲取到實(shí)時的?志了,然后再send到websocketserverwebsocketserver獲取遠(yuǎn)程服務(wù)器的?志信中,那連接到的瀏覽器,就會實(shí)時展現(xiàn)出來了??臺服務(wù)器來實(shí)現(xiàn)這個場景,A服務(wù)器是websocket服務(wù)端,B服務(wù)器是?志端A服務(wù)器是我瀏覽器本機(jī),websocket服務(wù)端也是這臺機(jī),IP是:21B服務(wù)器是要遠(yuǎn)程查看?志的服務(wù)器,我這??:0以下是A服務(wù)器的websocketserve的python代碼:1.#!/usr/bin/envpython2.#coding=utf-83.#__author__戴儒鋒'='4.#5.6."""7.執(zhí)?代碼前需要安裝8.pipinstallbottle9.pipinstallwebsocket-client10.pipinstallbottle-websocket11."""12.frombottleimportget,run13.frombottle.ext.websocketimportGeventWebSocketServer14.frombottle.ext.websocketimportwebsocket15.16.users=set()連接進(jìn)來的we#bsocket客戶端集合17.@get('/websocket/',apply=[websocket])18.defchat(ws):19.users.add(ws)20.whileTrue:4.25.26.msg=接客ws.receive()戶端的消息ifmsg:#foruinusers:發(fā)送信息給所u.send(msg)有的客戶端else:#break27.斷開連接#,則踢出28.users.remove(ws)29.run(host='',port=8000,server=GeventWebSocketServer)users集合記得安裝bottle、websocket-clien、bottle-websocket模塊,服務(wù)端允許所有的IP訪問其8000端?websocket服務(wù)端除了?以上的?法外,還可以?這下?的?法實(shí)現(xiàn):

?頁親,你迷路了!親,你迷路了!親,該?頁可能搬家了!輸?搜索內(nèi)容在電腦桌?,寫?個簡單的HTML5javascripts頁?,隨便命名了,如web_socket.html,這個頁?使?了websocket連接到websocket服務(wù)端:1.<!DOCTYPEhtml>2.<html>3.<head>4.</head>.9.<style>#msg{width:400px;height:400px;overflow:auto;border:2pxsolid#000000;color:#ffffff;}</style>10.</head>11.12.<body>0.<p>實(shí)時?志</p><divid="msg"></div><scriptsrc="/jquery/1.9.1/jquery.min.js"></script><script>$(document).ready(function(){/*!window.WebSocket、window.MozWebSocket檢測瀏覽器對websocket的?持*/if(!window.WebSocket){if(window.MozWebSocket){window.WebSocket=window.MozWebSocket;}else{$('#msg').prepend("<p>你的瀏覽器不?持websocket</p>");}}/*ws=newWebSocket創(chuàng)建WebSocket的實(shí)例注意設(shè)置對以下的websocket的地址哦*/ws=newWebSocket('ws://21:8000/websocket/');/*ws.onopen握?完成并創(chuàng)建TCP/IP通道,當(dāng)瀏覽器和WebSocketServer連接成功后,會觸發(fā)onopen消息ws.onmessage接收到WebSocketServer發(fā)送過來的數(shù)據(jù)時,就會觸發(fā)onmessage消息,參數(shù)evt中包含server傳輸過來的數(shù)據(jù);*/ws.onopen=function(evt){$('#msg').append('<li>websocket連接成功</li>');}ws.onmessage=function(evt){$('#msg').prepend('<li>'+evt.data+'</li>');}});41.</script>42.</body>43.</html>注意:WebSocket('ws://21:8000/websocket/');這?的21?定要改成你的websocket服務(wù)端IP,切記到這?,就搞定瀏覽器連接到websocket服務(wù)端的場景了,現(xiàn)在要A服務(wù)器?寫?段代碼,去采集B服務(wù)器的實(shí)時信息了,其實(shí)采集原理很簡單,就是使?shell中的tailf命令,實(shí)時顯?最新的信息已,我們在這段腳本中,使?subprocess.Popen()來遠(yuǎn)程查看?志信息:python代碼如下:1.#!/usr/bin/python2.#encoding=utf-83.4.importsubprocess5.importtime6.fromwebsocketimportcreate_connection7.8.#配置遠(yuǎn)程服務(wù)器的IP,帳號,密碼,端?等,因我做了雙機(jī)密鑰信任,所以不需要密碼9.r_user="root"10.r_ip="0"11.r_port=2212.r_log="/tmp/web_socket.log"#遠(yuǎn)程服務(wù)器要被采集的?志路徑13.14.#websocket服務(wù)端地址15.ws_server="ws://21:8000/websocket/"16.17.#執(zhí)?的shell命令(使?ssh遠(yuǎn)程執(zhí)?)18.cmd="/usr/bin/ssh-p{port}{user}@{ip}/usr/bin/tailf{log_path}".format(user=r_user,ip=r_ip,port=r_port,log_path=r_log)19.20.deftailfLog():0."""獲取遠(yuǎn)程服務(wù)器實(shí)時?志,并發(fā)送到websocket服務(wù)端"""popen=subprocess.Popen(cmd,stdout=subprocess.PIPE,stderr=subprocess.PIPE,shell=True)print('連接成功')ws=create_connection(ws_server)#創(chuàng)建websocket連接whileTrue:line=popen.stdout.readline().strip()#獲取內(nèi)容ifline:ws.send(line)#把內(nèi)容發(fā)送到websocket服務(wù)端printtime.time()31.if__name__=='__main__':32.tailfLog()?章最后再解析subprocess.Popen的原理和功能執(zhí)?websocket服務(wù)端腳本和上?這個websocket客戶端采集腳本,再打開?瀏覽器打開上?的html5頁?后,環(huán)境就基本部署好了,雙websocket客戶端連接到websocket服務(wù)端中上?腳本指定的r_log="/tmp/web_socket.log"?志路徑,我們需要?成這個?志?件,并不停地往??寫??志,這樣才能在瀏覽器中實(shí)時顯?效果(真實(shí)場景中,可以指定服務(wù)器某?志,如apache,nginx?志等)我們在B服務(wù)器寫?段python代碼,然后每隔?秒就往r_log="/tmp/web_socket.log"?志中寫?內(nèi)容:python代碼如下:1.#!/usr/bin/envpython2.#coding=utf-83.4.importtime5.importrandom6.log_path='/tmp/web_socket.log'7.while1:8.9.withopen(log_path,'a')asf:f.write('[%s]%s\n'%(time.ctime(),random.random()))time.sleep(1)10.腳本寫?的內(nèi)容概是:[TueJul2618:30:412016]0.527242649654[TueJul2618:30:422016]0.21080845298[TueJul2618:30:432016]

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論