centos+nginx从零开始配置负载均衡

nginx负载均衡的理解

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

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

现在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的整个运作过程,如图下图所示。

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

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

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

反向代理是和正向代理(或者叫代理) 相反的,代理大家定听过吧,为了更方便的访问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.myapp2.com:80;  #这里是你自己要做负载均衡的服务器地址1
        server www.myapp1.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.myapp1.com:80;
       server www.myapp2.com:8080;
    }
    server {
        listen       80;
        server_name  my22;
        location / {
            proxy_pass   http://myServer;
        }
    }
}

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

可以看到上一步骤有两个服务器地址,www.myapp1.com:80www.myapp2.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.myapp1.com #对应的域名,负载均衡的服务器地址
    DocumentRoot E:\soft\xampp\htdocs\www.myapp1.com #代码文件夹
</VirtualHost>
<VirtualHost *:8080>
    ServerName www.myapp2.com
    DocumentRoot E:\soft\xampp\htdocs\www.myapp2.com
</VirtualHost>

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

127.0.0.1        www.myapp1.com
127.0.0.1        www.myapp2.com

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

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

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

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

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

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

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

[[email protected] nginx]# curl www.myapp1.com:80
I‘m the myapp1<br>【view】1
[[email protected] nginx]# curl www.myapp2.com:8080
I‘m the myapp2<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 myapp2<br>";
echo "【view】{$_SESSION[‘view‘]}";

看看效果

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

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

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

I‘m the myapp2、I‘m the myapp1

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

  本文版权归作者iforever([email protected])所有,未经作者本人同意禁止任何形式的转载,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。

时间: 2024-10-26 13:21:28

centos+nginx从零开始配置负载均衡的相关文章

nginx + tomcat配置负载均衡

目标:Nginx做为HttpServer,连接多个tomcat应用实例,进行负载均衡. 注:本例程以一台机器为例子,即同一台机器上装一个nginx和2个Tomcat且安装了JDK1.7. 1.安装Nginx安装Nginx教程 2.配置两个Tomcat在本机上配置两个Tomcat,分别为tomcat7-8081.tomcat7-8082.tomcat7-8081访问地址:http://localhost:8081,浏览显示内容:this is 8081 porttomcat7-8082访问地址:h

Nginx + Tomcat 配置负载均衡集群

一.Hello world 1.前期环境准备 准备两个解压版tomcat,如何同时启动两个tomcat,请看我的另一篇文章<一台机器同时启动多个tomcat>. nginx官网下载解压版nginx. 创建一个简单的web项目.为了直观的区分访问的哪个tomcat,在页面写上标记8081.8082. 分别部署到对应的tomcat下.如图:???? ? 2.配置nginx 进入nginx-1.10.1\conf路径,修改配置文件nginx.conf. 1.配置服务器组,在http{}节点之间添加u

nginx+tomcat配置负载均衡集群

一.Hello world 1.前期环境准备 准备两个解压版tomcat,如何同时启动两个tomcat,方法如下:首先去apache tomcat官网下载一个tomcat解压版.解压该压缩包,生成n份tomcat 分别命名为 tomcat1,tomcat2,然后修改server.xml配置文件,分别进入tomcat/conf/目录,修改server.xml,一共三处.第一处:第二处.tomcat访问端口号:第三处:之后修改bin下的启动文件分别进入tomcat/bin目录,修改 startup.

Nginx + Tomcat 配置负载均衡集群简单实例

一.Hello world 1.前期环境准备 准备两个解压版tomcat,如何同时启动两个tomcat,请看我的另一篇文章<一台机器同时启动多个tomcat>. nginx官网下载解压版nginx. 创建一个简单的web项目.为了直观的区分访问的哪个tomcat,在页面写上标记8081.8082. 分别部署到对应的tomcat下.如图:???? ? 2.配置nginx 进入nginx-1.10.1\conf路径,修改配置文件nginx.conf. 1.配置服务器组,在http{}节点之间添加u

nginx普通配置/负载均衡配置/ssl/https配置

1.nginx普通配置 server { listen 80; server_name jqlin.lynch.com; access_log /var/log/nginx/main.log main; error_log /var/log/nginx/pay_local.error; #log_format access '$remote_addr - $remote_user [$time_local] "$request" $status $body_bytes_sent $re

Nginx+Tomcat——配置负载均衡和动静分离(实战!)

Nginx应用 Nginx是一款非常优秀的HTTP服务器软件 支持高达50000个并发连接数的响应 拥有强大的静态资源处理能力 运行稳定 内存.CPU等系统资源消耗非常低 目前很多大型网站都应用Nginx服务器作为后端网站程序的反向代理及负载均衡器,提升整个站点的负载并发能力 Nginx负载均衡实现原理 Nginx配置反向代理的主要参数 upstream 服务池名{} 配置后端服务器池,以提供响应数据 proxy_ _pass http://服务池名 配置将访问请求转发给后端服务器池的服务器处理

nginx+tomcat 配置负载均衡

nginx 从Nginx官网下载页面(http://nginx.org/en/download.html)下载Nginx最新版本(我用的是nginx-1.8.1版本) 安装就直接把压缩包解压到一个路径下(路径最好是没有中文非空的) 在cmd里切换到部署目录路径   启动Nginx:start nginx   停止Nginx:nginx -s stop 查看进程,如果看到    这两个进程就说明你nginx已经成功启动 成功启动nginx之后,在浏览器里访问http://localhost,可以看

Nginx+Tomcat配置负载均衡-动静分离(二)

配置动静分离的时候遇到了一些问题,一个是配置nginx配置文件有问题导致访问不到服务器,另一个问题是配置静态资源的路径和实际的资源目录不匹配导致404,502等错误 结合上一篇的基础,在此将动静分离的配置文件主要部分做一说明,为日后参考. 1 #user nobody; 2 worker_processes 1; 3 4 #error_log logs/error.log; 5 #error_log logs/error.log notice; 6 #error_log logs/error.l

安装 Nginx 并配置负载均衡

1,在节点 192.168.1.40 上执行安装 nginx,操作如下: 01 02 03 sudo apt-add-repository ppa:nginx/development sudo apt-get update sudo apt-get install nginx nginx启动命令为 sudo /etc/init.d/nginx start   或者 service nginx start 多说几句,以下是对 nginx 的几个参数的说明 start – 启动 stop – 停止