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

Nginx负载均衡的理解 http://www.linuxdiyf.com/linux/10205.html

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.88181.com:80;  #这里是你自己要做负载均衡的服务器地址1

server www.linux.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.linux.com:80;
server www.88181.com:8080;
}
server {
listen      80;
server_name  my22;
location / {
proxy_pass  http://myServer;
}
}
}

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

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

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

127.0.0.1        www.linux.com
127.0.0.1        www.88181.com

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

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

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

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

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

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

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

[[email protected] nginx]# curl www.linux.com:80
I‘m the linux<br>【view】1
[[email protected] 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 linux

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

时间: 2024-10-08 01:16:21

CentOS+Nginx一步一步开始配置负载均衡的相关文章

Linux、Nginx配置负载均衡

nginx配置负载均衡其实很简单,一直还以为负载均衡是个很高端人士玩的 首先先了解下负载均衡,假设一个场景,如果有1000个客户同时访问你服务器时,而你只有一台服务器的Nginx,且只有一个MySQL服务器,那么这些请求 可能会高出你的的服务器承受能力,就会down掉: 解决方法: 1.垂直升级:就是增加服务器的配置,CPU,内存等 2.水平升级:添加多台服务器来分担服务器压力 配置Nginx负载均衡

Nginx的安装以及反向代理和负载均衡的配置

环境说明 由于我使用的是windows系统,所以我用虚拟机虚拟出来了3台linux系统 虚拟机一:192.168.1.20 (Nginx反向代理和负载均衡服务器,系统kali linux) 虚拟机二:192.168.1.19 (node服务器一,系统ubuntu 17.10) 虚拟机三:192.168.1.22(node服务器二,系统ubuntu 17.10) 环境需要的程序 git Node Nginx pm2 首先环境的搭建,由于这三台电脑都是我刚刚虚拟出来的,所以什么环境都没有! 虚拟机一

图解nginx配置负载均衡

1. 在Linux上准备两份tomcat 2. 修改两份tomcat的端口号 3. 启动两个tomcat服务器 4. 修改两个服务器上的主页方便测试区分 5. 在nginx配置文件里配置反向代理 备注: 1) hosts文件中 www.burgundyred.com 192.168.18.107 2) nginx默认端口80 6. 重新加载nginx配置文件 ./nginx -s reload 7. 配置负载均衡 备注: 1) weight为权重, 权重高的server被分配的几率较高 2) u

Nginx基于TCP/UDP端口的四层负载均衡(stream模块)配置梳理

Nginx基于TCP/UDP端口的四层负载均衡(stream模块)配置梳理 通常我们会用Nginx的upstream做基于http/https端口的7层负载均衡,由于Nginx老版本不支持tcp协议,所以基于tcp/udp端口的四层负载均衡一般用LVS或Haproxy来做.至于4层负载均衡和7层负载均衡的区别,可以参考:http://www.cnblogs.com/kevingrace/p/6137881.html.然而Nginx从1.9.0版本开始,新增加了一个stream模块,用来实现四层协

Consul+Nginx+Upsync+Linux+Keepalived+Lvs的动态负载均衡

注: Nginx版本必须大于等于1.9,linux我使用的是7.0版本,记得关闭防火墙 开始正文: 这里只提一下两个比较会出错的配置,consul,upsync,PCRE库,SSL库,ZLIB库的配置网上很多不一一详解(我是在/usr/local中配置的) Nginx的配置: cd /usr/local/ wget http://nginx.org/download/nginx-1.9.10.tar.gz tar -zxvf nginx-1.9.10.tar.gz groupadd nginx

Nginx服务器的安装与反向代理负载均衡

Nginx服务器 一:什么是Nginx? 我们生活的世界中,有的时候需要上网.我们可以浏览很多很多的网页,这些网页都是由一系列的程序组成,但是我们是否想过,这些程序存储在什么地方呢?没错,这些程序都是存储在一种名叫服务器的硬件上,比如我们的电脑也是一种服务器,只不过我们的个人电脑作为服务器的话性能会比较低.我们的网页程序存储在服务器硬件上,是否可以随意存储呢?不是的,我们需要在服务器硬件的操作系统中搭建一个服务器软件,那么这样,有服务器软件跟服务器硬件配合,才形成一个完整的服务器.服务器软件有非

单节点nginx为两台apache服务器提供负载均衡

需求:本实验为单节点nginx为两台apache服务器提供负载均衡,所有配置为最简单 1.初始化3台测试server,该关的关了 [[email protected] ~]# vim /etc/hosts 192.168.1.101 ng-master 192.168.1.161 web1 192.168.1.162 web2 [[email protected] ~]# yum clean all [[email protected] ~]# systemctl stop firewalld.

Nginx+keepalived做双机热备加tomcat负载均衡

Nginx+keepalived做双机热备加tomcat负载均衡 环境说明: nginx1:192.168.2.47 nginx2:192.168.2.48 tomcat1:192.168.2.49 tomcat2:192.168.2.50 vip:192.168.2.51 一.Nginx配置1.安装Nginx所需pcre库wgetftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.10.tar.gz tar -zxvf pc

单节点nginx为两台apache服务器提供负载均衡(转载)

单节点nginx为两台apache服务器提供负载均衡 需求:本实验为单节点nginx为两台apache服务器提供负载均衡,所有配置为最简单 1.初始化3台测试server,该关的关了 1 2 3 4 5 6 7 8 9 [[email protected] ~]# vim /etc/hosts 192.168.1.101   ng-master 192.168.1.161   web1 192.168.1.162   web2 [[email protected] ~]# yum clean a

Nginx反向代理、动静分离、负载均衡及rewrite隐藏路径详解(Nginx Apache MySQL Redis)–第三部分

Nginx反向代理.动静分离.负载均衡及rewrite隐藏路径详解 (Nginx Apache MySQL Redis) 楓城浪子原创,转载请标明出处! 更多技术博文请见个人博客:https://fengchenglangzi.000webhostapp.com 微信bh19890922 QQ445718526.490425557 三.Nginx动静分离及负载均衡 3.1 Nginx安装 请参考:https://fengchenglangzi.000webhostapp.com/?p=511 亦