C++ 全栈知识体系C++ 全栈知识体系
✿导航
  • 基础
  • 函数
  • 知识点
  • IO框架
  • 新版本特性
  • 数据库原理
  • SQL语言
  • SQL - MySQL
  • NoSQL - Redis
  • NoSQL - ElasticSearch
  • 算法基础
  • 常见算法
  • 领域算法
  • 分布式算法
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • 计算机组成
  • 开发
  • 测试
  • 架构基础
  • 分布式系统
  • 微服务
  • 中间件
  • 概念
  • 理论
  • 架构设计原则
  • 设计模式
  • 协议
  • 技术选型
  • 编码规范
  • 流水线构建 - CI/CD
  • 知识点 - Linux
  • 网站 - Nginx
  • 容器化 - Docker
  • 容器编排 - Kubernetes
  • 服务网格 - Service Mesh Istio
  • 常用快捷键 - Shortcut
  • 工具使用 - Tools
  • 开源项目
  • 学习项目
  • 个人项目
  • 项目开发
  • 项目Idea
  • 并发
  • 部署
  • 分布式
  • 知识
  • 问题
  • 编程语言与技术
  • 系统与架构
  • 软件开发实践
  • 数据处理与应用设计
  • 个人
  • 产品
  • 团队
  • 知识体系
  • Vue
关于
✿导航
  • 基础
  • 函数
  • 知识点
  • IO框架
  • 新版本特性
  • 数据库原理
  • SQL语言
  • SQL - MySQL
  • NoSQL - Redis
  • NoSQL - ElasticSearch
  • 算法基础
  • 常见算法
  • 领域算法
  • 分布式算法
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • 计算机组成
  • 开发
  • 测试
  • 架构基础
  • 分布式系统
  • 微服务
  • 中间件
  • 概念
  • 理论
  • 架构设计原则
  • 设计模式
  • 协议
  • 技术选型
  • 编码规范
  • 流水线构建 - CI/CD
  • 知识点 - Linux
  • 网站 - Nginx
  • 容器化 - Docker
  • 容器编排 - Kubernetes
  • 服务网格 - Service Mesh Istio
  • 常用快捷键 - Shortcut
  • 工具使用 - Tools
  • 开源项目
  • 学习项目
  • 个人项目
  • 项目开发
  • 项目Idea
  • 并发
  • 部署
  • 分布式
  • 知识
  • 问题
  • 编程语言与技术
  • 系统与架构
  • 软件开发实践
  • 数据处理与应用设计
  • 个人
  • 产品
  • 团队
  • 知识体系
  • Vue
关于
  • 流水线构建 - CI/CD

    • CI/CD - 基础
    • CI/CD - 部署
    • CI/CD - 本地仓库CI流程
    • CI/CD - 远程仓库CI流程
  • 知识点 - Linux

    • Linux - 常用命令大全
    • Linux - 信号
    • Linux - 线程
    • Linux - 进程
    • Linux - 线程和进程同步
    • Linux - shell命令使用技巧
    • Linux - 使echo命令输出结果带颜色
  • 网站 - Nginx

    • Nginx - 学习笔记
    • Nginx - 部署静态页面网站
    • Nginx - 反向代理服务器
    • Nginx - 错误日志配置及信息详解
    • Nginx - 图片服务器配置
  • 容器化 - Docker

    • Docker - 容器技术Docker、Compose、k8s的演变
    • Docker - Dockerfile学习
    • Docker - 命令大全
    • Docker - Docker-compose学习
  • 容器编排 - Kubernetes

    • Kubernetes - 概念
    • Kubernetes - 基础应用
    • Kubernetes - 命令
    • Kubernetes - 检测探针
  • 服务网格 - Service Mesh Istio

    • Istio - 基础
    • Istio - 安装
    • Istio - 使用
    • Istio - 架构解析
    • Istio - 可观察性
    • Istio - 通过阿里云ecs部署k8s集群
  • 常用快捷键 - Shortcut

    • Shortcut - Linux
    • Shortcut - Vim
    • Shortcut - VsCode
    • Shortcut - IDEA
  • 工具使用 - Tools

    • Tools - cmake使用指南
    • Tools - cmake install详解
    • Tools - curl使用方法
    • Tools - docker使用方法
    • Tools - GCC警告选项
    • Tools - GCC和动静态库
    • Tools - gdb调试方法
    • Tools - nginx安装以及使用
    • Tools - VsCode插件

