shell脚本管理员通过输入防火墙端口码查看端口的打开或关闭
时间: 2024-01-22 11:20:17 浏览: 26
您可以使用以下的 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 没有打开`。
相关问题
shell脚本中,管理员输入“端口号”及“on/off”操作,系统根据管理员的输入,开启或关闭指定的端口号
好的,您可以使用以下代码实现:
```bash
#!/bin/bash
# 获取管理员输入的端口号和操作(on/off)
read -p "请输入端口号:" port
read -p "请输入操作(on/off):" action
# 判断操作是否合法
if [ $action != "on" ] && [ $action != "off" ]
then
echo "操作不合法,只能输入 on 或 off"
exit 1
fi
# 开启或关闭指定的端口号
if [ $action == "on" ]
then
firewall-cmd --zone=public --add-port=$port/tcp --permanent
firewall-cmd --reload
echo "端口号 $port 已开启"
else
firewall-cmd --zone=public --remove-port=$port/tcp --permanent
firewall-cmd --reload
echo "端口号 $port 已关闭"
fi
```
其中,`firewall-cmd` 是 CentOS/RHEL 中的防火墙管理工具,如果您使用的是其他操作系统或防火墙管理工具,需要修改相应的命令。此外,为了方便起见,上述代码没有进行输入合法性的检查,实际使用时需要根据具体情况进行修改。
通过shell执行脚本执行netstat查看端口,并清理该端口
可以编写一个脚本来实现这个任务。以下是一个简单的示例:
```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
```
在命令行中执行该脚本,输入要清理的端口号,它会自动查找该端口是否在监听状态,如果是,则杀掉相关进程,否则输出无需清理的信息。