kill-port.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import { exec as execCallback } from 'child_process';
  2. import { promisify } from 'util';
  3. const exec = promisify(execCallback);
  4. const port = 3000; // 可修改为需要监听的端口
  5. const getCommand = (port) => {
  6. return process.platform === 'win32'
  7. ? `netstat -ano | findstr ${port}`
  8. : `lsof -i :${port}`;
  9. };
  10. const getKillCommand = (pid) => {
  11. return process.platform === 'win32'
  12. ? `taskkill /f /pid ${pid}`
  13. : `kill -9 ${pid}`;
  14. };
  15. const killPort = async (port) => {
  16. try {
  17. const cmd = getCommand(port);
  18. const { stdout } = await exec(cmd);
  19. if (!stdout.trim()) {
  20. console.log(`端口 ${port} 未被占用`);
  21. return;
  22. }
  23. const lines = stdout.trim().split('\n');
  24. const killPromises = lines.map(async (line) => {
  25. const parts = line.trim().split(/\s+/);
  26. const pid = process.platform === 'win32' ? parts[4] : parts[1];
  27. if (pid && !isNaN(pid)) {
  28. try {
  29. const killCmd = getKillCommand(pid);
  30. await exec(killCmd);
  31. console.log(`成功终止占用端口 ${port} 的进程: ${pid}`);
  32. } catch (killErr) {
  33. console.error(`终止进程 ${pid} 失败:`, killErr);
  34. }
  35. }
  36. });
  37. await Promise.all(killPromises);
  38. } catch (err) {
  39. console.error('执行命令时出错:', err);
  40. }
  41. };
  42. // 执行函数
  43. killPort(port);