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

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

412次阅读
没有评论

共计 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、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7984871
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定! 前言 作为 NAS 玩家,你是否总被这些...
亚马逊云崩完,微软云崩!当全球第二大云“摔了一跤”:Azure 宕机背后的配置风险与警示

亚马逊云崩完,微软云崩!当全球第二大云“摔了一跤”:Azure 宕机背后的配置风险与警示

亚马逊云崩完,微软云崩!当全球第二大云“摔了一跤”:Azure 宕机背后的配置风险与警示 首先来回顾一下 10...
【1024程序员】我劝你赶紧去免费领一个AWS、华为云等的主机

【1024程序员】我劝你赶紧去免费领一个AWS、华为云等的主机

【1024 程序员】我劝你赶紧去免费领一个 AWS、华为云等的主机 每年 10 月 24 日,程序员们都会迎来...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...
星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛 NAS 硬件 03:五盘位 +N5105+ 双网口的成品 NAS 值得入手吗 前言 大家好,我...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...
安装并使用谷歌AI编程工具Antigravity(亲测有效)

安装并使用谷歌AI编程工具Antigravity(亲测有效)

  安装并使用谷歌 AI 编程工具 Antigravity(亲测有效) 引言 Antigravity...
安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装 Black 群晖 DSM7.2 系统安装教程(在 Vmware 虚拟机中、实体机均可)! 前言 大家好,...
浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍 前言 在 AI 自动化快速发展的当下,浏览器早已不再只是...
300元就能买到的”小钢炮”?惠普7L四盘位小主机解析

300元就能买到的”小钢炮”?惠普7L四盘位小主机解析

  300 元就能买到的 ” 小钢炮 ”?惠普 7L 四盘位小主机解析 最近...