通过 INFINI Console 集中管理极限网关配置

之前有做过介绍实现极限网关(INFINI Gateway) 配置动态加载,这是一个 Gateway 实例的操作,直接在服务器上修改配置文件。如果有多个 Gateway 实例需要调整,登录多台主机修改配置文件就有些繁琐,有没有简便的方法呢?

答案是: 当然有!

INFINI Gateway 有配套的管理页面,那就是 INFINI Console

Gateway 注册到 Console 后,就可以在如下的页面上进行管理。

其中 Config 可以查看到当前 Gateway 的配置。

当然不止有查看功能,也可以在这里修改配置,然后下发给 Gateway。

要实现这一功能,需要有相应的配置。

  1. 需要将下发的配置进行存储(存到 Console 的系统集群索引 .infini_configs 中)
python 复制代码
PUT .infini_configs/_doc/gateway_proxy_yml
{
  "payload": {
    "content": """
entry:
  - name: my_es_entry
    enabled: true
    router: my_router
    max_concurrency: 200000
    network:
      binding: 0.0.0.0:8000

flow:
  - name: simple_flow
    filter:
      - http:
          schema: https
          host: 192.168.0.102:9200

router:
  - name: my_router
    default_flow: simple_flow""",
    "version": 1,
    "name": "gateway_proxy.yml"
  },
  "metadata": {
    "labels": {
      "instance": "_all"
    },
    "category": "app_settings",
    "name": "gateway"
  },
  "id": "gateway_proxy_yml"
}
字段 是否必须 说明
payload.content 具体的 Gateway 配置
payload.version 当前配置的版本,用于确认是否同步配置
payload.name 配置下发后落地的文件名
metadata.labels 配置标签,instance: _all 表明所有 Gateway 实例都可以同步该配置
metadata.category 配置属于应用配置,Gateway 应填写 app_settings
metadata.name 配置属于哪类应用,可选 gateway、agent
id 配置 ID
  1. 配置 Gateway
yaml 复制代码
env:
  CONFIG_SERVER: http://192.168.0.102:9000

path.data: data
path.logs: log
path.configs: config # directory of additional gateway configurations

configs:
  auto_reload: true # set true to auto reload gateway configurations
  #for managed client's setting
  managed: true # managed by remote servers
  panic_on_config_error: false #ignore config error
  interval: "10s"
  servers: # config servers
    - $[[env.CONFIG_SERVER]]
  soft_delete: false
  max_backup_files: 5

api:
  enabled: true
  network:
    binding: 0.0.0.0:2900

配置中心参数详情请查阅文档

  1. 创建额外配置存储目录并启动 Gateway。
bash 复制代码
mkdir config
./gateway-mac-amd64

从日志中,可以看到 Gateway 已经注册到配置管理,获取到 gateway_proxy.yml,然后配置重新加载。

通过 Console 的 Gateway 配置管理页面查看下发的配置:

在页面上调整配置,点击 Save 保存。

注:更新完配置后,需同时增大配置的版本号(MANAGED_CONFIG_VERSION)。

从 Gateway 日志中可以看到,配置文件进行了同步并应用。

相关推荐
爬山算法6 分钟前
Redis(66)Redis如何实现分布式锁?
数据库·redis·分布式
游戏开发爱好者811 分钟前
FTP 抓包分析实战,命令、被动主动模式要点、FTPS 与 SFTP 区别及真机取证流程
运维·服务器·网络·ios·小程序·uni-app·iphone
Super Rookie40 分钟前
MongoDB 自动化脚本安装方案
数据库·mongodb·自动化
Code哈哈笑1 小时前
【MongoDB 基本语法】数据库和集合的基本操作--探秘 MongoDB
数据库·mongodb
恋红尘1 小时前
Redis面试八股
数据库·redis·面试
纸带2 小时前
USB --SETUP --STATUS阶段
linux·服务器·网络
直有两条腿2 小时前
【数据迁移】HBase Bulkload批量加载原理
大数据·数据库·hbase
言之。2 小时前
ClickHouse 数据更新策略深度解析:突变操作与最佳实践
服务器·数据库·clickhouse
ajassi20003 小时前
开源 Linux 服务器与中间件(三)服务器--Nginx
linux·服务器·开源
wheeldown3 小时前
【Linux】Linux进程间通信:命名管道(FIFO)的模拟实现重要知识点梳理
linux·运维·服务器