云服务器ECS配置 (一)防火墙firewall 开放端口 查看端口占用

阿里云ECS相关(一) 防火墙firewall 与开放端口认识

一、端口号的范围是从1~65535。

其中1~1024是被RFC 3232规定好了的,被称作“众所周知的端口”(Well Known Ports);

从1025~65535的端口被称为动态端口(Dynamic Ports),可用来建立与其它主机的会话,也可由用户自定义用途。

一些常见的端口号及其用途如下:

- 21端口:FTP 文件传输服务
- 22端口:SSH 端口
- 23端口:TELNET 终端仿真服务
- 25端口:SMTP 简单邮件传输服务
- 53端口:DNS 域名解析服务
- 80端口:HTTP 超文本传输服务
- 110端口:POP3 “邮局协议版本3”使用的端口
- 443端口:HTTPS 加密的超文本传输服务
- 1433端口:MS SQL*SERVER数据库 默认端口号
- 1521端口:Oracle数据库服务
- 1863端口:MSN Messenger的文件传输功能所使用的端口
- 3306端口:MYSQL 默认端口号
- 3389端口:Microsoft RDP 微软远程桌面使用的端口
- 5631端口:Symantec pcAnywhere 远程控制数据传输时使用的端口
- 5632端口:Symantec pcAnywhere 主控端扫描被控端时使用的端口
- 5000端口:MS SQL Server使用的端口
- 8000端口:腾讯QQ
二、服务器如何开通一个端口

指定IP 参见: https://my.oschina.net/u/4984817/blog/5593149

1. 首先

1-1. 如果您使用的是云服务器ECS需要在安全组中放行需要开通的端口,操作方法请参考:添加安全组规则 。

1-1-1. 阿里云ECS 安全组是分地区和实例的。华北(北京),华东(杭州) 两个安全组是不互通的, focus项目时,开放了1955测试端口,curl http:xxx 一直访问不了原因:

  • 一开始 只开放了firewall-cmd 级别的端口,没有想到云ECS有安全组
  • 之后想到 有安全组,配置了安全规则 1955/1955,依然访问不通。
  • 安全组选错了杭州的,北京的安全组没有配置开放 1955/1955

1-2. 如果您使用的是轻量应用服务器,需要在防火墙中放行需要开通的端口,操作方法请参考:轻量应用服务器防火墙 。

2. 其次,

您需要在服务器内部确保对应的服务已经启动,并且监听了需要开通的端口,以下以80端口为例:

  • Linux系统可以通过执行 netstat -nupl | grep 80 的命令查看对应端口是否是监听的listen状态。
  • Windows系统可以通过执行 netstat -ano | findstr 80 命令查看端口是否监听状态 LISTEN 。
最后,您还需要在服务器内部的防火墙里确保对应端口已开放。

Linux系统常见的防火墙有 iptables、firewalld等,Windows系统常见的防火墙有 Windows防火墙、安全狗等。

以上三点确认无误后,请再测试端口是否可以正常连接。
如果依然访问不通,参考上面 focus 错误排查

附: 测试nginx启动成功 代理端口生效 小方法 nginx status
    location /ngx_status {
        stub_status on;
        access_log on;
        #allow 127.0.0.1;
        #deny all;
    }
三、配置firewalld 新用的防火墙软件
实例
# =============== 安装firewalld ===============
yum install firewalld firewall-config

systemctl start  firewalld # 启动
systemctl status firewalld # 或者 firewall-cmd --state 查看状态
systemctl disable firewalld # 停止
systemctl stop firewalld  # 禁用

# =============== 配置 ===============
firewall-cmd --version  # 查看版本
firewall-cmd --help     # 查看帮助

# 查看设置:
firewall-cmd --state  # 显示状态
firewall-cmd --get-active-zones  # 查看区域信息
firewall-cmd --get-zone-of-interface=eth0  # 查看指定接口所属区域
firewall-cmd --panic-on  # 拒绝所有包
firewall-cmd --panic-off  # 取消拒绝状态
firewall-cmd --query-panic  # 查看是否拒绝

