阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

CentOS+Nginx一步一步开始配置负载均衡

123次阅读
没有评论

共计 4986 个字符,预计需要花费 13 分钟才能阅读完成。

Nginx 负载均衡的理解

Nginx 是一个轻量级的、高性能的 WebServer,他主要可以干下面两件事:

  1. 作为 http 服务器(和 apache 的效果一样)
  2. 作为反向代理服务器实现负载均衡

现在 Nginx 到处都可以见到,经常会看到宕机后的网页会显示 nginx 的字样,这也说明 Nginx 由于高性能、使用配置简、开源单这些特点被越来越多的用户所接受,所使用。

其中第一种作为 http 服务器,结合 php-fpm 进程,对发来的请求进行处理,nginx 本身并不会解析 php,他只是作为一个服务器,接受客户端发来的请求,如果是 php 请求,则交给 php 进程处理,并将 php 处理完成之后的结果发送给客户端。这个很简单,安装好 nginx+php-fpm 之后配置好各自的配置文件,启动就可以实现。运行原理可以看下面这段解释:

Nginx 不支持对外部程序的直接调用或者解析,所有的外部程序(包括 PHP)必须通过 FastCGI 接口来调用。FastCGI 接口在 Linux 下是 socket(这个 socket 可以是文件 socket,也可以是 ip socket)。为了调用 CGI 程序,还需要一个 FastCGI 的 wrapper(wrapper 可以理解为用于启动另一个程序的程序),这个 wrapper 绑定在某个固定 socket 上,如端口或者文件 socket。当 Nginx 将 CGI 请求发送给这个 socket 的时候,通过 FastCGI 接口,wrapper 接收到请求,然后派生出一个新的线程,这个线程调用解释器或者外部程序处理脚本并读取返回数据;接着,wrapper 再将返回的数据通过 FastCGI 接口,沿着固定的 socket 传递给 Nginx;最后,Nginx 将返回的数据发送给客户端。这就是 Nginx+FastCGI 的整个运作过程,如图下图所示。

CentOS+Nginx 一步一步开始配置负载均衡

上面这段话解释了 nginx+fastcgi 的运行机制,在 nginx 配置文件中会对请求进行匹配,并作做出相应的处理,比如说直接返回错误文件(这里和上面说的有点区别,我估计是 nginx 内部对 html 等这些静态文件可以做类似上图的解析),使用 php 进程对 php 请求进行处理(这里的 php 进程可以是多个)。

第二种是用反向代理事项负载均衡,这个其实其实很简单,说起来就是自己定义一组 server,对请求进行匹配,并将请求转给 server 中的任意一个处理,来减轻每个 server 的压力,先看看网上对反向向代理的定义:

反向代理(Reverse Proxy)方式是指以代理服务器来接受 internet 上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 internet 上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

CentOS+Nginx 一步一步开始配置负载均衡

反向代理是和正向代理(或者叫代理)相反的,代理大家定听过吧,为了更方便的访问 B 资源,通过 A 资源间接的访问 B 资源,特点就是用户知道自己最终要访问的网站是什么,但是反向代理用户是不知道代理服务器后边做了什么处理的,反向代理中服务真正的处理服务器放在内网,对外网而言只可以访问反向代理服务器,这也大大提高了安全性。

安装软件

nginx 安装很简单

1、安装 nginx 需要的环境,pcre(作用 rewrite)、zlib(作用压缩)、ssl,这个也可以自己下载编译安装

yum -y install zlib;

yum –y install pcre;

yum –y install openssl;

2、下载安装 nginx-*.tar.gz。

tar –zxvf nginx-1.2.8.tar.gz –C ./;

cd nginx-1.2.8;

./congigure –prefix=/usr/local/nginx;

make && make install;

3、配置

这里配置的时候只需要修改 http{} 之间的内容就行了,修改的第一个地方就是设置服务器组,在 http 节点之间添加

upstream myServer{

server www.88181.com:80;  #这里是你自己要做负载均衡的服务器地址 1

server www.linuxidc.com:8080; #这里是要参与负载均衡的地址 2

}

nginx 中的 upstream 支持下面几种方式:轮询(默认,按照时间顺序对所有服务器一个一个的访问,如果有服务器宕机,会自动剔除)、weight(服务器的方位几率和 weight 成正比,这个可以在服务器配置不均的时候进行配置)、ip_hash(对每个请求的 ip 进行 hash 计算,并按照一定的规则分配对应的服务器)、fair(按照每台服务器的响应时间(rt)来分配请求,rt 晓得优先分配)、url_hash(按照访问 url 的 hash 值来分配请求),我这里使用了默认的轮训方式。

将请求指向 myServer

location / {

proxy_pass  http://myServer;

}

完整的文件(删除注释)如下:

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include      mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    upstream myServer{
      server www.linuxidc.com:80;
      server www.88181.com:8080;
    }
    server {
        listen      80;
        server_name  my22;
        location / {
            proxy_pass  http://myServer;
        }
    }
}

