欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > python基于pexpect庫自動獲取日志信息

python基于pexpect庫自動獲取日志信息

熱門標簽:杭州房產地圖標注 天津塘沽區地圖標注 如何申請400電話代理 滴滴地圖標注公司 甘肅高頻外呼系統 地圖標注可以遠程操作嗎 智能電話機器人調研 400電話在線如何申請 江門智能電話機器人

1. 前言

對大部分的人來說,解決 Bug 都是依靠關鍵字去日志去定位問題!

在調試情況下,我們可以實時在控制臺查看日志;但對于部署到服務器上的應用,日志都存放在服務器某個目錄下,沒法通過本地查看到

這種情況下,就需要我們先登錄服務器,然后進入到日志目錄文件夾,最后通過日志文件去定位問題;如果涉及到 K8s 容器,可能還需要使用 kubectl 命令進入到服務對應的容器中,進入到日志目錄,才能開始定位問題,這一切顯得非常繁瑣且低效

本篇文章介紹一款 Python 依賴庫:pexpect,作為一款命令行自動化工具,它可以幫助我們一鍵獲取日志,快速定位問題!

2. pexpect 介紹

pexpect 是 Python 語言實現的類 Expect 的一種實現,通過產生子應用程序并控制它們,通過期望模式對子應用程序的輸出做出相應處理

項目地址:

https://github.com/pexpect/pexpect/tree/5eed1a31a2853a09b7367c59fbd1a4a0b53341df

它主要對人機對話進行模擬,來實現一些自動化的場景

比如:用來和 SSH、FTP、PASSWD、Telnet 等命令行程序進行自動化交互

在使用之前,我們先安裝依賴包

# 安裝依賴庫
pip3 install pexpect

3. 實戰一下

我們以從服務器 K8S 容器獲取日志為例進行講解

3-1 SSH 登錄

首先,初始化使用 pexpect 模擬 SSH 遠程登錄服務器

import pexpect

PROMPT = ['# ', '>>> ', '> ', '\$ ']