firewall-cmd --reload # 更新防火墙规则
firewall-cmd --complete-reload
# 两者的区别就是第一个无需断开连接,就是firewalld特性之一动态添加规则,第二个需要断开连接,类似重启服务


# 将接口添加到区域,默认接口都在public
firewall-cmd --zone=public --add-interface=eth0
# 永久生效再加上 --permanent 然后reload防火墙

# 设置默认接口区域,立即生效无需重启
firewall-cmd --set-default-zone=public

# 查看所有打开的端口:
firewall-cmd --zone=dmz --list-ports

# 加入一个端口到区域:
firewall-cmd --zone=dmz --add-port=8080/tcp
# 若要永久生效方法同上

# 打开一个服务,类似于将端口可视化,服务需要在配置文件中添加,/etc/firewalld 目录下有services文件夹,这个不详细说了,详情参考文档
firewall-cmd --zone=work --add-service=smtp

# 移除服务
firewall-cmd --zone=work --remove-service=smtp

# 显示支持的区域列表
firewall-cmd --get-zones

# 设置为家庭区域
firewall-cmd --set-default-zone=home

# 查看当前区域
firewall-cmd --get-active-zones

# 显示当前区域的接口
firewall-cmd --get-zone-of-interface=enp03s

# 显示所有公共区域(public)
firewall-cmd --zone=public --list-all

# 临时修改网络接口(enp0s3)为内部区域(internal)
firewall-cmd --zone=internal --change-interface=enp03s

# 永久修改网络接口enp03s为内部区域(internal)
firewall-cmd --permanent --zone=internal --change-interface=enp03s
服务管理
# 显示服务列表  
Amanda, ftp, Samba和tftp等最重要的服务已经被FirewallD提供相应的服务,可以使用如下命令查看:

firewall-cmd --get-services

# 允许ssh服务通过(注:在 0.9.4 版本的firewalld上,不存在--enable 或 --disable 参数来开关服务。
)
firewall-cmd --enable service=ssh

# 禁止SSH服务通过
firewall-cmd --disable service=ssh

# 打开TCP的8080端口
firewall-cmd --enable ports=8080/tcp

# 临时允许Samba服务通过600秒
firewall-cmd --enable service=samba --timeout=600

# 显示当前服务
firewall-cmd --list-services

# 添加HTTP服务到内部区域(internal)
firewall-cmd --permanent --zone=internal --add-service=http
firewall-cmd --reload     # 在不改变状态的条件下重新加载防火墙

端口管理

# 打开443/TCP端口
firewall-cmd --add-port=443/tcp

# 永久打开3690/TCP端口
firewall-cmd --permanent --add-port=3690/tcp

# 永久打开端口好像需要reload一下,临时打开好像不用,如果用了reload临时打开的端口就失效了
# 其它服务也可能是这样的,这个没有测试
firewall-cmd --reload

# 查看防火墙,添加的端口也可以看到
firewall-cmd --list-all
控制端口 / 服务

可以通过两种方式控制端口的开放,一种是指定端口号另一种是指定服务名。虽然开放 http 服务就是开放了 80 端口,但是还是不能通过端口号来关闭,也就是说通过指定服务名开放的就要通过指定服务名关闭;通过指定端口号开放的就要通过指定端口号关闭。还有一个要注意的就是指定端口的时候一定要指定是什么协议,tcp 还是 udp。知道这个之后以后就不用每次先关防火墙了,可以让防火墙真正的生效。

firewall-cmd --add-service=mysql        # 开放mysql端口
firewall-cmd --remove-service=http      # 阻止http端口
firewall-cmd --list-services            # 查看开放的服务
firewall-cmd --add-port=3306/tcp        # 开放通过tcp访问3306
firewall-cmd --remove-port=80tcp        # 阻止通过tcp访问3306
firewall-cmd --add-port=233/udp         # 开放通过udp访问233
firewall-cmd --list-ports               # 查看开放的端口
伪装 IP
firewall-cmd --query-masquerade # 检查是否允许伪装IP
firewall-cmd --add-masquerade   # 允许防火墙伪装IP
firewall-cmd --remove-masquerade# 禁止防火墙伪装IP
端口转发

