python websocket網頁實時顯示遠程伺服器日誌信息

来源:https://www.cnblogs.com/xiaoyou2018/archive/2018/07/18/9328950.html
-Advertisement-
Play Games

功能:用websocket技術,在運維工具的瀏覽器上實時顯示遠程伺服器上的日誌信息 一般我們在運維工具部署環境的時候,需要實時展現部署過程中的信息,或者在瀏覽器中實時顯示程式日誌給開發人員看。你還在用ajax每隔段時間去獲取伺服器日誌?out了,試試用websocket方式吧 我用bottle框架, ...


功能:用websocket技術,在運維工具的瀏覽器上實時顯示遠程伺服器上的日誌信息

一般我們在運維工具部署環境的時候,需要實時展現部署過程中的信息,或者在瀏覽器中實時顯示程式日誌給開發人員看。你還在用ajax每隔段時間去獲取伺服器日誌?out了,試試用websocket方式吧

我用bottle框架,寫了個websocket服務端,瀏覽器連接到websocket server,再用python subprocess獲取遠程伺服器的日誌信息,subprocess,就是用Popen調用shell的shell命令而已,這樣可以獲取到實時的日誌了,然後再send到websocket server中,那連接到websocket server的瀏覽器,就會實時展現出來了

用二台伺服器來實現這個場景,A伺服器是websocket服務端,B伺服器是日誌端

A伺服器是我瀏覽器本機,websocket服務端也是這台機,IP是:192.168.2.222

B伺服器是要遠程查看日誌的伺服器,我這裡用:192.168.2.224

以下是A伺服器的操作(Python2)

安裝

    pip install bottle

    pip install websocket-client

    pip install bottle-websocket

websocket servet的python代碼:

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 from bottle import get, run
 4 from bottle.ext.websocket import GeventWebSocketServer
 5 from bottle.ext.websocket import websocket
 6 users = set()   # 連接進來的websocket客戶端集合
 7 @get('/websocket/', apply=[websocket])
 8 def chat(ws):
 9     users.add(ws)
10     while True:
11         msg = ws.receive()  # 接客戶端的消息
12         if msg:
13             for u in users:
14                 u.send(msg) # 發送信息給所有的客戶端
15         else:
16             break
17     # 如果有客戶端斷開連接,則踢出users集合
18     users.remove(ws)
19 run(host='0.0.0.0', port=8000, server=GeventWebSocketServer)

 

記得安裝bottle、websocket-client 、bottle-websocket 模塊,服務端允許所有的IP訪問其8000埠

 

websocket服務端除了用以上的方法外,還可以用這下麵的方法實現:

 http://www.linuxyw.com/831.html

在電腦桌面,寫一個簡單的HTML5  javascripts頁面,隨便命名了,如test.html,這個頁面使用了websocket連接到websocket服務端:

 1  <!DOCTYPE html>
 2 <html>
 3 <head>
 4 </head>
 5     <style>
 6         #msg{
 7             width:400px; height:400px; overflow:auto; border:2px solid #000000;background-color:#000000;color:#ffffff;
 8     }
 9     </style>
10 </head>
11 <body>
12     <p>實時日誌</p>
13     <div id="msg"></div>
14     <script src="http://libs.baidu.com/jquery/1.9.1/jquery.min.js"></script>
15     <script>
16     $(document).ready(function() {
17         /* !window.WebSocket、window.MozWebSocket檢測瀏覽器對websocket的支持*/
18         if (!window.WebSocket) {
19             if (window.MozWebSocket) {
20                 window.WebSocket = window.MozWebSocket;
21             } else {
22                 $('#msg').prepend("<p>你的瀏覽器不支持websocket</p>");
23             }
24         }
25         /* ws = new WebSocket 創建WebSocket的實例  註意設置對以下的websocket的地址哦*/
26         ws = new WebSocket('ws://192.168.2.222:8000/websocket/');
27         /*
28             ws.onopen  握手完成並創建TCP/IP通道,當瀏覽器和WebSocketServer連接成功後,會觸發onopen消息
29             ws.onmessage 接收到WebSocketServer發送過來的數據時,就會觸發onmessage消息,參數evt中包含server傳輸過來的數據;
30         */
31         ws.onopen = function(evt) {
32             $('#msg').append('<li>websocket連接成功</li>');
33         }
34         ws.onmessage = function(evt) {
35             $('#msg').prepend('<li>' + evt.data + '</li>');
36         }
37     });
38 </script>
39 </body>
40 </html>

 

到這裡,就搞定瀏覽器連接到websocket服務端的場景了,現在要A伺服器里‘遠程查看日誌.py’,去採集B伺服器的實時信息了,其實採集原理很簡單,就是使用shell中的tailf命令,實時顯示最新的信息而已,我們在這段腳本中,使用subprocess.Popen()來遠程查看日誌信息:

