首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python使用坚韧模块重试

Python使用坚韧模块重试
EN

Stack Overflow用户
提问于 2017-11-04 20:01:05
回答 1查看 8.6K关注 0票数 6

我很难让坚韧库按预期工作。下面的测试中的重试根本不会触发。我希望每5秒进行一次重试,日志文件将反映重试尝试。

代码语言:javascript
复制
import paramiko
import tenacity
from configparser import RawConfigParser
import logging

def main():
    parser = RawConfigParser()
    parser.read('config.ini')
    HOST = parser['SSH']['host']
    PORT = parser['SSH']['port']
    USER = parser['SSH']['user']
    LOG_LEVEL = parser['Logging']['level']
    LOG_FILE = parser['Files']['log_file']
    LOG_FORMAT = parser['Logging']['format']

    with open(LOG_FILE, "a") as f:
        logging.basicConfig(filename=LOG_FILE,level=LOG_LEVEL,format=LOG_FORMAT)
        logging.info("******Started logging******")

    client = paramiko.SSHClient()
    client.set_missing_host_key_policy(paramiko.AutoAddPolicy())

    @tenacity.retry(wait=tenacity.wait_fixed(5))
    def connect():
        try:
            client.connect(HOST, int(PORT), USER)
            logging.info("Successful connection to remote server")
        except Exception:
            logging.error("Cannot connect to remote server")

    connect()

if __name__ == "__main__":
    main()

日志文件将如下所示:

代码语言:javascript
复制
> 2017-11-04 19:55:20,695 ******Started logging******
> 2017-11-04 19:55:20,695 Cannot connect to remote server
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-11-04 20:37:11

我认为tenacity通过处理异常来检测故障。在您的代码中,异常将被记录,然后丢弃。因此,对于tenacity来说,您的调用实际上是成功的。您应该重新引发此异常,以获得预期的行为。如下所示:

代码语言:javascript
复制
@tenacity.retry(wait=tenacity.wait_fixed(5))
def connect():
    try:
        client.connect(HOST, int(PORT), USER)
        logging.info("Successful connection to remote server")
    except Exception:
        logging.error("Cannot connect to remote server")
        raise
票数 12
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47115059

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档