端口转发可以将指定地址访问指定的端口时,将流量转发至指定地址的指定端口。转发的目的如果不指定 ip 的话就默认为本机,如果指定了 ip 却没指定端口,则默认使用来源端口。 如果配置好端口转发之后不能用,可以检查下面两个问题:

  1. 比如我将 80 端口转发至 8080 端口,首先检查本地的 80 端口和目标的 8080 端口是否开放监听了
  2. 其次检查是否允许伪装 IP,没允许的话要开启伪装 IP
firewall-cmd --add-forward-port=port=80:proto=tcp:toport=8080   # 将80端口的流量转发至8080
firewall-cmd --add-forward-port=port=80:proto=tcp:toaddr=192.168.0.1 # 将80端口的流量转发至192.168.0.1
firewall-cmd --add-forward-port=port=80:proto=tcp:toaddr=192.168.0.1:toport=8080 # 将80端口的流量转发至192.168.0.1的8080端口

当我们想把某个端口隐藏起来的时候,就可以在防火墙上阻止那个端口访问,然后再开一个不规则的端口,之后配置防火墙的端口转发,将流量转发过去。

端口转发还可以做流量分发,一个防火墙拖着好多台运行着不同服务的机器,然后用防火墙将不同端口的流量转发至不同机器。

阿里云ECS 相关 (二)

安全组
1. 开放3306端口给指定的IP

1-1. 如何获取自己的公网IP

1-2. 服务器内部防火墙放行这个规则

命令详细参见: https://my.oschina.net/u/4984817/blog/5592875

[root@iZ2ze6m4la2xm5wzpt7126Z ~]# firewall-cmd --list-ports 

20/tcp 21/tcp 22/tcp 80/tcp 443/tcp 1955/tcp 8080/tcp 8081/tcp 8082/tcp 8811/tcp 8888/tcp 8899/tcp 39000-40000/tcp 8080/udp 8081/udp 8082/udp 8811/udp 8899/udp

[root@iZ2ze6m4la2xm5wzpt7126Z ~]# firewall-cmd --add-port=3306/tcp --permanent --zone=public 
success
[root@iZ2ze6m4la2xm5wzpt7126Z ~]# firewall-cmd --reload 
success
[root@iZ2ze6m4la2xm5wzpt7126Z ~]# firewall-cmd --list-ports 