python代碼如下:

 1 #!/usr/bin/python
 2 # encoding=utf-8
 3 import subprocess
 4 import time
 5 from websocket import create_connection
 6 # 配置遠程伺服器的IP,帳號,密碼,埠等,因我做了雙機密鑰信任,所以不需要密碼
 7 r_user = "root"
 8 r_passwd='jason_zhang'
 9 r_ip = "192.168.2.224"
10 r_port = 22
11 r_log = "/tmp/test.log"   # 遠程伺服器要被採集的日誌路徑
12 # websocket服務端地址
13 ws_server = "ws://192.168.2.222:8000/websocket/"
14 # 執行的shell命令(使用ssh遠程執行)
15 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)
16 def tailfLog():
17     """獲取遠程伺服器實時日誌,併發送到websocket服務端"""
18     popen = subprocess.Popen(cmd,stdout=subprocess.PIPE,stderr=subprocess.PIPE,shell=True)
19     print('連接成功')
20     ws = create_connection(ws_server)   # 創建websocket連接
21     while True:
22         line = popen.stdout.readline().strip()  #獲取內容
23         if line:
24             ws.send(line)   #把內容發送到websocket服務端
25         print (time.time())
26 if __name__ == '__main__':
27     tailfLog()

 

 在伺服器B的日誌文件隨便輸入點東西,再運行伺服器A的獲取日誌腳本

 

獲取到的結果

 

   

tailfLog()文章最後再解析subprocess.Popen的原理和功能

執行websocket服務端腳本和上面這個websocket客戶端採集腳本,再打開用瀏覽器打開上面的html5頁面後,環境就基本部署好了,雙websocket客戶端連接到websocket服務端中

上面腳本指定的r_log = "/tmp/web_socket.log"日誌路徑,我們需要生成這個日誌文件,並不停地往裡面寫入日誌,這樣才能在瀏覽器中實時顯示效果(真實場景中,可以指定伺服器某日誌,如apache,nginx日誌等)

 

剛纔提到subprocess.Popen的原理和功能,請看以下資料:

http://www.cnblogs.com/fengbeihong/articles/3374132.html

bottle websocket參考資料:

http://rfyiamcool.blog.51cto.com/1030776/1269232/

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、Redis簡介 點擊鏈接查看:https://www.cnblogs.com/hwlong/p/9325986.html 二、Redis安裝及基本配置 點擊鏈接查看:https://www.cnblogs.com/hwlong/p/9330191.html 三、Redis持久化 點擊鏈接查看:h ...
  • 創建用戶,切換用戶,登錄和退出操作系統: 關機:init0 切換終端:ctrl+alt+[f1~f6] 同時只有六個終端同時開啟,開啟二號終端是可以同時按下ctrl+alt+f2 掌握退出命令:exit 掌握普通用戶登錄系統提示符:$ 掌握root用戶登錄系統提示符:# 創建用戶名:useradd+ ...
  • 一.系統結構 Linux是一個倒樹形結構,最大的目錄名叫“/”(根目錄) 根目錄之下有許多的二級目錄,這些目錄在系統中都擁有自己不同的功能,如圖: 以後的諸多命令的執行和操作都與這些目錄相關,現在瞭解一下,以後的操作中會慢慢瞭解各個文件的作用。 二.文件管理命令 1.文件的建立 touch file ...
  • How to connect to a VM hosted on QEMU remotely using virt-viewer I couldn’t find comprehensive articles about this, so I decided to write one myself. ...
  • 相信不少初學手機聯網開發的朋友都想知道Http與Socket連接究竟有什麼區別,希望通過自己的淺顯理解能對初學者有所幫助。 一、基本概念 1、TCP連接 手機能夠使用聯網功能是因為手機底層實現了TCP/IP協議,可以使手機終端通過無線網路建立TCP連接。TCP協議可以對上層網路提供介面,使上層網路數 ...
  • 複製當前文件夾下所有的文件名稱 複製的文件類型一: DIR *.* /B> XXX.txt 複製的文件類型二: DIR *.* /B> XXX.xls ...
  • win7自帶的截圖工具很好,很強大,比從網上下載的截圖工具好用多了,很少會出現問題。但是它能不能像QQ截圖工具一樣可以使用快捷鍵呢?今天小編和大家分享下心得,希望能夠給你的工作帶來快捷。 工具/原料 win7自帶截圖工具 工具/原料 win7自帶截圖工具 win7自帶截圖工具 win7自帶截圖工具 ...
  • 1.準備工具 1).交叉編譯工具 2).下載libcurl和openssl源代碼,我使用的是(openssl 1.0.2o.tar,curl 7.59.0.tar) 3).查看cpu詳細 2.開始編譯 openssl 庫版本 : openssl 1.0.2o march和 D__ARM_MAX_AR ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...