Python的win32serviceutil之疑似BUG
鄭昀@玩聚SR?20090515
1、現象:
用Python的win32serviceutil控制Windows Service啟動、停止、重啟時,如下代碼一般是沒問題的。
import win32serviceutil
def service_manager(action, machine, service):
??? if action == 'stop':
??????? win32serviceutil.StopService(service, machine)
??? elif action == 'start':
??????? win32serviceutil.StartService(service, machine)
??? elif action == 'restart':
??????? win32serviceutil.RestartService(service, machine)
??? elif action == 'status':
??????? if win32serviceutil.QueryServiceStatus(service, machine)[1] == 4:
??????????? print "%s is happy" % service
??????? else:
??????????? print "%s is being a PITA" % service
但控制Apache Service時,會出現一個很怪的現象。
譬如運行這么簡單的語句:
import win32serviceutil
win32serviceutil.StartService("Apache2.2","localhost")
順利執行后,停止的Apache服務并沒有被啟動。
此時,Windows事件日志就會報告這種錯誤:
事件類型:??? 錯誤
事件來源:??? Apache Service
事件種類:??? 無
事件 ID:??? 3299
The Apache service named? reported the following error:
>>> Usage: C:""Apache2.2""bin""httpd.exe [-D name] [-d directory] [-f file]
?
同樣,win32serviceutil.RestartService 函數雖然可以先正常地停止掉Apache服務,但試圖啟動時仍遇到同樣的錯誤。
在多臺服務器(Windows2003+SP2)和我本機(WindowsXP+SP2)都可以重現。
2、解決:
?
把machine參數去掉不傳即可,或傳空字符串。
即:
win32serviceutil.StartService("Apache2.2")
或
win32serviceutil.StartService("Apache2.2","")
可以正常啟動本機的Apache,這樣無法遙控域內其他服務器了。
?
3、更多:
1:win32serviceutil.StartService(service, '-w -n "Apache2.2" -k start')
這樣不傳machine參數,只設定服務啟動的傳入參數也不行。
2:對于 win32serviceutil.StopService 函數,停止Apache等Windows服務時,不存在此問題。
轉載于:https://www.cnblogs.com/zhengyun_ustc/archive/2009/05/16/win32serviceutil.html
總結
以上是生活随笔為你收集整理的Python的win32serviceutil之疑似BUG的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 职场交流:一位软件工程师的7年总结
- 下一篇: 得到python默认的帮助文档