20/tcp 21/tcp 22/tcp 80/tcp 443/tcp 1955/tcp 3306/tcp 8080/tcp 8081/tcp 8082/tcp 8811/tcp 8888/tcp 8899/tcp 39000-40000/tcp 8080/udp 8081/udp 8082/udp 8811/udp 8899/udp
[root@iZ2ze6m4la2xm5wzpt7126Z ~]# 
1-3. 登录mysql 创建新账号,授权远程登录 %
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
FLUSH PRIVILEGES;
2. 设置…
<think>嗯,用户问的是如何在阿里云服务器上安装ws库。首先,我需要确定ws库指的是什么。在Node.js环境中,常用的WebSocket库是ws,所以用户可能是指这个。接下来,我要考虑阿里云服务器的操作系统,般常见的是Linux,比如Ubuntu或CentOS,所以步骤可能需要分不同系统来写,不过有时候可以统处理,比如使用npm安装的话,可能步骤差不多。 用户可能已经有定的服务器操作基础,但可能不太熟悉Node.js环境的配置。所以需要从安装Node.js和npm开始。首先,需要确认系统是否已经安装了Node.js和npm,如果没有的话,就需要先安装。对于不同的Linux发行版,安装方法可能不同,比如Ubuntu使用apt,CentOS使用yum或者dnf。 然后,使用npm全局安装还是项目内安装ws库。般情况下,如果是项目依赖,建议在项目目录下安装,但用户可能需要全局安装,所以需要给出两种选项。此外,可能需要提到权限问题,比如使用sudo或者在用户目录下配置npm全局路径,避免权限错误。 另外,用户可能在使用过程中遇到防火墙问题,比如阿里云的安全组配置没有开放WebSocket使用的端口(比如8080),所以需要提醒用户检查安全组设置,放行相应端口。同时,服务器本地的防火墙(如ufw或firewalld)也需要配置,允许端口通过。 测试部分,提供个简单的WebSocket服务器示例是必要的,这样用户可以直接运行并检查是否安装成功。同时,说明如何通过客户端连接,比如使用浏览器开发者工具或者在线WebSocket测试工具,来验证服务是否正常运行。 可能还需要提到版本兼容性问题,建议用户安装LTS版本的Node.js,以确保ws库的兼容性。此外,如果用户使用的是其他环境,比如Python的ws库,可能需要进步澄清,但根据常见情况,先假设是Node.js的ws库。 最后,总结步骤,确保用户按照流程操作,从安装Node.js到配置防火墙,再到测试,每步都清晰。同时,提醒用户注意权限和路径问题,避免常见错误。</think>在阿里云服务器上安装Node.js的`ws`库(WebSocket库)的步骤如下: --- ### 、前置条件 1. **登录服务器** 使用SSH工具连接阿里云ECS实例: ```bash ssh root@your_server_ip # 替换为你的服务器IP ``` 2. **更新系统包** ```bash sudo apt update # Ubuntu/Debian # 或 sudo yum update # CentOS/RHEL ``` --- ### 二、安装Node.js环境(若未安装) 1. **通过NodeSource安装(推荐)** ```bash # Ubuntu/Debian curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash - sudo apt install -y nodejs # CentOS/RHEL curl -fsSL https://rpm.nodesource.com/setup_lts.x | sudo bash - sudo yum install -y nodejs ``` 2. **验证安装** ```bash node -v # 应输出类似 v18.x.x npm -v # 应输出类似 9.x.x ``` --- ### 三、安装`ws`库 1. **项目内安装(推荐)** ```bash mkdir my-ws-project && cd my-ws-project # 创建项目目录 npm init -y # 初始化package.json npm install ws # 安装ws库 ``` 2. **全局安装(可选)** ```bash sudo npm install -g ws # 可能需要管理员权限 ``` --- ### 四、验证安装 1. **创建测试文件** 新建文件 `server.js`,写入以下代码: ```javascript const WebSocket = require('ws'); const wss = new WebSocket.Server({ port: 8080 }); wss.on('connection', function connection(ws) { ws.on('message', function incoming(message) { console.log('Received: %s', message); }); ws.send('Connected to WebSocket server!'); }); console.log('WebSocket server running on port 8080'); ``` 2. **运行服务器** ```bash node server.js ``` 3. **测试连接** 通过浏览器开发者工具或在线WebSocket工具(如 https://websocket.org/tools/)连接: ```javascript const ws = new WebSocket('ws://your_server_ip:8080'); ``` --- ### 五、防火墙配置(关键步骤!) 1. **阿里云安全组规则** - 登录阿里云控制台 → 进入ECS实例 → 安全组 → 添加入方向规则: - 端口范围:`8080` - 授权对象:`0.0.0.0/0`(或指定IP) 2. **服务器本地防火墙** ```bash # Ubuntu/Debian (ufw) sudo ufw allow 8080 sudo ufw reload # CentOS/RHEL (firewalld) sudo firewall-cmd --permanent --add-port=8080/tcp sudo firewall-cmd --reload ``` --- ### 六、常见问题 1. **权限问题** - 若使用非root用户,需添加权限: ```bash sudo chown -R $(whoami) ~/.npm # 修复npm全局安装权限 ``` 2. **端口冲突** - 确保端口`8080`未被其他服务占用,或修改代码中的端口号。 --- **总结步骤**:安装Node.js → 创建项目 → 安装`ws` → 编写代码 → 开放端口 → 测试连接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值