Nginx - 反向代理服务器

  • 正向代理
  • 反向代理
  • 两者的区别
  • 反向代理服务器简单实例
  • 负载均衡实例

Nginx正向代理与反向代理概念

nginx能够提供以下几种服务:

  • http服务器
    • 能处理http协议
  • 反向代理服务器
  • 邮件服务器
    • IMAP/POP3/SMTP

正向代理

  1. 代理内部网络对Internet的连接请求
  2. 客户机必须指定代理服务器
  3. 代理服务器是为用户服务的

正向代理

反向代理

  1. 以代理服务器来接受Internet上的连接请求
  2. 将请求转发给内部网络上的服务器
  3. 将服务器上得到的结果返回给Internet上请求连接的客户端

反向代理

两者的区别

正向代理: * 典型用途是为在防火墙内的局域网客户端提供访问Internet的途径。 * 正向代理还可以使用缓冲特性减少网络使用率。 反向代理: * 典型用途是将防火墙后面的服务器提供给Internet用户访问。 * 反向代理还可以为后端的多台服务器提供负载平衡,或为后端较慢的服务器提供缓冲服务。

反向代理服务器简单实例

设计思路:

利用windows机器搭建nginx反向代理服务器,为创建的两个虚机的nginx的web服务器提供代理服务。

  1. 远程登录192.168.2.230和192.168.2.231虚机,启动nginx服务
[root@192 ~]# systemctl stop httpd
[root@192 ~]# systemctl stop firewalld.service
[root@192 ~]# /usr/local/nginx/sbin/nginx
  1. 校验是否能在window机器上访问对应IP地址:

访问ip地址校验1访问ip地址校验2

3. 在window上启动nginx反向代理服务器,设置文件nginx.conf

设计的格式如下: 	

    #设置反向代理
	upstream myprj.test{
	   server 192.168.2.230:80;  
	}
	
	
	#要配置代理的服务器信息
	# myprj.com - 192.168.2.230 
    server {
        listen       80;
        server_name  myprj.com;

        location / {
            #设置代理
            proxy_pass http://myprj.test;
        }
	}

此外还需要手动修改windows机器上的C:\Windows\System32\drivers\etc 下的hosts文件,使得IP和主机名成映射关系。

192.168.2.230  myprj.com
192.168.2.231  myweb.com
  1. 使用对应域名访问nginx服务器,如果能够访问成功,表明反向代理服务器搭建完成。

通过域名访问

负载均衡实例

修改nginx.conf文件的内容:

   #设置反向代理
	upstream linux.test{
	   server 192.168.2.230:80; 
	   server 192.168.2.231:80;  	   
	}
	

	#要配置代理的服务器信息
    server {
        listen       80;
        server_name  localhost;

        location / {
            #设置代理
            proxy_pass http://linux.test;
        }
	}

可以直接通过http://localhost/  网址 均等机会访问192.168.2.230:80 和192.168.2.231:80 的nginx服务器。

进一步,修改对应服务器的权值,使得性能高的服务器,更大几率被访问。

#设置反向代理
	upstream linux.test{
	   server 192.168.2.230:80 weight=5; 
	   server 192.168.2.231:80 weight=1;  	   
	}
Last Updated:
Contributors: klc407073648
Prev
Nginx - 部署静态页面网站
Next
Nginx - 错误日志配置及信息详解