一、Nginx实现反向代理

概念

反向代理:在收到客户端请求之后,会修目标IP地址和端口

正向代理:在收到客户端请求之后,会修源IP地址和端口

上游服务器:代理服务器后端的哪些真正给客户端提供服务的节点,这样的服务器称之为上游服务器

下游服务器:客户端就是下游节点

模块:nginx_http_proxy_module

指令:

proxy_pass:指定上游服务器的ip和端口

proxy_set_header:指定在重新封装请求报文的时候,添加一个新的首部

部署步骤:

0.检查环境

1.安装服务

yum -y install nginx httpd php

2.配置httpd端口

vim /etc/httpd/conf/httpd.conf

###########

Listen 45678

############

3.启动httpd

systemctl start httpd

systemctl enable httpd

netstat -anp|grep httpd

4.修改Nginx配置文件

vim /etc/nginx/nginx.conf

########

删除默认的80端口server          #切记最后需要加一个}。

###############

cd /etc/nginx/conf.d

vim pass.conf

###########

server {

listen      80;

location / {

proxy_pass   http://127.0.0.1:45678;

}

}

###########

5.启动nginx

nginx -t              #进行语法检测

systemctl restart nginx

systemctl enable nginx

netstat -anp|grep nginx

firewall-cmd --add-port=80/tcp

firewall-cmd --add-port=80/tcp --permanent

6.浏览器验证

7.验证php

echo "<?php phpinfo(); ?>" > /var/www/html/index.php

8.浏览器验证

9.配置nginx网站

mkdir /nginx

echo "123" > /nginx/index.html

vim /etc/nginx/conf.d/pass.conf

###################

server {

listen      80;

location ~* \.php$ {

proxy_pass   http://127.0.0.1:45678;

}

location / {

root /nginx;

}

}

################

10.重启nginx

nginx -t

systemctl restart nginx

11.浏览器验证

IP/index.html

IP/index.php

补充一:

location如下:
location /admin {
proxy_pass http://www.ken.com/;
proxy_pass http://www.ken.com;
}
请求的url 是http://www.ken.com/admin/a.html
如果代理方式是 proxy_pass http://www.ken.com/; 那么去www.ken.com的根目录下找a.html,/代表完全代理。
如果代理方式是 proxy_pass http://www.ken.com; 那么去www.ken.com的根目录下的admin找a.html

补充二:

   如果location中使用了模式匹配(正则),那么,location中的url会直接补充到代理节点的后面.
此时,上游服务器的的后面不能有任何内容,包括 / location ~ \.php$ {
proxy_pass http://www.ken.com; [正则表达式proxy_pass转发的地址后面什么都不能加] <<< 正确写法
proxy_pass http://www.ken.com:80; <<< 正确写法
proxy_pass http://www.ken.com/; <<< 错误写法
proxy_pass http://www.ken.com/img; <<< 错误写法
} 此时,如果请求的url是 http://www.baidu.com/book/stu/a.php ,就会代理成 http://www.ken.com/book/stu/a.php

补充三:

    在location中如果有重定向的话,那么就用重定向后的uri替换掉代理节点中的uri
location / {
rewrite /(.*)$ /index.php?name=$1 break;
proxy_pass http://www.baidu.com:80/img;
} 此时,如果请求的url是 http://www.ken.com/bajie ,就会代理成 www.baidu.com/index.php?name=bajie

二、nginx实现负载均衡

概念:

1、概念

调度器:分发用户的请求到一个后端节点

上游服务器(真实服务器):每个真正用来处理用户请求的节点都是一个上游服务器

CIP:(client IP)客户端的IP地址

RIP:(real IP)真实服务器的IP地址

VIP:(virtual IP)虚拟IP,用户所看到的是也是虚拟IP

2、指令

指令:upstream

作用:定义一个上游服务器组

格式

