CentOS7查看和关闭防火墙,查看端口占用情况netstat -apn | grep 8080

本文详细介绍了在CentOS7系统中配置firewalld防火墙的方法,包括更新系统、安装及启用防火墙、添加特定端口和服务规则、查看防火墙状态等关键步骤。

CentOS 7默认使用的是firewall作为防火墙

查看防火墙状态

firewall-cmd --state
  • 停止firewall
systemctl stop firewalld.service
  • 禁止firewall开机启动
systemctl disable firewalld.service 

查看端口占用情况

netstat -apn | grep 8080  

 

 

阿里云ECS服务器CentOS7防火墙firewalld设置

使用root登录

1.确保服务器系统处于最新状态
[root@localhost ~]# yum -y update
如果显示以下内容说明已经更新完成
Complete!

2.重启服务器
[root@localhost ~]# reboot

3.安装防火墙
[root@localhost ~]# yum install firewalld

4.设置在开机时启用防火墙服务
[root@localhost ~]# systemctl enable firewalld.service

4.查看防火墙状态
[root@localhost ~]# systemctl status firewalld

5.启动防火墙
[root@localhost ~]# systemctl start firewalld

6.增加80端口到防火墙规则
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=80/tcp

7.增加3306端口到防火墙规则
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=3306/tcp

8.增加21端口到防火墙规则
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=21/tcp

9.增加33000端口到防火墙规则
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=33000-33003/tcp

10.设置HTTP协议服务被允许
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-service=http

11.使最新的防火墙设置规则生效
[root@localhost ~]# firewall-cmd --reload

12.重启防火墙服务
[root@localhost ~]# systemctl restart firewalld.service


firewalld的基本使用

使最新的防火墙设置规则生效

[root@localhost ~]# firewall-cmd --reload

查询ssh协议服务是否被允许

[root@localhost ~]# firewall-cmd --zone=public --query-service=ssh

查询HTTP协议服务是否被允许

[root@localhost ~]# firewall-cmd --zone=public --query-service=http

启动

[root@localhost ~]# systemctl start firewalld

查看状态

[root@localhost ~]# systemctl status firewalld

停止

[root@localhost ~]# systemctl disable firewalld

禁用

[root@localhost ~]# systemctl stop firewalld

#启动服务
[root@localhost ~]# systemctl start firewalld.service

关闭服务

[root@localhost ~]# systemctl stop firewalld.service

重启服务

[root@localhost ~]# systemctl restart firewalld.service

显示一个服务的状态

[root@localhost ~]# systemctl status firewalld.service

在开机时启用一个服务

[root@localhost ~]# systemctl enable firewalld.service

在开机时禁用一个服务

[root@localhost ~]# systemctl disable firewalld.service

查看服务是否开机启动

[root@localhost ~]# systemctl is-enabled firewalld.service

查看已启动的服务列表

[root@localhost ~]# systemctl list-unit-files|grep enabled

查看启动失败的服务列表

[root@localhost ~]# systemctl --failed

查看版本

[root@localhost ~]# firewall-cmd --version

查看帮助

[root@localhost ~]# firewall-cmd --help

显示状态

[root@localhost ~]# firewall-cmd --state

查看所有打开的端口

[root@localhost ~]# firewall-cmd --zone=public --list-ports

更新防火墙规则

[root@localhost ~]# firewall-cmd --reload

查看区域信息

[root@localhost ~]# firewall-cmd --get-active-zones

查看指定接口所属区域

[root@localhost ~]# firewall-cmd --get-zone-of-interface=eth0

拒绝所有包

[root@localhost ~]# firewall-cmd --panic-on

取消拒绝状态

[root@localhost ~]# firewall-cmd --panic-off

查看是否拒绝

[root@localhost ~]# firewall-cmd --query-panic

端口添加(–permanent永久生效,没有此参数重启后失效)

