Я хочу перечислить и убить все процессы, принадлежащие сеансу определенного процесса, который использует порт. Это должно происходить с помощью пакетной команды Windows, которая будет принимать номер порта в качестве входных данных.
Например: предположим, что процесс PA в настоящее время прослушивает порт 8081. PA работает в рамках сеанса S1. Есть процессы PB и PC, принадлежащие к тому же сеансу, что и PA. PB и ПК будут работать на разных портах (не важно, на каких портах они работают)
Командный / пакетный файл Windows должен принимать 8081 в качестве входных данных и уничтожать процессы PA, PB и PC.
Это возможно? Благодарю за небольшую помощь по этому поводу, поскольку я не очень хорошо разбираюсь в пакетных командах / сценариях.
Моя неудачная попытка:
(for /F "tokens=2" %%i in (for /f "tokens=5" %a in ('netstat -aon ^| findstr 8081') do tasklist /NH /FI "PID eq %a") do taskkill /NH /FI "SESSIONNAME eq %%i")
На самом деле это довольно просто в PowerShell:
# Get the process of the listening NetTCPConnection and the session ID of the process
$SessionId = (Get-Process -Id (Get-NetTCPConnection -State Listen -LocalPort 8081).OwningProcess).SessionId
# Get all processes from that session and stop them
Get-Process | Where-Object { $_.SessionId -eq $SessionId } |
Stop-Process -Force -Confirm:$false
Если вы ищете пакетный скрипт
for /f "tokens=5" %%a in ('netstat -aon ^| findstr 8081 ^| findstr "LISTEN"') do (
for /f "tokens=3" %%b in ('tasklist /NH /FI "PID eq %%a"') do (
for /f "tokens=2" %%c in ('tasklist /NH /FI "SESSIONNAME eq %%b"') do (
taskkill /F /PID %%c
)
)
)