4 Nginx 反向代理
4.6 Nginx 的四层代理和负载均衡
Nginx在1.9.0版本开始支持tcp模式的负载均衡,在1.9.13版本开始支持udp协议的负载,udp主要用于DNS的域名解析,其配置方式和指令和http 代理类似,其基于ngx_stream_proxy_module模块实现tcp负载,另外基于模块ngx_stream_upstream_module实现后端服务器分组转发、权重分配、状态监测、调度算法等高级功能
如果编译安装,需要指定 --with-stream 选项才能支持ngx_stream_proxy_module模块
http://nginx.org/en/docs/stream/ngx_stream_proxy_module.html # 非http协议的反向代理
https://nginx.org/en/docs/stream/ngx_stream_upstream_module.html # 非http协议的负载均衡
4.6.2 实现TCP协议的反向代理
角色 |
IP |
Client |
10.0.0.208 |
Proxy Server |
10.0.0.206 |
Mysql Server |
10.0.0.210 |
Redis Server |
10.0.0.159 |
#10.0.0.206 Proxy Server 配置,此配置要写在最外层
stream {
server {
listen 3306;
proxy_pass 10.0.0.210:3306;
}
server {
listen 6379;
proxy_pass 10.0.0.159:6379;
}
}
#10.0.0.210 安装mysql-server,并配置远程用户
[root@ubuntu ~]# apt update;apt install mysql-server
mysql> create user proxyer@'10.0.0.%' identified by '123456';
Query OK, 0 rows affected (0.01 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
#当前mysql-server 只监听了本机的3306
[root@ubuntu ~]# ss -tnlp | grep 3306
LISTEN 0 70 127.0.0.1:33060 0.0.0.0:* users: (("mysqld",pid=2461,fd=21))
LISTEN 0 151 127.0.0.1:3306 0.0.0.0:* users: (("mysqld",pid=2461,fd=23))
#修改配置,注释掉这两行
[root@ubuntu ~]# vim /etc/mysql/mysql.conf.d/mysqld.cnf
#bind-address = 127.0.0.1
#mysqlx-bind-address = 127.0.0.1
skip-name-resolve #添加此行,跳过主机名反解
#重启服务
[root@ubuntu ~]# systemctl restart mysql.service
[root@ubuntu ~]# ss -tnlp | grep 3306
LISTEN 0 70 *:33060 *:* users: (("mysqld",pid=3928,fd=21))
LISTEN 0 151 *:3306 *:* users: (("mysqld",pid=3928,fd=23))
#10.0.0.159 安装redis-server
[root@ubuntu ~]# apt update;apt install redis-server
#当前只监听了127.1
[root@ubuntu ~]# ss -tnlp | grep 6379
LISTEN 0 511 127.0.0.1:6379 0.0.0.0:* users:(("redisserver",pid=2153,fd=6))
LISTEN 0 511 [::1]:6379 [::]:* users:(("redisserver",pid=2153,fd=7))
#修改配置并重启
[root@ubuntu ~]# vim /etc/redis/redis.conf
#bind 127.0.0.1 ::1
protected-mode no #关闭保护模式
[root@ubuntu ~]# systemctl restart redis-server.service
[root@ubuntu ~]# ss -tnlp | grep 6379
LISTEN 0 511 0.0.0.0:6379 0.0.0.0:* users:(("redisserver",pid=2480,fd=7))
LISTEN 0 511 [::]:6379 [::]:* users:(("redisserver",pid=2480,fd=6))
#客户端配置,并测试
[root@ubuntu ~]# apt update
[root@ubuntu ~]# apt install mysql-client-8.0 redis
#直连测试
[root@ubuntu ~]# mysql -h 10.0.0.210 -uproxyer -p'123456'
#在mysql 服务端查看,客户端直连
mysql> show processlist\G
*************************** 2. row ***************************
Id: 9
User: proxyer
Host: 10.0.0.208:42714
db: NULL
Command: Sleep
Time: 358
State:
Info: NULL
#redis 测试,客户端直连
[root@ubuntu ~]# redis-cli -h 10.0.0.159
#服务端查看
[root@ubuntu ~]# ss -tnep| grep 6379
FIN-WAIT-2 0 0 10.0.0.159:6379 10.0.0.208:39838 timer: (timewait,43sec,0) ino:0 sk:1004
#代理测试
[root@ubuntu ~]# mysql -h 10.0.0.206 -uproxyer -p'123456'
#是代理服务器在连mysql-server
mysql> show processlist\G
*************************** 1. row ***************************
Id: 12
User: proxyer
Host: 10.0.0.206:49452
db: NULL
Command: Query
Time: 0
State: init
Info: show processlist
1 row in set, 1 warning (0.00 sec)
#redis 测试
[root@ubuntu ~]# redis-cli -h 10.0.0.206
10.0.0.206:6379> keys *
(empty array)
10.0.0.206:6379> set test 123
OK
10.0.0.206:6379> keys *
1) "test"
4.6.3 实现TCP协议的负载均衡
#10.0.0.206 Proxy Server 配置,此配置要写在最外层
stream {
upstream mysql {
server 10.0.0.210:3306;
server 10.0.0.159:3306;
}
upstream redis {
server 10.0.0.210:6379;
server 10.0.0.159:6379;
}
server {
listen 3306;
proxy_pass mysql;
}
server {
listen 6379;
proxy_pass redis;
}
}