[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=80/tcp

使最新的防火墙设置规则生效

[root@localhost ~]# firewall-cmd --reload

查看80端口

[root@localhost ~]# firewall-cmd --zone=public --query-port=80/tcp

删除80端口

[root@localhost ~]# firewall-cmd --permanent --zone=public --remove-port=80/tcp

删除21端口

[root@localhost ~]# firewall-cmd --permanent --zone=public --remove-port=21/tcp

删除HTTP协议服务

[root@localhost ~]# firewall-cmd --permanent --zone=public --remove-service=http

增加3306端口到防火墙规则tcp

[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=3306/tcp

增加3306端口到防火墙规则udp

[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=3306/udp

查看当前的区域

[root@localhost ~]# firewall-cmd --get-default-zone

查看当前的服务

[root@localhost ~]# firewall-cmd --zone=public --list-services

安装图形化用户接口工具 firewall-config,则以 root 用户身份运行下列命令

[root@localhost ~]# yum install firewall-config

检查防火墙版本

[root@localhost ~]# firewall-cmd --version

查看帮助

[root@localhost ~]# firewall-cmd --help

 

<think> 我们正在解答用户的问题:使用`netstat –lnpt |grep 80`命令查看80端口是否被监听的原理、使用方法及结果解读 注意:用户要求使用中文回答,并按照示例格式(包括数学公式的格式要求)来组织答案。同时,需要生成相关问题。 根据用户提供的引用资料,我们可以总结如下: 引用[1]:netstat -l 可以显示监听端口 引用[2]:在CentOS7中,netstat命令需要安装net-tools,使用`netstat -lnpt |grep 端口号`可以检查端口被哪个进程占用 引用[3]:详细解释了netstat的常用参数,并给出了示例 引用[4]:展示了使用`netstat -lntp`查看监听端口情况 因此,我们将围绕`netstat –lnpt |grep 80`这个命令展开。 注意:在命令中,用户使用了`–`(长破折号),但实际上应该是短横线(-)。我们按照正确的命令`netstat -lnpt | grep 80`来讲解。 </think>### `netstat -lnpt | grep 80` 命令详解 #### 一、命令原理 1. **`netstat` 功能** 网络统计工具,用于显示网络连接、路由表、接口统计等信息[^1][^3]。其参数组合: - `-l`:仅显示**监听状态**的套接字(LISTEN) - `-n`:禁用域名解析,直接显示**IP端口号** - `-p`:显示**进程ID程序名** - `-t`:仅显示**TCP协议**连接 2. **`grep 80` 作用** 过滤输出结果,只保留包含 `80` 的行(即80端口相关连接) 3. **数学表示** 命令逻辑可形式化为: $$ \text{output} = \left\{ (s, p) \mid s \in S_{\text{netstat}}, \, p \in P_{80} \right\} $$ 其中: - $S_{\text{netstat}}$ 是 `netstat -lnpt` 的输出集合 - $P_{80}$ 是包含端口80的条目集合 --- #### 二、使用方法 ```bash sudo netstat -lnpt | grep ':80\b' ``` - **必须使用sudo**:普通用户无法查看系统进程信息[^2] - **关键参数**: - `-lnpt` 等效于 `-l -n -p -t` 的组合 - `:80\b` 确保精确匹配80端口(避免匹配8080端口- **输出示例**: ``` tcp6 0 0 :::80 :::* LISTEN 1234/nginx ``` 字段说明: 1. `tcp6`:协议类型(IPv6 TCP) 2. `:::80`:监听地址(`::`表示所有IPv6地址) 3. `:::*`:远程地址(`*`表示接受任意来源) 4. `LISTEN`:连接状态 5. `1234/nginx`:进程ID/程序名 --- #### 三、结果解读 | 输出结果 | 含义 | 后续操作 | |---------|------|---------| | **有输出** | 80端口已被监听 | 检查进程名是否预期(如nginx/apache) | | **无输出** | 80端口未被占用 | 可安全启动新服务 | | **权限拒绝** | 需sudo权限 | 重新执行`sudo netstat...`[^2] | | **命令不存在** | 需安装net-tools | 执行`yum install net-tools`[^2] | **特殊案例**: 1. **多进程监听**:可能显示多行结果(如Nginx+PHP-FPM) 2. **非Web服务**:若显示`python/java`等,需检查是否恶意程序 3. **仅IPv6监听**:输出为`tcp6`时,需检查IPv4兼容性 --- #### 四、替代方案对比 | 方法 | 优势 | 劣势 | |------|------|------| | `netstat -lnpt` | 兼容性高(支持旧系统) | 需安装net-tools[^2] | | `ss -ltnp` | 执行速度更快 | 部分系统无预装 | | `lsof -i:80` | 直接显示文件句柄 | 输出格式较复杂 | > **推荐**:生产环境优先使用 `ss -ltnp sport = :80`[^3],其性能更优 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值