当前位置: 首页 > article >正文

Apache APISIX学习(1):介绍、docker启动

 一、介绍

        Apache APISIX 是一个动态、实时、高性能的 API 网关, 提供负载均衡、动态上游、灰度发布、服务熔断、身份认证、可观测性等丰富的流量管理功能。你可以把 Apache APISIX 当做流量入口,来处理所有的业务数据,包括动态路由、动态上游、动态证书、 A/B 测试、金丝雀发布(灰度发布)、蓝绿部署、限流限速、抵御恶意攻击、监控报警、服务可观测性、服务治理等。

        Apache APISIX 的技术架构如下图所示:

二、下载镜像

        使用docker pull apache/apisix:2.10.0-alpine命令下载apisix镜像。

        使用docker pull apache/apisix-dashboard:2.9.0获取apisix-dashboard镜像。

三、启动apisix

1、启动etcd

        因为apisix依赖etcd,所以要先保证etcd启动。etcd安装步骤请移步ETCD学习使用-CSDN博客这篇文章。使用命令ps -ef | grep etcd查看是否已经启动。

2、创建配置文件

        在宿主机本地创建apisix的配置文件config.yaml。下面的key修改为自己的,这个key是调用apisix的admin相关API需要传的,如果不改会有一个默认的在源码里写死的,如果你部署在公网上会导致被别人攻击,因为知道这个key就可以随意调用你的API操作apisix。

        内容如下: 

apisix:
  admin_key:
    -
      name: admin
      # 使用固定API令牌存在安全风险,请在部署到生产环境时进行更新      
      key: zZ2Trn0WFjk3k34hjsdaReplrVUekVz  
      role: admin
etcd:
  host:  
    # 可以为同一个etcd集群定义多个etcd主机地址。
    # 如果您的etcd集群启用TLS,请使用https方案。
    # 例如 https://127.0.0.1:2379.
    - "http://192.168.197.131:2379" 
                                 
  prefix: /apisix  # Apisix配置前缀
  timeout: 300

3、启动apisix

        执行如下命令,启动容器:

docker run -d -p 9080:9080 -v /usr/local/apisix/conf/config.yaml:/usr/local/apisix/conf/config.yaml apache/apisix:2.10.0-alpine

        用浏览器访问http://服务器ip:9080/显示如下内容,表示启动成功。

4、启动apisix-dashboard

        在指定目录下创建配置文件conf.yaml

        内容如下:

conf:
  listen:
    host: 0.0.0.0         # Manager API应该监听的地址。
                          # 默认值为0.0.0.0,如果需要指定,请启用。
                          # 该值接受IPv4、IPv6和主机名
    port: 9000            # '管理器API '应该监听的端口。

  allow_list:             # 如果我们不设置任何IP列表,则默认情况下允许任何IP访问。
  etcd:
    endpoints:            # 支持为etcd定义多个etcd主机地址

cluster
      - 192.168.197.131:2379
    # username: "root"  #如果没开启授权,可以注掉
    # password: "123456" #如果没开启授权,可以注掉
authentication:
  secret:
    zQ5w5jkLDh3jZpywJ3sskrw6Yv633ruq
  expire_time: 3600     # JWT令牌过期时间,单位为秒
  users:                # Yamllint启用规则:comments-缩进
    - username: admin
      password: password
    - username: user
      password: password

        使用如下命令启动,我这里9000端口被占用了,所以转成了9111端口。

docker run -d -p 9111:9000 -v /usr/local/apisix-dashboard/conf/conf.yaml:/usr/local/apisix-dashboard/conf/conf.yaml apache/apisix-dashboard:2.9.0

        在浏览器输入服务器ip:9111进入登录界面:

        使用配置文件中admin/password即可登录成功。


http://www.kler.cn/news/316513.html

相关文章:

  • Java是怎么处理死锁的
  • 006——队列
  • 带线无人机现身俄罗斯抗干扰技术详解
  • HTML5 Video标签的属性、方法和事件汇总,以及常用视频插件推荐
  • 深蓝学院-- 量产自动驾驶中的规划控制算法 小鹏
  • G - Merchant Takahashi / F - Useless for LIS
  • mysql学习教程,从入门到精通,TOP 和MySQL LIMIT 子句(15)
  • 本地连线上Redis访问不通
  • SpringBoot权限认证-Sa-Token的使用与详解
  • C++第十二节课 模板初阶和string引入
  • Apache Flink 流批融合技术介绍
  • 安装vue 试了很多镜像不成功, 最后找到了
  • Sentence Transformers 教程!
  • LeetCode_sql_day28(1767.寻找没有被执行的任务对)
  • STM32 通过软件模拟 I2C 驱动 24Cxx 系列存储器
  • 沙盒的一机两用能否运用在源代码加密方面呢?
  • 随手记:前端一些定位bug的方法
  • java Class类与Field、Method、Constructor类
  • 大数据毕业设计选题推荐-网络电视剧收视率分析系统-Hive-Hadoop-Spark
  • 【网络编程】网页的显示过程
  • 软件工程的七条基本原理
  • JdbcTemplate常用方法一览AG网页参数绑定与数据寻址实操
  • pick你的第一个人形机器人——青龙强化学习环境测试
  • Vuex 入门与实战
  • CMake 教程(五):安装和测试
  • [全网首篇]关于 VMSA-2024-0019 安全公告(CVE-2024-38812、CVE-2024-38813)的说明与解决方案
  • 【系统架构设计师】软件架构的概念(经典习题)
  • Vue3.5+ 更新 - 模板引用
  • 【Go】Go语言中深拷贝和浅拷贝
  • PlantUML的使用以及各种图表示例