Python的win32serviceutil之疑似BUG
鄭昀@玩聚SR?20090515
1、現(xiàn)象:
用Python的win32serviceutil控制Windows Service啟動(dòng)、停止、重啟時(shí),如下代碼一般是沒(méi)問(wèn)題的。
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時(shí),會(huì)出現(xiàn)一個(gè)很怪的現(xiàn)象。
譬如運(yùn)行這么簡(jiǎn)單的語(yǔ)句:
import win32serviceutil
win32serviceutil.StartService("Apache2.2","localhost")
順利執(zhí)行后,停止的Apache服務(wù)并沒(méi)有被啟動(dòng)。
此時(shí),Windows事件日志就會(huì)報(bào)告這種錯(cuò)誤:
事件類型:??? 錯(cuò)誤
事件來(lái)源:??? Apache Service
事件種類:??? 無(wú)
事件 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 函數(shù)雖然可以先正常地停止掉Apache服務(wù),但試圖啟動(dòng)時(shí)仍遇到同樣的錯(cuò)誤。
在多臺(tái)服務(wù)器(Windows2003+SP2)和我本機(jī)(WindowsXP+SP2)都可以重現(xiàn)。
2、解決:
?
把machine參數(shù)去掉不傳即可,或傳空字符串。
即:
win32serviceutil.StartService("Apache2.2")
或
win32serviceutil.StartService("Apache2.2","")
可以正常啟動(dòng)本機(jī)的Apache,這樣無(wú)法遙控域內(nèi)其他服務(wù)器了。
?
3、更多:
1:win32serviceutil.StartService(service, '-w -n "Apache2.2" -k start')
這樣不傳machine參數(shù),只設(shè)定服務(wù)啟動(dòng)的傳入?yún)?shù)也不行。
2:對(duì)于 win32serviceutil.StopService 函數(shù),停止Apache等Windows服務(wù)時(shí),不存在此問(wèn)題。
轉(zhuǎn)載于:https://www.cnblogs.com/zhengyun_ustc/archive/2009/05/16/win32serviceutil.html
總結(jié)
以上是生活随笔為你收集整理的Python的win32serviceutil之疑似BUG的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 职场交流:一位软件工程师的7年总结
- 下一篇: 火狐 和 IE 透明度的设置。