深入理解 Nginx 与 Kong 的配置与实践

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: 在微服务架构中,Nginx 用于配置负载均衡,如示例所示,定义上游`pay-service`包含不同权重的服务节点。Kong API 网关则通过service和route进行服务管理和路由,与Nginx的upstream和location类似。通过Kong的命令行接口,可以创建upstream、target、service和route,实现对后端服务的负载均衡和请求管理。Nginx和Kong协同工作,提供高效、灵活的API管理和流量控制。

在现代的微服务架构中,服务之间的通信和负载坐标成为了关键环节。这篇文章将深入探讨如何通过 Nginx 配置实现服务的负载均衡,同时如何利用 Kong API 网关管理微服务,包括但不限于服务发现、路由、和负载坐标。我们将使用具体代码示例,确保即便是编程新手也能轻松领悟。

一、理解 Nginx 配置

Nginx 是一个高性能的 HTTP 和反向代理服务器,也被广泛用于负载均衡。首先,让我们来看一个基本的 Nginx 配置例子,这将帮助我们理解如何实现负载均衡。

Nginx 配置示例

upstream pay-service {
   
   
    server 127.0.0.1:5501 weight=2;
    server 127.0.0.1:5502 weight=4;
    server 127.0.0.1:5503 weight=8;
}

server {
   
   
    listen 80;
    server_name pay-service.xxx.com;

    location /paymanger {
   
   
        proxy_redirect             off;
        proxy_set_header           Host             $http_host;
        proxy_set_header           X-Real-IP        $remote_addr;
        proxy_set_header           X-Forwarded-For  $proxy_add_x_forwarded_for;

        proxy_cookie_path / "/; secure; HttpOnly; SameSite=strict";

        proxy_pass                 http://pay-service;
    }   
}

上面的配置定义了一个名为 pay-service 的 upstream,它包括三个后端服务节点,通过不同的权重分配处理请求。这里的权重意味着 127.0.0.1:5503 的请求处理能力是 127.0.0.1:5501 的四倍。

核心概念解释:

  • upstream: 用来定义一组后端服务节点。
  • server: 监听客户端请求的配置。
  • location: 匹配请求URI,并定义处理请求的配置。
  • proxy_pass: 指定请求转发的后端服务群组。
Kong 组件 说明
service service 对应服务,可以直接指向一个 API 服务节点(host 参数设置为 ip + port),也可以指定一个 upstream 实现负载均衡。简单来说,服务用于映射被转发的后端 API 的节点集合。 对应的就是以上的 proxy_pass http://pay-service; 这一行配置
route route 对应路由,它负责匹配实际的请求,映射到 service 中。 对应的就是以上的 /paymanger 配置
upstream upstream 对应一组 API 节点,实现负载均衡
target target 对应一个 API 节点 对应的就是以上的 127.0.0.1:5501 127.0.0.1:5502 127.0.0.1:5503 这三个节点

请求示例图

二、使用 Kong 进行服务管理

Kong 是一个云原生、快速、可扩展的微服务抽象层(API 网关),用于管理微服务的请求如路由、身份验证、监控等。

Kong 组件简介

  • service: 映射后端 API 节点集合。
  • route: 匹配并映射到 service。
  • upstream: 一组 API 节点,用于负载均衡。
  • target: 一个 API 节点。

创建 upstream 和 target

创建 upstream

curl -X POST http://127.0.0.1:8001/upstreams  --data "name=pay-service"
curl http://127.0.0.1:8001/upstreams

创建 target

curl -X POST http://127.0.0.1:8001/upstreams/pay-service/targets  \
--data "target=127.0.0.1:5501" \
--data "weight=2"

curl -X POST http://127.0.0.1:8001/upstreams/pay-service/targets  \
--data "target=127.0.0.1:5502" \
--data "weight=4"

curl -X POST http://127.0.0.1:8001/upstreams/pay-service/targets  \
--data "target=127.0.0.1:5503" \
--d...

以上命令将创建三个带有不同权重的 target,对应到之前的 Nginx 配置的三个服务节点。

创建 service 和 route

# 创建 service
curl -X POST http://127.0.0.1:8001/services  \
--data "name=payment-service" \
--data "host=pay-service"

# 创建 service 对应的 route
curl -X POST http://127.0.0.1:8001/services/payment-service/routes  \
--data "name=payment-service-route" \
--data "paths[]=/paymanger"

通过上述配置,当用户请求 /paymanger 时,Kong 会映射这个请求到 payment-service,并通过 upstream pay-service 实现负载均衡。

结语

Nginx 和 Kong 在现代微服务架构中起到了至关重要的角色。Nginx 擅长处理静态内容、负载均衡和反向代理,而 Kong 提供了一个强大的 API 管理平台,让你可以更容易地管理和监控你的 API。希望这篇文章能够帮助你深入理解它们的工作原理和配置方法。

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
1月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
83 7
|
6天前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
38 5
|
1月前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
1月前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
22天前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
43 3
|
1月前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
263 1
nginx配置反向代理404问题
|
1月前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
55 4
|
1月前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
55 3
|
1月前
|
安全 应用服务中间件 网络安全
配置Nginx反向代理实现SSL加密访问的步骤是什么?
我们可以成功地配置 Nginx 反向代理实现 SSL 加密访问,为用户提供更安全、可靠的网络服务。同时,在实际应用中,还需要根据具体情况进行进一步的优化和调整,以满足不同的需求。SSL 加密是网络安全的重要保障,合理配置和维护是确保系统安全稳定运行的关键。
107 3
|
1月前
|
应用服务中间件 网络安全 nginx
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
215 1