校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 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庫自動獲取日志信息的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    岛国精品在线播放| 亚洲国产日韩一区二区| 欧美精品乱人伦久久久久久| 99免费精品视频| 国产精品一区二区三区99| 免费在线看成人av| 日本伊人色综合网| 亚洲成人动漫在线免费观看| 亚洲一二三四在线| 亚洲伊人色欲综合网| 亚洲bt欧美bt精品777| 日本va欧美va精品发布| 蜜桃av噜噜一区| 九九**精品视频免费播放| 国产精品一卡二卡在线观看| 国产精品伊人色| 91色porny在线视频| 在线观看日韩一区| 欧美日韩国产美女| 精品日韩一区二区| 国产精品久久99| 亚洲自拍另类综合| 毛片av一区二区| 成人晚上爱看视频| 99精品视频在线播放观看| 欧美午夜寂寞影院| xnxx国产精品| 国产精品久久久久久久久动漫 | 精品国产乱码久久久久久免费| 日韩午夜在线影院| www久久精品| 亚洲欧美福利一区二区| 日韩制服丝袜av| 成人午夜大片免费观看| 91精品福利在线| 亚洲精品在线电影| 亚洲精品久久久蜜桃| 久久国产尿小便嘘嘘尿| www.日韩精品| 日韩欧美www| 亚洲男人的天堂在线观看| 欧美aaaaaa午夜精品| 99国产精品一区| 日韩欧美视频在线| 一区二区三区在线看| 黄色资源网久久资源365| 在线观看av一区二区| 久久精品一区二区三区四区| 亚洲精品视频在线观看网站| 国内精品久久久久影院色| 色噜噜狠狠色综合欧洲selulu| 欧美不卡一区二区| 亚洲高清中文字幕| 成人中文字幕电影| 欧美成人性福生活免费看| 亚洲激情图片一区| 不卡视频在线看| 精品久久久久久最新网址| 亚洲成人一区二区在线观看| 99久久婷婷国产综合精品| 久久综合一区二区| 免费在线成人网| 欧美中文字幕一区二区三区 | 亚洲制服丝袜av| 成人自拍视频在线观看| 青青草97国产精品免费观看无弹窗版| 久久久久国产成人精品亚洲午夜| 亚洲丶国产丶欧美一区二区三区| 制服丝袜亚洲播放| 蜜臀91精品一区二区三区 | 视频一区国产视频| 91黄视频在线观看| 欧美大片国产精品| 青青草精品视频| 91 com成人网| 午夜a成v人精品| 欧美丰满高潮xxxx喷水动漫| 亚洲三级电影网站| 一本色道a无线码一区v| 国产精品久久二区二区| 成人精品国产免费网站| 国产精品色一区二区三区| 国产成人综合亚洲网站| 久久综合丝袜日本网| 国产精品夜夜嗨| 亚洲国产电影在线观看| 成人18视频在线播放| 亚洲欧洲制服丝袜| 欧美三级日韩三级| 日韩精品1区2区3区| 日韩欧美中文字幕制服| 日本成人在线看| 精品免费99久久| 国产91精品欧美| 日韩理论在线观看| 欧美在线啊v一区| 免费欧美在线视频| 国产喂奶挤奶一区二区三区| jlzzjlzz欧美大全| 亚洲高清视频在线| 日韩欧美在线观看一区二区三区| 国产酒店精品激情| 亚洲男人的天堂一区二区| 337p亚洲精品色噜噜| 国内一区二区在线| 国产精品国产a| 欧美一区二区久久久| 国产成人三级在线观看| 一区二区免费看| 欧美一区二区在线免费播放| 丰满岳乱妇一区二区三区| 亚洲一区二区三区精品在线| 日韩欧美中文一区二区| 91色在线porny| 捆绑调教一区二区三区| 亚洲免费观看在线视频| 欧美一激情一区二区三区| 国产不卡在线一区| 午夜亚洲福利老司机| 久久奇米777| 欧美老年两性高潮| 成人免费毛片aaaaa**| 青青青伊人色综合久久| 中文字幕亚洲一区二区av在线| 91精品国产综合久久久久久| 波多野结衣在线aⅴ中文字幕不卡| 免费观看一级特黄欧美大片| 亚洲人精品午夜| 久久九九久精品国产免费直播| 欧美丝袜第三区| 99精品欧美一区二区三区小说| 日韩高清中文字幕一区| 一区二区三区在线视频播放| 国产女人aaa级久久久级| 在线电影国产精品| 在线免费观看日本欧美| 成人午夜av在线| 另类调教123区 | 在线不卡的av| 91老师国产黑色丝袜在线| 国产另类ts人妖一区二区| 看电影不卡的网站| 亚洲福利一区二区| 一区二区三区产品免费精品久久75| 国产欧美一区二区精品久导航| 日韩免费看的电影| 欧美一区二区三区性视频| 欧美在线观看视频一区二区| 色综合久久久网| 97成人超碰视| 成人免费av资源| 成人av动漫网站| 99精品视频在线观看免费| 不卡一区二区在线| 91色.com| 在线免费观看一区| 欧美日韩一区 二区 三区 久久精品| 91丨九色porny丨蝌蚪| 91蜜桃视频在线| 在线观看欧美黄色| 欧美日韩一级视频| 在线播放91灌醉迷j高跟美女| 欧美日韩精品一二三区| 欧美日本一区二区| 欧美一区在线视频| 欧美精品一区二区三区蜜桃| 久久免费看少妇高潮| 国产欧美一区二区精品忘忧草| 欧美国产综合一区二区| 亚洲女人****多毛耸耸8| 亚洲午夜久久久久久久久电影院| 一个色妞综合视频在线观看| 亚洲国产一区二区a毛片| 亚洲成av人影院在线观看网| 日韩中文欧美在线| 国产乱码字幕精品高清av| 不卡的电视剧免费网站有什么| 色94色欧美sute亚洲线路一久| 欧美性videosxxxxx| 日韩女优制服丝袜电影| 久久精品在这里| 亚洲综合成人在线视频| 视频一区在线视频| 国产成人在线看| 91黄视频在线| 久久中文娱乐网| 亚洲精品中文字幕在线观看| 水蜜桃久久夜色精品一区的特点 | 美女高潮久久久| 成人国产精品免费观看动漫| 色悠悠亚洲一区二区| 日韩视频在线一区二区| 国产精品人人做人人爽人人添| 亚洲成a人v欧美综合天堂下载| 另类小说色综合网站| 日本韩国欧美一区二区三区| 欧美电视剧在线看免费| 亚洲免费伊人电影| 国产一区二区免费视频| 欧美色国产精品|