## Nginx 反向代理。

(一)简介

  一、什么是代理服务器

    客户机原本发送给服务器的请求,不会直接发送给服务器,而是先发送给代理服务器;经过代理服务器处理后转发给服务器服务器数据处理后转回给代理服务器代理服务器再返回给客户机的一个过程。

    

  二、代理服务器的作用

    1. 防火墙作用

      由于所有的客户机请求都必须通过代理服务器访问远程站点,因此可在代理服务器上设限,过滤某些不安全信息;

    2. 提高Web访问速度

      可以缓存真实Web服务器上的某些静态资源,减轻真实Web服务器的负载压力;

    3. 实现负载均衡

      内部可以采用多台服务器来组成服务器集群,外部还是可以采用一个地址访问;

(二)架构思路

  一、架构图

    

    先来分析这张图:

      1. 用户会访问 “10.167.167.167(默认80端口)” 。

      2. Nginx收到 PC 端的HTTP请求。

      3. Nginx根据配置将请求负载到 三台Apache的机子上去。

      4. Apache服务器将数据处理后返回给Nginx。

      5. Nginx将数据返回PC

  (二)看完以上的分析后,可能大家有会几个问题:

    1. 为什么使用Nginx做代理服务器?

      a) 轻量级,同样起web 服务,比apache 占用更少的内存及资源;

      b) 非阻塞、高并发连接:数据复制时,磁盘I/O的第一阶段是非阻塞的。官方测试能够支撑5万并发连接,在实际生产环境中跑到2~3万并发连接数;

    2. 为什么使用Apache后台服务器?

      a) rewrite ,比nginx 的rewrite 强大;

      b) 少bug ,nginx 的bug 相对较多;

       c) 稳定

三、架构实战

  (一) Nginx、Apache 安装

    1. http://www.cnblogs.com/bluebirds/p/6386649.html  (这是之前讲到的在window安装nginx的案例, Linux也很简单,这里就不做多讲了)

  (二)Nginx配置

    1. Nginx.conf

      进程数与每个进程的最大连接数

      Nginx进程数,建议设置为等于CPU总核心数

      单个进程最大连接数,那么该服务器的最大连接数 = 连接数 * 进程数

#user  apache;
worker_processes ; # 工作进程的个数 events {
use epoll;
worker_connections ; # 单个进程的连接数
} http {
# 服务器集群(Apache) weight 分配权重 权重越大 分配概率越高.
upstream php_pool{
server 192.168.10.101: max_fails= fail_timeout=30s weight=;
server 192.168.10.102: max_fails= fail_timeout=30s weight=;
server 192.168.10.103: max_fails= fail_timeout=30s weight=;
}
}
server {
listen ;
server_name www.test.com; # 域名 本地
access_log /data/www/logs/nginx_log/access/www.test.com_access.log main ;
error_log /data/www/logs/nginx_log/error/www.test.com_error.log ;
root /data/www/vhosts/www.test.com/httpdocs ;
index index.html index.php;
error_page /.html; location ~ \.php$ {
proxy_pass http://php_pool; # 服务集群池
include proxy_params;
expires -;
} location / {
include proxy_params;
if (!-d $request_filename){
set $flag $flag;
}
if (!-f $request_filename){
set $flag $flag;
}
if ($flag = ""){
proxy_pass http://php_pool;
expires -;
}
}
}

以上就是 反向代理的配置,只要理解服务的访问过程及原理,应该是不难的。

四、学习总结

  本章借助Nginx 和 Apache 搭建了反向代理服务器,实在的基本的负载均衡。

  在目前大多数的应用中,都会将Nginx部署在Linux服务器中,并且会做一些针对负载均衡的优化配置;

  经过这次也更加深入的了解了 Nginx 和 Apache 服务配置两种服务的优缺点,能够更准确的在场景中运用。

