• Centos防火墙设置与端口开放


    前言

    最近在部署项目的时候遇到了一些问题,阿里云主机要配置安全组策略和端口。对于这点看到了一片好的博文,特此总结记录下。

    iptables
    • 方法一

      打开某个端口

      // 开启端口
      iptables -A INPUT -p tcp --dport 8080 -j ACCEPT 
      // 保存并重启防火墙
      /etc/rc.d/init.d/iptables save
      /etc/init.d/iptables restart
      

      打开8444~9666之间的端口

      iptables -A INPUT -p tcp --dport 49152:65534 -j ACCEPT 
      // 保存并重启防火墙
      /etc/rc.d/init.d/iptables save
      /etc/init.d/iptables restart
      

      查看打开的端口

      /etc/init.d/iptables status
      
    • 方法二

      // 修改/etc/sysconfig/iptables文件的方式开启端口
      vi /etc/sysconfig/iptables
      // 在文中添加一行
      -A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 8080 -j ACCEPT
      

    参数说明

    –A 参数就看成是添加一条规则
    –p 指定是什么协议,我们常用的tcp 协议,当然也有udp,例如53端口的DNS
    –dport 就是目标端口,当数据从外部进入服务器为目标端口
    –sport 数据从服务器出去,则为数据源端口使用
    –j 就是指定是 ACCEPT -接收 或者 DROP 不接收
    

    打开/关闭/重启防火墙

    开启防火墙(重启后永久生效):chkconfig iptables on
    关闭防火墙(重启后永久生效):chkconfig iptables off
    开启防火墙(即时生效,重启后失效):service iptables start
    关闭防火墙(即时生效,重启后失效):service iptables stop
    重启防火墙:service iptables restartd
    
    firewalld

    Centos7默认安装了firewalld,如果没有安装的话,可以使用 yum install firewalld firewalld-config进行安装

    • 启动防火墙

      systemctl start firewalld 
      
    • 禁用防火墙

    systemctl stop firewalld
    
    • 设置开机启动
    systemctl enable firewalld
    
    • 停止并禁用开机启动
    sytemctl disable firewalld
    
    • 重启防火墙 *
    firewall-cmd --reload
    
    • 查看状态 *
    systemctl status firewalld或者 firewall-cmd --state
    
    • 查看版本 *
    firewall-cmd --version
    
    • 查看帮助
    firewall-cmd --help
    
    • 查看区域信息
    firewall-cmd --get-active-zones
    
    • 查看指定接口所属区域信息
    firewall-cmd --get-zone-of-interface=eth0
    
    • 拒绝所有包
    firewall-cmd --panic-on
    
    • 取消拒绝状态
    firewall-cmd --panic-off
    
    • 查看是否拒绝
    firewall-cmd --query-panic
    
    • 将接口添加到区域(默认接口都在public)
    firewall-cmd --zone=public --add-interface=eth0(永久生效再加上 --permanent 然后reload防火墙)
    
    • 设置默认接口区域
    firewall-cmd --set-default-zone=public(立即生效,无需重启)
    
    • 更新防火墙规则
    firewall-cmd --reload或firewall-cmd --complete-reload
    (两者的区别就是第一个无需断开连接,就是firewalld特性之一动态添加规则,第二个需要断开连接,类似重启服务)
    
    • 查看指定区域所有打开的端口 *
    firewall-cmd --zone=public --list-ports
    
    • 在指定区域打开端口 *
    firewall-cmd --zone=public --add-port=80/tcp(永久生效再加上 --permanent)
    

    说明

    –zone 作用域
    –add-port=8080/tcp 添加端口,格式为:端口/通讯协议
    –permanent #永久生效,没有此参数重启后失效
    
    参考

    https://havee.me/linux/2015-01/using-firewalls-on-centos-7.html

    https://blog.csdn.net/u011846257/article/details/54707864#commentBox

    https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/security_guide/sec-using_firewalls

    https://fedoraproject.org/wiki/Firewalld?rd=FirewallD

  • 相关阅读:
    判断字符串是否为空
    NameVirtualHost *:80 has no VirtualHosts
    angular笔记
    Angular *ngIf length
    angular 8 表单带文件上传接口
    angular8 大地老师学习笔记---第十课
    angular8 大地老师学习笔记---第九课
    angular8 大地老师学习笔记---第八课
    angular8 大地老师学习笔记---第六课
    记录一下网上找到的别人写的angualr总结
  • 原文地址:https://www.cnblogs.com/TomAndJerry/p/11756289.html
Copyright © 2020-2023  润新知