系统环境:
3台服务器,或者开虚拟机吧!我就是开虚拟机实现的。
ip分别为:192.168.1.10 192.168.1.11 192.168.1.12
环境:安装了ngixn 没有做任何配置
3台服务器环境最好一样。
192.168.1.10 作为 负载均衡服务器 (一会负载均衡就在这里台服务器做配置,另外2台不用做配置)
nginx 的 upstream目前支持 4 种方式的分配
1)、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)、weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
2)、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
3)、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
4)、url_hash(第三方)
打开192.168.1.10 的nginx.conf 只需要在配置文件增加如下代码
server 192.168.1.11:80;
server 192.168.1.12:80;
}
server {
listen 80;
server_name www.;
location / {
proxy_pass http://www.;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
access_log logs/access_log;
error_log logs/error_log;
}
实践结果:
http://www. 通过修改host 指向了 192.168.1.10
修改ngixn默认页面的html
vi /usr/local/nginx/html/index.html
再index.html 加入显示本机ip
192.168.1.11 和 192.168.1.12 。
通过本机浏览器,输入 http://www.,进行测试。
每次刷新,都会跳转到不同的服务器上页面。
如下图:
一,nginx的停止操作
停止操作是通过向nginx进程发送信号来实现的。
步骤1:查询nginx主进程号
在进程列表里 面找master进程,它的编号就是主进程号了。
步骤2:发送信号
从容停止Nginx:
kill -QUIT 主进程号
快速停止Nginx:
kill -TERM 主进程号
强制停止Nginx:
另外, 若在nginx.conf配置了pid文件存放路径则该文件存放的就是Nginx主进程号,如果没指定则放在nginx的logs目录下。有了pid文 件,我们就不用先查询Nginx的主进程号,而直接向Nginx发送信号了,命令如下:
二,nginx的平滑重启
如果更改了配置就要重启Nginx,要先关闭Nginx再打开?不是的,可以向Nginx 发送信号,平滑重启。
平滑重启命令:
或使用
/usr/nginx/sbin/nginx -s reload
注意,修改了配置文件后最好先检查一下修改过的配置文件是否正 确,以免重启后Nginx出现错误影响服务器稳定运行。判断Nginx配置是否正确命令如下:
或者
/usr/nginx/sbin/nginx -t
三,nginx的平滑升级
如果服务器正在运行的Nginx要进行升级、添加或删除模块时,我们需 要停掉服务器并做相应修改,这样服务器就要在一段时间内停止服务,Nginx可以在不停机的情况下进行各种升级动作而不影响服务器运行。
步骤1:
若升级Nginx程序,先用新程序替换旧程序文件,编译安装的话新程序直接编译到Nginx安装目录中。
步 骤2:执行命令
kill -USR2 旧版程序的主进程号或进程文件名
此时旧的Nginx主进程将会把自己的进程文件改名为.oldbin,然后执行新版 Nginx。新旧Nginx会同市运行,共同处理请求。
这时要逐步停止旧版 Nginx,输入命令:
kill -WINCH 旧版主进程号
慢慢旧的工作进程就都会随着任务执行完毕而退出,新版的Nginx的工作进程会逐渐取代旧版 工作进程。
可以决定使用新版还是恢复到旧版。
四,不重载配置启动新/旧工作进程
kill -HUP 旧/新版主进程号
从容关闭旧/新进程
kill -QUIT 旧/新主进程号
如果此时报错,提示还有进程没有结束就用下面命令先关闭旧/新工作进程,再关闭主进程号:
kill -TERM 旧/新工作进程号
这样下来,如果要恢复到旧版本,只需要上面的几个步 骤都是操作新版主进程号,如果要用新版本就上面的几个步骤都操作旧版主进程号就行了。
上面就是Nginx的一些基本的操作,希望以后Nginx能有更好的方法来处理这些操作, 最好是Nginx的命令而不是向Nginx进程发送系统信号。
在阿里云服务器上,进程性的 nginx -s stop后再次启动nginx -s reload ,总是会报错误nginx: [error] open() "/alidata/server/nginx/logs/nginx.pid" failed (2: No such file or directory)。
原因:nginx进程杀死后pid丢失了,下一次再开启nginx -s reload时无法启动,重装可以解决问题,做不做,你决定吧,哈哈。
还是英文的解释比较专业:
issued a nginx -s stop and after that I got this error when trying to reload it.
[error]: invalid PID number "" in "/var/run/nginx.pid"
That /var/run/nginx/pid file is empty atm.
What do I need to do to fix it?
nginx -s reload is only used to tell a running nginx process to reload its config. After a stop, you don't have a running nginx process to send a signal to. Just run nginx (possibly with a -c /path/to/config/file)
使用方法:
//我的机器是这样:/alidata/server/nginx/sbin/nginx -c /alidata/server/nginx/conf/nginx.conf
这里首先要说明的是:
nginx属于七层架构,支持的是http协议,本身对tcp协议没有支持。
所以不能代理mysql等实现负载均衡。
以下介绍的实现方法,需要借助nginx的模块nginx_tcp_proxy_module来实现。
1,下载module模块
下载地址 : https://nodeload.github.com/yaoweibin/nginx_tcp_proxy_module/zipball/master
$ tar -xzvf nginx-1.2.1.tar.gz
$ cd nginx-1.2.1/
$ patch -p1 < /path/to/nginx_tcp_proxy_module/tcp.patch /path是指nginx_tcp_proxy_module路径
$ ./configure --add-module=/usr/local/ngx_cache_purge-1.4 --prefix=/usr/local/nginx --with-http_stub_status_module --add-module=/path/to/nginx_tcp_proxy_module //编译
$ make
$ make install
2,修改nginx配置文件:
server {
listen 80;
location /status {
check_status;
}
}
}
tcp {
upstream mysql{
server 10.10.10.17:3306 weight=1;
server 10.10.10.18:3306 weight=1;
#check interval=3000 rise=2 fall=5 timeout=1000;
}
server {
listen 3306;
proxy_pass mysql;
}
}
启动nginx进没测试,log信息如下:
2013/8/26 18:22:32 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:32 10.10.10.17:3306 1446 4383
2013/8/26 18:22:33 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:32 10.10.10.18:3306 1447 4383
2013/8/26 18:22:33 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:33 10.10.10.17:3306 1445 4383
2013/8/26 18:22:34 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:33 10.10.10.18:3306 1445 4383
2013/8/26 18:22:34 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:34 10.10.10.17:3306 1446 4383
2013/8/26 18:22:35 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:34 10.10.10.18:3306 1445 4383
2013/8/26 18:22:35 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:35 10.10.10.17:3306 1445 4383
2013/8/26 18:22:36 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:35 10.10.10.18:3306 1445 4383
2013/8/26 18:22:37 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:36 10.10.10.17:3306 1446 4383
2013/8/26 18:22:37 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:37 10.10.10.18:3306 1446 4383
2013/8/26 18:22:37 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:37 10.10.10.17:3306 1445 4383
2013/8/26 18:22:38 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:37 10.10.10.18:3306 1444 4383
2013/8/26 18:22:39 [3921] 10.10.10.107 0.0.0.0:3306 2013/8/26 18:22:38 10.10.10.17:3306 1445 4383