Nginx 反向代理、负载均衡的更多相关文章

  1. Nginx 反向代理 负载均衡 虚拟主机配置

    Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...

  2. Nginx 反向代理 负载均衡 虚拟主机

    Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...

  3. 十.nginx反向代理负载均衡服务实践部署

    期中集群架构-第十章-nginx反向代理负载均衡章节章节====================================================================== 0 ...

  4. 【转】Nginx 反向代理 负载均衡 虚拟主机配置

    原文:http://www.cnblogs.com/itdragon/p/8059000.html Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代 ...

  5. Centos7.4 Nginx反向代理+负载均衡配置

    Ningx是一款高性能的HTTP和反向代理服务器,配置起来也比较简单. 测试环境: 172.16.65.190 Nginx-反向代理 172.16.65.191 Ningx-Web 172.16.65 ...

  6. 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器

    Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...

  7. 项目实战2.2—nginx 反向代理负载均衡、动静分离和缓存的实现

    实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备注 nginx VIP:172.17.11.11 反向代理服务器 开启代理功能 设置监控,调度 rs01 RIP ...

  8. 项目实战2.1—nginx 反向代理负载均衡、动静分离和缓存的实现

    总项目流程图,详见 http://www.cnblogs.com/along21/p/8000812.html 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备 ...

  9. 项目实战02:nginx 反向代理负载均衡、动静分离和缓存的实现

    目录 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 2.下载编译安装tengine 3.设置代理服务器的配置文件 4.启动tengine服务 5.开启后端的web服务 6.测试 实验二:ng ...

  10. Centos 7.6配置nginx反向代理负载均衡集群

    一,实验介绍 利用三台centos7虚拟机搭建简单的nginx反向代理负载集群, 三台虚拟机地址及功能介绍 192.168.2.76    nginx负载均衡器 192.168.2.82    web ...

随机推荐

  1. 2017·iOS学习资料

    我的两个想法更新了,欢迎新老司机出来槽点一下 star →[iOS·UIKit & Foundation框架-Annotations & Category注解工具类

  2. .net—— webservice的新建、发布、使用(最全、最简单)【原创】

    网上有很多关于webservice资料,但大部分都不完整,其中还要很大部分是转载的--.这个悲剧了,自己都没试过能不能用就不负责任的转载. 所以今天对webservice的新建.发布.使用最一个全面. ...

  3. 通过wireshark学习Traceroute命令(UDP,ICMP协议)

    traceroute: 通过TTL限定的ICMP/UDP/TCP侦测包来发现从本地主机到远端目标主机之间的第三层转发路径.用来调试网络连接性和路由问题. mtr: traceroute的一个变种,能根 ...

  4. 在Quo.js下Tap和singleTap的区别

    前两天上网搜开发手机页面的JS,看到了Quo.js下载下来后来看了一下,支持的触屏手势挺多的,在一般的开发中应该够用了,更让我喜欢它的一点是它跟JQ差不多(虽然功能不如JQ强大但是语法基本一致).这就 ...

  5. 每天一个JS 小demo之新建文件夹。主要知识点:DOM方法的综合运用

    <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"& ...

  6. golang 浮点数 取精度的效率对比

    需求 浮点数取2位精度输出 实现 代码 package main import ( "time" "log" "strconv" " ...

  7. Android网络请求框架AsyncHttpClient实例详解(配合JSON解析调用接口)

    最近做项目要求使用到网络,想来想去选择了AsyncHttpClient框架开进行APP开发.在这里把我工作期间遇到的问题以及对AsyncHttpClient的使用经验做出相应总结,希望能对您的学习有所 ...

  8. SQL Server各个版本的区别

    SQLEXPR_x64_CHS.exe,标准SQL Server Express edition,只有数据库引擎,甚至连图形管理界面都没有.SQLEXPRWT_x64_CHS.exe,多了一个图形管理 ...

  9. 使用EF连接Postgresql

    环境: VS2017 Community Windows 10 Postgresql 9.6 安装Postgresql: https://www.postgresql.org/download/ 1. ...

  10. PHP+MySql实现后台数据的读取

      我们使用的是PHP 的php_mysqli扩展   首先了解一些基础的用法  1.连接数据库使用 mysqli_connect()  参数:①主机地址 ②MYSQL用户名 ③MYSQL密码 ④选择 ...