upstream name {

server  上游服务器1  参数 参数;

server  上游服务器1  参数 参数;

server  上游服务器1  参数 参数;

3、参数

weight=#:设置服务器的权重(数字越大,权重越高)

backup:设置服务器处于备用状态(其他节点出现故障,备用节点才开始工作)

down:设置让一个节点处于离线状态(经常用在维护一个节点的情况下)

max_fails=number:设置连续几次转发失败就认为该节点出现故障,然后就不再向该节点转发用户请求了

fail_timeout=time:和上个参数组合使用,作用是设置等待上游服务器响应超时时间

实验:a.com、b.com、c.com

1.安装服务

yum -y install nginx

2.建立路径

mkdir -p /work/html_a

mkdir -p /work/html_b

echo "aaaaaaaaa" > /work/html_a/index.html

echo "bbbbbbbb" > /work/html_b/index.html

3.编辑配置文件

cd /etc/nginx/conf.d

vim ab.conf

###########################

server {

listen      80;

server_name a.com;

location / {

root /work/html_a;

}

}

server {

listen      80;

server_name b.com;

location / {

root /work/html_b;

}

}

server {

listen      80;

server_name c.com;

location / {

proxy_pass http://abc;

}

}

upstream abc {

server     127.0.0.1:81;

server     127.0.0.1:82;

}

server {

listen      81;

server_name a.com;

location / {

root /work/html_a;

}

}

server {

listen      82;

server_name b.com;

location / {

root /work/html_b;

}

}

########################

4.查错

nginx -t

5.重启服务

systemctl restart nginx

6.添加防火墙端口

firewall-cmd --add-port=80/tcp --permanent

firewall-cmd --reload

7.设置域名静态解析

echo "192.168.10.100 a.com" >> /etc/hosts

echo "192.168.10.100 b.com" >> /etc/hosts

echo "192.168.10.100 c.com" >> /etc/hosts

8.验证

curl a.com

curl b.com

curl c.com

三、反向代理和负载均衡的区别

1、反向代理proxy_pass后跟的是一个具体的IP地址,负载均衡proxy_pass后跟的是集群名;

2、反向代理代理到的是某一个特点的服务器,而负载均衡器是根据算法调度到集群中的某个节点上;

3、反向代理和负载均衡都可以使用模式匹配(正则)。

四、nginx启动错误

  利用nginx进行反向代理的时候,我们会配置proxy_pass。在启动nginx的时候,会报如下错误:

nginx: [emerg] host not found in upstream "xxx.com" in /usr/local/nginx/conf/vhost/yq.nginx.com.conf:19

  其实nginx配置语法上没有错误的,只是系统无法解析这个域名,所以报错.
解决办法就是添加dns到/etc/resolv.conf 或者是/etc/hosts,让其能够解析到IP。类似windows下的hosts文件的修改。

  具体步骤如下:

vim /etc/hosts

//修改hosts文件,在hosts文件里面加上一句:

127.0.0.1       localhost.localdomain   xxx.com

Linux服务之nginx服务篇三(反向代理、负载均衡)的更多相关文章

  1. 【05】Nginx:TCP / 正向 / 反向代理 / 负载均衡

    写在前面的话 在我们日常的工作中,不可能所有的服务都是简单的 HTML 静态网页,nginx 作为轻量级的 WEB 服务器,其实我们将它用于更多的地方还是作为我们网站的入口.不管你是后端接口,还是前端 ...

  2. nginx之rewrite重写,反向代理,负载均衡

    rewrite重写(伪静态): 在地址栏输入xx.com/user-xxx.html, 实际上访问的就是xxx.com/user.php?id=xxx rewrite就这么简单 附上ecshop re ...

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

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

  4. 反向代理负载均衡之nginx

    一.集群 1.1 什么是集群 集群是一组相互独立的.通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高可用性 ...

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

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

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

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

  7. nginx 详解反向代理负载均衡

    什么是反向代理负载均衡 使用代理服务器可以将请求转发给内部的Web服务器,使用这种加速模式显然可以提升静态网页的访问速度.因此也可以考虑使用这种技术,让代理服务器将请求 均匀转发给多台内部Web服务器 ...

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

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

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

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

  10. Nginx特性验证-反向代理/负载均衡/页面缓存/URL重定向

    原文发表于cu:2016-08-25 参考文档: Nginx 反向代理.负载均衡.页面缓存.URL重写等:http://freeloda.blog.51cto.com/2033581/1288553 ...

随机推荐

  1. 考前自救题库NABCD分析

    考前自救题库NABCD分析 项目 内容 这个作业属于哪个课程 2021春季软件工程(罗杰 任健) 这个作业的要求在哪里 团队项目-初次邂逅,需求分析 项目名称:考前自救题库(暂定) 项目简介:本产品计 ...

  2. oo第四单元作业总结暨课程总结

    oo第四单元作业总结暨课程总结 一.本单元作业架构设计 本单元需要构建一个UML解析器,通过对输入的UML类图/顺序图/状态图的相关信息进行解析以供查询,其中课程组已提供输入整体架构及输入解析部分,仅 ...

  3. python进阶(7)--文件与异常

    一.文件读取二.文件写入三.异常四.存储数据 ---------------------------------------分割线:正文-------------------------------- ...

  4. 【笔记】《Redis设计与实现》chapter15 复制

    15.1 旧版复制功能的实现 同步 命令传播 旧版复制功能的缺陷 15.3 新版复制功能的实现 Redis2.8开始,使用PSYNC命令替代SYNC命令来执行复制时的同步操作 PSYNC命令具有完整重 ...

  5. 【Redis破障之路】二:Redis安装和基本数据结构

    1.安装Redis Redis6.0在2020年已经发布,所以我们安装Redis3.0. 1.1.在Linux上安装Redis 我们在CentOS上安装Redis.常见的的有三种安装方式: yum/a ...

  6. C#入门到精通系列课程——第1章软件开发及C#简介

    ◆本章内容 (1)了解软件 (2)软件开发相关概念 (3)认识.NET Framework (4)C#语言 (5)Visual Studio 2017 ◆本章简述 软件在现代人们的日常生活中随处可见, ...

  7. 安卓to鸿蒙系列:Timber

    目录 Guide 原理 知识点 移植到鸿蒙 Guide 本文基于https://gitee.com/andych008/timber_ohos 分析Timber的源码,及移植到鸿蒙需要做的工作. 大神 ...

  8. 2021S软件工程——案例分析作业

    2021S软件工程--案例分析作业 18231169 黄思为 项目 内容 这个作业属于哪个课程 2021春季软件工程(罗杰 任建) 这个作业的要求在哪里 案例分析作业 我在这个课程的目标是 了解并熟悉 ...

  9. 关于SpringBoot结合mybatis后遇到的坑

    先放出我遇到的出错信息,真的出错了可以先看看出错信息,就能更加高效准确的搜索到信息 我的报错日志: org.springframework.beans.factory.UnsatisfiedDepen ...

  10. 【日志追踪】(微服务应用和单体应用)-logback中的MDC机制

    一.MDC介绍 MDC(Mapped Diagnostic Contexts)映射诊断上下文,该特征是logback提供的一种方便在多线程条件下的记录日志的功能, 某些应用程序采用多线程的方式来处理多 ...