设置反向代理后端作为负载均衡的两个服务器

可以看到上一步骤有两个服务器地址,www.linuxidc.com:80 和 www.88181.com:8080,上面的 nginx 我是安装在虚拟机上面的,这两个服务器我是安装在本机 win8 系统中的,使用 apache 的 virtualhost,设置了两个域名,这两个域名下的代码是互相独立的,设置也很简单:

1、设置 apache 配置文件

我使用的是 xampp 集成环境,要修改的地方有两个,在 httpd.conf 中监听端口的地方添加

Listen 8080

也就是说这个地方监听了两个端口

Listen 80
    Listen 8080

看看下面这个句是否打开,没有打开的话,打开,打开如下面所示

# Virtual hosts
Include conf/extra/httpd-vhosts.conf

在 httpd-vhosts.conf 中添加下面的内容,

<VirtualHost *:80>
    ServerName www.linuxidc.com #对应的域名,负载均衡的服务器地址
    DocumentRoot E:\soft\xampp\htdocs\www.linuxidc.com #代码文件夹
</VirtualHost>
<VirtualHost *:8080>
    ServerName www.88181.com
    DocumentRoot E:\soft\xampp\htdocs\www.88181.com
</VirtualHost>

修改 windows 的 hosts 文件,追加下面的内容

127.0.0.1        www.linuxidc.com
127.0.0.1        www.88181.com

修改 linux 的 /etc/hosts 文件,追加下面的内容

192.168.1.12        www.linuxidc.com #这里前面的地址对应我 win8 本机的 ip 地址
192.168.1.12        www.88181.com

我在 www.linuxidc.com:80 中放了一个文件 index.php【E:\soft\xampp\htdocs\www.linuxidc.com\index.php】

www.88181.com:8080 中也放了一个文件 index.php【E:\soft\xampp\htdocs\www.88181.com\index.php】

文件中的内容基本相同,只是 I ’m the 88181 这个地方有区别,一个是 linuxidc,另一个是 88181。

如果你可以在 win8 浏览器中输入 www.linuxidc.com:80 和 www.88181.com:8080 看到不同的效果

并且在 CentOS 下面看到下面的结果(自己美化了下)说明配置成功了

[root@bogon nginx]# curl www.linuxidc.com:80
I’m the linuxidc<br>【view】1
[root@bogon nginx]# curl www.88181.com:8080
I’m the 88181<br>【view】1

<?php
session_save_path(“./”);
session_start();
header(“Content-type:text/html;charset=utf-8”);
if(isset($_SESSION[‘view’])){
    $_SESSION[‘view’] = $_SESSION[‘view’] + 1;
}else{
    $_SESSION[‘view’] = 1;
}
echo “I’m the 88181<br>”;
echo “【view】{$_SESSION[‘view’]}”;

看看效果

等所有都 ok 之后可硬通过浏览器访问看看效果

忘了说了,nginx 代理服务器的地址为 http://192.168.1.113,

浏览器输入 http://192.168.1.113/index.php 之后,不停的刷新,你会发现,会在

I’m the 88181、I’m the linuxidc

这两个页面之间来回交换,view 会没刷新两下增加一次,这也证明了前面所说的默认是轮训的方式,但这里又有一个比较常见的问题了,当用户访问网站时,未做处理的情况下,session 会保存在不同的服务器上(我这里用两个不同的文件夹模拟两台服务器),session 数据可能出现多套,这个问题怎么解决呢,下篇文章说说这个问题,其实也很简单。

————————————– 分割线 ————————————–

CentOS 6.2 实战部署 Nginx+MySQL+PHP http://www.linuxidc.com/Linux/2013-09/90020.htm

使用 Nginx 搭建 WEB 服务器 http://www.linuxidc.com/Linux/2013-09/89768.htm

搭建基于 Linux6.3+Nginx1.2+PHP5+MySQL5.5 的 Web 服务器全过程 http://www.linuxidc.com/Linux/2013-09/89692.htm

CentOS 6.3 下 Nginx 性能调优 http://www.linuxidc.com/Linux/2013-09/89656.htm

CentOS 6.3 下配置 Nginx 加载 ngx_pagespeed 模块 http://www.linuxidc.com/Linux/2013-09/89657.htm

CentOS 6.4 安装配置 Nginx+Pcre+php-fpm http://www.linuxidc.com/Linux/2013-08/88984.htm

Nginx 安装配置使用详细笔记 http://www.linuxidc.com/Linux/2014-07/104499.htm

Nginx 日志过滤 使用 ngx_log_if 不记录特定日志 http://www.linuxidc.com/Linux/2014-07/104686.htm

————————————– 分割线 ————————————–

Nginx 的详细介绍 :请点这里
Nginx 的下载地址 :请点这里

更多 CentOS 相关信息见 CentOS 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=14

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计4986字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中