nginx使用stream模块反向代理mysql

前言

在一个项目中需要与另一个团队配合,读写他们的数据库,但是由于客户那边的网络权限问题,这我们无法直接访问个数据库所在的服务器,因此通过一台两边都能访问的服务器作为反向代理服务器,使用nginx进行反向代理。

步骤

1、修改配置

vi nginx.conf

末尾添加

stream {
    include /usr/nginx/stream.conf;
}

编辑stream.conf

vi /usr/nginx/stream.conf

server {
    listen  50001;
    proxy_timeout   525600m; //两个成功的读或写操作之间的间隔时间,超出这个时间连接会关闭。这里设置为1年
    proxy_pass  1xx.xx.3.4:3306;
}

这里曾遇到一个坑,因为没有配置proxy_timeout ,默认为10m。应用超过10分钟没有数据库操作,nginx会关闭这个server,下次访问就会报错
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure。

2、检查配置是否可用

/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf

3、平滑更新nginx配置

查看nginx的pid

ps -ef |grep nginx
kill -HUP pid 

完成。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值