国产微服务 网关Apache APISIX 上手

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 2019 年 10 月 17 日,支流科技 API 网关 APISIX 进入 Apache 开始孵化。笔者表示去搜索了一下这家公司 OpenResty 圈内顶级大牛《OpenResty 最佳实践》作者 温铭 和 王院生,这就非常有意思了 APISIX 是一个高性能、可扩展的微服务 API 网关。

2019 年 10 月 17 日,支流科技 API 网关 APISIX 进入 Apache 开始孵化。笔者表示去搜索了一下这家公司 OpenResty 圈内顶级大牛《OpenResty 最佳实践》作者 温铭 和 王院生,这就非常有意思了

APISIX 是一个高性能、可扩展的微服务 API 网关。它是基于 Nginx 和 etcd 来实现,和传统 API 网关相比,
APISIX 作为微服务请求⽹关,通过插件提供负载平衡,⽇志记录,身份验证
等功能:

  • 动态负载均衡: ⽀持不同上游服务的动态负载均衡
  • 安全插件: 内置安全处理层,⽀持如OAuth2、ACL、CORS、动态 SSL 和
    IP 限制等
  • 流量控制插件: 速率限制,请求⼤⼩限制和响应速率限制等
  • 分析和监控插件:借助如 Prometheus,Datadog 和 Runscope 产品,完成
    API 流量的可视化、检查和监控
  • ⽇志插件:记录请求或响应⽇志,并通过 HTTP、TCP 或 UDP 等⽅式发送
    到你的系统(⽐如: StatsD, Syslog)

github: https://github.com/iresty , 可以看到相较于于 KongTraefik 从源码角度非常简洁。

安装

安装 openresty

  • 基于 OpenResty 实现的,记住 OpenResty一个基于Nginx 与Lua 的高性能Web 平台.
yum install yum-utils
yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo

yum install -y openresty 

安装 etcd

  • etcd 一个 (key-value) 强一致性NoSQL数据库。相较于 Kong使用的PostgreSQL关系型数据库,又是一大亮点
 yum install -y  etcd
 service etcd start

 yum install -y https://github.com/iresty/apisix/releases/download/v0.8/apisix-0.8-0.el7.noarch.rpm

启动 apisix

sudo apisix start

访问控制台: http://127.0.0.1:9080/apisix/dashboard/ ,直接访问即可

PS: 登录功能没有实现,骗人的!

功能体验

  • 目标我们实现web服务的反向代理,并且可以实现限流
  1. upstream > 添加

2 . routes > 添加

令牌桶限流配置

  • rate # 流速 每秒
  • burst # 令牌桶的容积
  • key #根据哪个header 来限流
  • rejected_code # 返回错误码
  • 访问: ip:9080/ 体验限流效果

在线演示版本

官方部署了一个在线的 dashboard ,方便大家了解 APISIX。
http://apisix.iresty.com

目录
相关文章
|
4天前
|
敏捷开发 负载均衡 监控
探索微服务架构下的API网关设计与实践
【5月更文挑战第31天】本文将深入剖析微服务架构中的关键组件——API网关,探讨其设计理念、核心功能以及在实际项目中的应用。我们将从API网关的基本概念出发,逐步展开对其路由、负载均衡、认证授权、监控日志等方面的详细讨论,并结合实际案例,分析如何高效地实现和管理一个稳定的API网关。
|
4天前
|
缓存 监控 安全
微服务架构下的API网关设计与实践
【5月更文挑战第31天】本文深入探讨了在微服务架构中,API网关的核心作用与设计策略。通过分析网关的职责、选型标准及实现细节,文章为读者提供了一套完整的API网关解决方案。同时,结合具体案例,展示了如何在实际应用中有效部署和优化API网关,确保系统的高可用性和可扩展性。
|
4天前
|
监控 应用服务中间件 API
探索微服务架构中的API网关模式
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构中的关键组件——API网关。我们将了解API网关的定义、功能以及它如何优化微服务的通信流程,提高安全性和性能。此外,我们还将讨论一些常见的API网关实现技术,并分析它们的优势和局限性。
|
4天前
|
监控 安全 API
微服务架构下的API网关设计原则
【5月更文挑战第31天】在本文中,我们将深入探讨微服务架构下API网关的设计原则。API网关作为微服务架构的入口点,其设计至关重要。我们将从性能、安全性、可扩展性等方面进行分析,并提出一些实用的设计建议。
|
4天前
|
负载均衡 测试技术 API
探索微服务架构中的API网关
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构中的一个关键组件——API网关。我们将了解它的定义、作用以及如何有效地实现它。此外,我们还将讨论一些最佳实践和可能遇到的挑战。
|
4天前
|
运维 负载均衡 安全
探索微服务架构下的API网关设计与实现
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构的关键组成部分——API网关。通过分析API网关的核心功能、设计原则以及实现技术,本文旨在为读者提供一个关于如何构建和维护高效、可靠的API网关的全面视角。我们将从API网关的基本概念出发,逐步深入到其在微服务架构中的作用,以及如何选择合适的技术栈来实现这一目标。最后,我们将通过一个具体的案例分析,展示API网关在实际项目中的应用和优化策略。
|
4天前
|
负载均衡 监控 安全
探索微服务架构中的API网关模式
本文深入探讨了在构建现代软件系统时,微服务架构中API网关的核心作用和实践策略。通过分析API网关的设计原则、实现技术以及面临的挑战,旨在为读者提供一套清晰的指导方针,以便在实际应用中有效地利用API网关来提升系统的可扩展性、安全性和性能。
|
5天前
|
负载均衡 监控 API
微服务架构中的API网关模式
本文将深入探讨微服务架构中的一个重要组件——API网关。我们将了解API网关的作用、实现方式以及它如何提高系统的可扩展性和安全性。通过实际案例分析,我们将展示API网关在微服务架构中的应用和优势。
|
6天前
|
负载均衡 监控 Kubernetes
构建高效微服务架构:API网关与服务发现的融合实践
【5月更文挑战第29天】 在当今的软件开发领域,微服务架构已成为一种流行的设计模式,其通过将应用程序拆分为一系列小型、自治的服务来提供灵活性和可扩展性。然而,随着服务数量的增加,确保通信效率和管理便捷性成为了关键挑战。本文聚焦于如何通过API网关和服务发现机制的有效整合,优化微服务间的交互,提高系统整体性能和可靠性。我们将探讨API网关在请求路由、负载均衡、安全性增强方面的作用,同时分析服务发现对于实现服务间动态通信的重要性,并展示两者如何协同工作以支持复杂的后端系统需求。
|
6天前
|
负载均衡 监控 API
构建高效微服务架构:API网关与服务发现的融合实践
【5月更文挑战第29天】 在微服务架构中,服务的分布式特性要求精确的服务发现机制和灵活的流量控制手段。本文将探讨如何通过合并API网关和服务发现功能来优化后端服务的通信效率,降低延迟,并提升系统的可伸缩性。我们将分析传统模式下两者独立运作的弊端,并提出一种集成方案,该方案不仅能够简化系统架构,还能增强服务的自愈能力。文章还将讨论实施过程中可能遇到的挑战及相应的解决策略。

推荐镜像

更多