前几天单位数据库挂了,虽说有从库,但告诉我,要修改配置文件,下午才能顶上来。
果然面对这样高科技的构架设计,我还是太年轻了。
刚巧最近学习了nginx,能不能用负载均衡办法迅速切换数据库呢?以前拿他玩过HTTP服务的代理,数据库这么搞行不行?
查了一下,nginx从1.9.0开始,新增加了一个stream模块,用来实现四层协议的转发、代理或者负载均衡等。四成协议转发是个什么鬼?没关系,支持HTTP代理和数据库的3306端口转发就行,OK,我的问题理论上解决了,动手。
nginx.conf配置文件里写了这么一段
stream {
upstream mysql_3306 {
server 154.10.18.221:3306 weight=10
server 154.10.18.220:3306 weight=10;
}
server {
listen 3307;
proxy_pass mysql_3306; # 从这里转发到 upstream
}
}
搞定了,但是在测试的时候就是不生效,
停止 nginx -s stop
重启 nginx -s reload
启动 start nginx
这几条命令敲了无数回,还专门查了,nginx配置文件修改后,重启 nginx -s reload就可以了,都没说服务器必须要重启。
没办法,准备放弃前最后的测试,重启了一下服务器,好了,代理生效了,NICE。
总结,nginx一般部署在Linux的系统上,配置修改不需要重启服务器,但在windows服务器,特别是2012R2上 ,一定要记得重启。(为什么要用window服务器,因为我菜呀,centos的系统不会用呀)