通过shell执行脚本执行netstat查看端口,并清理该端口
时间: 2023-12-20 17:03:16 浏览: 105
可以编写一个脚本来实现这个任务。以下是一个简单的示例:
```bash
#!/bin/bash
# 获取要清理的端口号
echo "请输入要清理的端口号:"
read port
# 查找该端口是否在监听状态
netstat -an | grep $port
# 如果端口在监听状态,就杀掉相关进程
if [ $? -eq 0 ]; then
echo "端口 $port 正在使用中,正在尝试清理..."
pid=$(lsof -i:$port | awk '{print $2}' | tail -n 1)
if [ -n "$pid" ]; then
echo "找到进程 $pid,正在尝试杀死..."
kill -9 $pid
echo "进程 $pid 已被杀死"
else
echo "无法找到占用该端口的进程"
fi
else
echo "端口 $port 未在使用中,无需清理"
fi
```
在命令行中执行该脚本,输入要清理的端口号,它会自动查找该端口是否在监听状态,如果是,则杀掉相关进程,否则输出无需清理的信息。
相关问题
使用shell 脚本 执行 ss 命令查看指定端口 并获取进程号
可以使用以下命令:
```
ss -lntp | grep <端口号>
```
其中,-lntp 表示列出所有监听端口的 TCP 连接信息,grep <端口号> 表示匹配指定端口号的连接信息。若该端口有进程与之对应,则会在连接信息中列出进程的 PID(进程号)。
同时,您也可以使用 netstat 命令来实现相同的功能:
```
netstat -lnp | grep <端口号>
```
shell脚本管理员通过输入防火墙端口码查看端口的打开或关闭
您可以使用以下的 Shell 脚本来查看端口的打开或关闭状态:
```bash
#!/bin/bash
# 获取输入的端口号
read -p "请输入要查询的端口号:" port
# 检查端口是否被打开
netstat -an | grep $port > /dev/null
if [ $? -eq 0 ]; then
echo "端口 $port 已经打开"
else
echo "端口 $port 没有打开"
fi
```
该脚本会先让管理员输入要查询的端口号,然后使用 `netstat` 命令来检查该端口是否被打开。如果端口已经被打开,则输出 `端口 $port 已经打开`;如果端口没有被打开,则输出 `端口 $port 没有打开`。
阅读全文