Python中文
首页
教程
问答
标签
搜索
登录
注册
如果shell脚本执行失败,如何实现重试机制?
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我正在尝试用Python代码执行shell脚本。到目前为止一切都很好。在</p> <p>下面是我的Python脚本,它将执行一个shell脚本。下面是一个简单的helloworld shell脚本。在</p> <pre><code>jsonStr = '{"script":"#!/bin/bash\\necho Hello world 1\\n"}' j = json.loads(jsonStr) shell_script = j['script'] print "start" proc = subprocess.Popen(shell_script, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) (stdout, stderr) = proc.communicate() if stderr: print "Shell script gave some error" print stderr else: print stdout print "end" # Shell script ran fine. </code></pre> <p>现在我要找的是,假设无论出于什么原因,每当我从Python代码执行shell脚本时,它失败了。那就意味着<code>stderr</code>不会为空。所以现在我想再次执行shell脚本,比如在休眠几毫秒之后?在</p> <p>这意味着如果shell脚本执行失败,是否有可能实现重试机制?我可以再试5到6次吗?也就是说可以配置这个号码吗?在</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>可能是这样:</p> <pre><code>maxRetries = 6 retries = 0 while (retries < maxRetries): doSomething () if errorCondition: retries += 1 continue break </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
无法使用Django/mongoengine连接到MongoDB(身份验证失败)
5 回答
无法使用Django\u mssql\u后端迁移到外部hos
9 回答
无法使用Django&Python3.4连接到MySql
9 回答
无法使用Django+nginx上载媒体文件
8 回答
无法使用Django1.6导入名称模式
8 回答
无法使用Django1.7和mongodb登录管理站点
4 回答
无法使用Djangoadmin创建项目,进程使用了错误的路径,因为我事先安装了错误的Python
7 回答
无法使用Djangockedi验证CBV中的字段
7 回答
无法使用Djangocketditor上载图像(错误400)
6 回答
无法使用Djangocron进行函数调用
8 回答
无法使用Djangofiler djang上载文件
9 回答
无法使用Djangokronos
5 回答
无法使用Djangomssql provid
10 回答
无法使用Djangomssql连接到带有Django 1.11的MS SQL Server 2016
10 回答
无法使用Djangomssq迁移Django数据库
4 回答
无法使用Djangonox创建用户
10 回答
无法使用Djangopyodb从Django查询SQL Server
8 回答
无法使用Djangopython3ldap连接到ldap
8 回答
无法使用Djangoredis连接到redis
8 回答
无法使用Django中的FK创建新表
3 回答