def login_with_pexpect():
    """
    登錄-pexpect
    :return:
    """
    # 端口號
    port = **

    # 用戶名
    user = **

    # 密碼
    pwd = **

    # ip地址
    ip = **

    ssh_cmd = "ssh -p {} {}@{}".format(port,user,ip)

    # 指定登錄命令,拿到程序操作句柄
    child = pexpect.spawn(ssh_cmd, timeout=60, encoding='utf-8')

    # 提示輸入密碼的字符出現,否則超時
    ret = child.expect([pexpect.TIMEOUT, '[P|p]assword: '], timeout=10)

    # 匹配成功后,輸入密碼,執行登陸操作
    if ret == 1:
        # 發送密碼
        child.sendline(pwd)
        child.expect(PROMPT)
        return child
    else:
        print('登錄失?。?)

其中

pexpect.spawn() :用于執行一個程序,并返回一個操作句柄

該方法常見的 3 個參數如下:

  • 第一個參數是待執行的命令
  • 第二個參數指定超時時間,程序執行后的輸出檢查,如果指定時間內沒有匹配到結果,就會拋異常
  • 第三個參數用于設置編碼格式

child.expect() :對輸出結果,利用正則表達式進行關鍵字匹配

代碼中的含義是在 10s 內等待出現關鍵字 '[P|p]assword: '

最后,如果匹配的結果為 1,使用 sendline() 方法發送帶回車符的字符串,模擬密碼的輸入,完成登錄操作

3-2  封裝發送命令

接下來,我們將操作句柄發送命令進行一次封裝,并獲取返回結果

def send_command(child, cmd, expected_content=None, timeout=10):
    """
    發送一條命令,并打印結果
    :param expected_content:
    :param child:
    :param cmd:
    :return:
    """
    # 發送一條命令
    if expected_content is None:
        expected_content = ["#"]

    child.sendline(cmd)

    # 期望有命令行提示字符出現
    child.expect(expected_content, timeout=timeout)

    # 將之前的內容都輸出
    result = child.before

    return result 

需要指出的是,child.before 用于獲取到匹配到關鍵字為止,緩存里面已有的全部數據

3-3  進入容器 pod 日志目錄

使用上面的方法,通過 kubectl 進入到對應的容器日志目錄

# 登錄pod容器
exec_enter_pod = 'kubectl -n %s exec -it %s  bash' % (env, pod_name)

# 進入容器
send_command(child, exec_enter_pod)

# 進入到日志目錄
send_command(child, "cd logs", expected_content='tomcat/logs#')

3-4  獲取日志內容

最后我們只需要組成獲取日志的命令

比如:使用 grep/tail 命令組成一個提取日志文件的命令

然后使用句柄對象發送這條命令

最后,對返回內容進行清洗即可

4. 最后

文中使用 pexpect 實現了一個非常簡單的場景

事實上,大部分人機對話自動化交互都可以由它來實現,比如,下載日志、實時配置、遠程打包下載等

以上就是python基于pexpect庫自動獲取日志信息的詳細內容,更多關于python pexpect庫自動獲取日志的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • python實現自定義日志的具體方法
  • Python 第三方日志框架loguru使用
  • python和websocket構建實時日志跟蹤器的步驟
  • 解決python logging遇到的坑 日志重復打印問題
  • python 實現多進程日志輪轉ConcurrentLogHandler
  • python 實現logging動態變更輸出日志文件名
  • python (logging) 日志按日期、大小回滾的操作
  • 詳解python日志輸出使用配置文件格式
  • Python日志打印里logging.getLogger源碼分析詳解
  • python subprocess pipe 實時輸出日志的操作
  • Python中logging日志的四個等級和使用
  • 如何在Python項目中引入日志

標簽:臨汾 河池 德宏 廊坊 長春 漢中 重慶 東莞

巨人網絡通訊聲明:本文標題《python基于pexpect庫自動獲取日志信息》,本文關鍵詞  python,基于,pexpect,庫,自動,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python基于pexpect庫自動獲取日志信息》相關的同類信息!
  • 本頁收集關于python基于pexpect庫自動獲取日志信息的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    日韩欧美国产成人精品免费| 亚洲免费观看高清完整版在线观看| 无码av中文一区二区三区桃花岛| 91在线高清观看| 国产精品九九九九九九| 中文字幕在线一区| 成人动漫在线一区| 国产suv一区二区三区| 国产精品夫妻自拍| 高清成人免费视频| 希岛爱理中文字幕| 国产精品传媒入口麻豆| 不卡欧美aaaaa| 91国产免费观看| 一区二区三区在线观看动漫| 91免费在线播放| 精品视频一区二区三区免费| 亚洲图片一区二区| 日韩精品人妻中文字幕有码| 日韩三级伦理片妻子的秘密按摩| 免费观看在线色综合| www.狠狠爱| 国产欧美一区二区三区网站| 大胆欧美人体老妇| 色狠狠一区二区| 亚洲一二三区在线观看| 少妇一级淫片免费放播放| 日韩三级视频在线看| 久久精品久久99精品久久| 摸摸摸bbb毛毛毛片| 国产欧美日韩激情| 99久久精品免费精品国产| 欧美天堂一区二区三区| 五月天视频一区| 欧美精品黑人猛交高潮| 久久久久久久久久久电影| 成人黄色一级视频| 欧美日韩成人激情| 麻豆成人久久精品二区三区小说| 奇米网一区二区| 亚洲免费观看高清| 亚洲av无码一区二区三区观看| 久久先锋资源网| aaa国产一区| 91精品国产黑色紧身裤美女| 精油按摩中文字幕久久| 在线免费观看亚洲视频| 午夜亚洲国产au精品一区二区| 天天躁日日躁aaaa视频| 一区在线播放视频| 在线观看国产三级| 国产欧美日韩在线| 蜜桃视频无码区在线观看| 欧美成人一区二区三区在线观看| 国产精品一二三四区| 欧美日韩免费观看一区三区| 精品一区二区影视| 欧美在线视频全部完| 理论电影国产精品| 色婷婷久久久久swag精品| 日韩av一区二区在线影视| 糖心vlog免费在线观看| 亚州成人在线电影| 手机在线中文字幕| 舔着乳尖日韩一区| 久久久精品少妇| 午夜在线成人av| 91日韩中文字幕| 日韩专区中文字幕一区二区| 欧美激情精品久久久久久免费| 亚洲不卡在线观看| 国产老头老太做爰视频| 午夜激情综合网| 美国黄色片视频| 日产欧产美韩系列久久99| 国产少妇在线观看| 蜜桃视频一区二区三区在线观看| 色婷婷综合久久久久中文一区二区| 男人的j进女人的j一区| 91福利精品视频| 激情文学综合丁香| 欧美精品视频www在线观看| 国产91精品精华液一区二区三区 | 国产精品免费无码| 一区二区三区久久久| gv天堂gv无码男同在线观看| 亚洲高清一区二区三区| 91九色丨porny丨极品女神| 蜜桃精品在线观看| 欧美色欧美亚洲另类二区| 国产黄色成人av| 精品精品国产高清a毛片牛牛| 91视频免费入口| 国产精品美女www爽爽爽| 久久久视频6r| 日本不卡一区二区三区高清视频| 在线日韩av片| 成人av网站在线观看免费| 久久一留热品黄| 欧美亚一区二区三区| 亚洲成人动漫精品| 在线观看亚洲专区| 成人动漫一区二区三区| 久久久久国产精品免费免费搜索| 国产精品一区二区入口九绯色| 亚洲一区二区黄色| 欧美在线视频全部完| 岛国精品在线观看| 欧美国产日产图区| 极品久久久久久久| 精品一区二区免费看| 欧美电影免费观看高清完整版| 极品白嫩的小少妇| 亚洲国产一区在线观看| 在线中文字幕一区| 成人午夜精品在线| 国产精品久久一卡二卡| 黄色录像二级片| 国产成人精品免费一区二区| 久久精品日韩一区二区三区| 亚洲黄色小说视频| 久久精品国产精品亚洲综合| 欧美大片日本大片免费观看| 中国黄色a级片| 麻豆精品一区二区av白丝在线| 日韩丝袜情趣美女图片| 国产精品jizz| 久久国内精品自在自线400部| 欧美电视剧免费观看| 一本加勒比北条麻妃| 麻豆精品一区二区| 337p日本欧洲亚洲大胆色噜噜| 亚洲天堂岛国片| 国产真实乱子伦精品视频| 国产亚洲欧美一区在线观看| 国产精品18在线| 成人免费视频视频在线观看免费| 中文字幕中文字幕一区| 色先锋aa成人| 欧美xxxx日本和非洲| 天天影视涩香欲综合网| 日韩亚洲欧美在线观看| 精品无码国产污污污免费网站 | 日韩毛片无码永久免费看| 国产一区二区久久| 国产精品美女久久久久av爽李琼| 色综合亚洲欧洲| 色综合久久久无码中文字幕波多| 亚洲二区在线观看| 日韩精品中文字幕在线一区| 免费黄色在线网址| 成人激情图片网| 亚洲自拍欧美精品| 日韩亚洲欧美成人一区| 成人免费视频入口| 99re66热这里只有精品3直播 | 国产在线国偷精品免费看| 亚洲国产精品传媒在线观看| 色综合网站在线| 男人的天堂影院| 精品一区二区三区蜜桃| 国产精品久久久久久久岛一牛影视| 在线看国产一区| 人妻丰满熟妇av无码久久洗澡 | 中文字幕亚洲精品在线观看| 欧美亚洲另类激情小说| 免费成人深夜夜行p站| 国产精品66部| 一区二区在线电影| 日韩视频123| 538精品在线视频| 欧美一区二区免费在线观看| 黄色日韩网站视频| 玉米视频成人免费看| 日韩欧美精品在线视频| 国产免费久久久久| 中文字幕天堂av| 国产精品亚洲午夜一区二区三区| 亚洲欧美日韩人成在线播放| 精品日韩欧美一区二区| 色综合久久久久综合体桃花网| 偷偷色噜狠狠狠狠的777米奇| 国产麻豆精品视频| 亚洲成人一区二区在线观看| 国产日韩影视精品| 欧美日高清视频| 成人一级黄色大片| 日批在线观看视频| 成人毛片视频在线观看| 日韩av二区在线播放| 中文字幕日本不卡| 欧美精品一区二区三区视频| 欧洲色大大久久| 一本在线免费视频| 一起草在线视频| 99久久精品国产导航| 国内不卡的二区三区中文字幕| 夜夜夜精品看看| 欧美—级在线免费片| 日韩丝袜美女视频|