当前位置:  操作系统/服务器>linux
本页文章导读:
    ▪nginx 配置轮询分流 实现负载均衡的方法      系统环境: 3台服务器,或者开虚拟机吧!我就是开虚拟机实现的。 ip分别为:192.168.1.10  192.168.1.11  192.168.1.12 环境:安装了ngixn 没有做任何配置 3台服务器环境最好一样。 192.168.1.10  作.........
    ▪重启nginx后丢失nginx.pid的解决方法      一,nginx的停止操作 停止操作是通过向nginx进程发送信号来实现的。 步骤1:查询nginx主进程号   代码示例: ps -ef | grep nginx 在进程列表里 面找master进程,它的编号就是主进程号了。 步骤2.........
    ▪nginx实现mysql 负载均衡的实例分享      这里首先要说明的是: nginx属于七层架构,支持的是http协议,本身对tcp协议没有支持。 所以不能代理mysql等实现负载均衡。 以下介绍的实现方法,需要借助nginx的模块nginx_tcp_proxy_module来实现.........

[1]nginx 配置轮询分流 实现负载均衡的方法
    来源: 互联网  发布时间: 2013-12-24

系统环境:
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  只需要在配置文件增加如下代码
 

代码示例:
upstream  www.129.com  { 
          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.,进行测试。
每次刷新,都会跳转到不同的服务器上页面。

如下图:



    
[2]重启nginx后丢失nginx.pid的解决方法
    来源: 互联网  发布时间: 2013-12-24

一,nginx的停止操作
停止操作是通过向nginx进程发送信号来实现的。
步骤1:查询nginx主进程号
 

代码示例:
ps -ef | grep nginx

在进程列表里 面找master进程,它的编号就是主进程号了。
步骤2:发送信号
从容停止Nginx:
kill -QUIT 主进程号
快速停止Nginx:
kill -TERM 主进程号
强制停止Nginx:
 

代码示例:
pkill -9 nginx

另外, 若在nginx.conf配置了pid文件存放路径则该文件存放的就是Nginx主进程号,如果没指定则放在nginx的logs目录下。有了pid文 件,我们就不用先查询Nginx的主进程号,而直接向Nginx发送信号了,命令如下:
 

代码示例:
kill -信号类型 '/usr/nginx/logs/nginx.pid'

二,nginx的平滑重启
如果更改了配置就要重启Nginx,要先关闭Nginx再打开?不是的,可以向Nginx 发送信号,平滑重启。
平滑重启命令:
 

代码示例:
kill -HUP 住进称号或进程号文件路径
或使用
/usr/nginx/sbin/nginx -s reload

注意,修改了配置文件后最好先检查一下修改过的配置文件是否正 确,以免重启后Nginx出现错误影响服务器稳定运行。判断Nginx配置是否正确命令如下:
 

代码示例:
nginx -t -c /usr/nginx/conf/nginx.conf
或者
/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)

使用方法:
 

代码示例:
nginx -c /path/to/config/file
//我的机器是这样:/alidata/server/nginx/sbin/nginx -c /alidata/server/nginx/conf/nginx.conf

    
[3]nginx实现mysql 负载均衡的实例分享
    来源: 互联网  发布时间: 2013-12-24

这里首先要说明的是:
nginx属于七层架构,支持的是http协议,本身对tcp协议没有支持。
所以不能代理mysql等实现负载均衡。

以下介绍的实现方法,需要借助nginx的模块nginx_tcp_proxy_module来实现。

1,下载module模块
下载地址 : https://nodeload.github.com/yaoweibin/nginx_tcp_proxy_module/zipball/master
 

代码示例:
$ wget 'http://nginx.org/download/nginx-1.2.1.tar.gz'
$ 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配置文件:
 

代码示例:
http {
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:31 10.10.10.18:3306 1446 4383
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

    
最新技术文章:
▪linux系统中的列出敏感用户的脚本代码
▪a10 config backup for aXAPI
▪一键备份gitolite服务器的Shell脚本
▪nagios 分发文件实现代码
▪阿里云云服务器Linux系统更新yum源Shell脚本
▪一个监控LINUX目录和文件变化的Shell脚本分享
▪Linux下实现SSH免密码登录和实现秘钥的管理、...
▪Shell正则表达式之grep、sed、awk实操笔记
▪3个备份系统文件并邮件发送的Shell脚本分享
▪CentOS 6.3下给PHP添加mssql扩展模块教程
▪监控网站是否可以正常打开的Shell脚本分享
▪shell脚本编程之if语句学习笔记
▪shell脚本编程之循环语句学习笔记
▪shell脚本编程之case语句学习笔记
▪Shell脚本实现的阳历转农历代码分享
▪Shell脚本实现复制文件到多台服务器的代码分...
▪Shell脚本实现批量下载网络图片代码分享
▪Shell脚本实现检测文件是否被修改过代码分享
▪Shell脚本数组用法小结
▪Shell脚本批量重命名文件后缀的3种实现
▪C语言实现的ls命令源码分享
▪Linux下查找后门程序 CentOS 查后门程序的shell脚...
▪Shell 函数参数
▪linux shell 自定义函数方法(定义、返回值、变...
▪Shell实现判断进程是否存在并重新启动脚本分...
▪Shell脚本break和continue命令简明教程
▪Shell脚本函数定义和函数参数
▪让代码整洁、过程清晰的BASH Shell编程技巧
▪shell常用重定向实例讲解
▪awk中RS、ORS、FS、OFS的区别和联系小结
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3