シンプルな(そして醜い)答え、WerFault.exe
特に問題のあるアプリケーションに関連するインスタンスを時々監視しますPID
。そして、それを殺します。対処WerFault.exe
は複雑ですが、無効にしたくありません。Windows エラー報告サービスを参照してください。
- 一致するプロセスのリストを名前で取得します
WerFault.exe
。psutil
パッケージを使用しています。psutil
プロセスはキャッシュされるので注意して使用してpsutil.get_pid_list()
ください。
- を使用してコマンド ラインをデコードし
argparse
ます。これはやり過ぎかもしれませんが、既存の Python ライブラリを活用します。
- に従って、アプリケーションを保持しているプロセスを特定します
PID
。
これは単純な実装です。
def kill_proc_kidnapper(self, child_pid, kidnapper_name='WerFault.exe'):
"""
Look among all instances of 'WerFault.exe' process for an specific one
that took control of another faulting process.
When 'WerFault.exe' is launched it is specified the PID using -p argument:
'C:\\Windows\\SysWOW64\\WerFault.exe -u -p 5012 -s 68'
| |
+-> kidnapper +-> child_pid
Function uses `argparse` to properly decode process command line and get
PID. If PID matches `child_pid` then we have found the correct parent
process and can kill it.
"""
parser = argparse.ArgumentParser()
parser.add_argument('-u', action='store_false', help='User name')
parser.add_argument('-p', type=int, help='Process ID')
parser.add_argument('-s', help='??')
kidnapper_p = None
child_p = None
for proc in psutil.get_pid_list():
if kidnapper_name in proc.name:
args, unknown_args = parser.parse_known_args(proc.cmdline)
print proc.name, proc.cmdline
if args.p == child_pid:
# We found the kidnapper, aim.
print 'kidnapper found: {0}'.format(proc.pid)
kidnapper_p = proc
if psutil.pid_exists(child_pid):
child_p = psutil.Process(child_pid)
if kidnapper_p and child_pid:
print 'Killing "{0}" ({1}) that kidnapped "{2}" ({3})'.format(
kidnapper_p.name, kidnapper_p.pid, child_p.name, child_p.pid)
self.taskkill(kidnapper_p.pid)
return 1
else:
if not kidnapper_p:
print 'Kidnapper process "{0}" not found'.format(kidnapper_name)
if not child_p:
print 'Child process "({0})" not found'.format(child_pid)
return 0
これで、taskkill
関数はtaskkill
正しいコマンドでコマンドを呼び出しますPID
。
def taskkill(self, pid):
"""
Kill task and entire process tree for this process
"""
print('Task kill for PID {0}'.format(pid))
cmd = 'taskkill /f /t /pid {0}'.format(pid)
subprocess.call(cmd.split())