通过 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 日志中可以看到,配置文件进行了同步并应用。

相关推荐
为什么不问问神奇的海螺呢丶8 分钟前
服务器巡检报告-基于categraf 采集数据-存入Prometheus-写入mysql后生成报告
服务器·mysql·prometheus
网硕互联的小客服14 分钟前
遇到网站500内部服务器错误如何处理?如何预防这样的问题发生?
运维·服务器·安全
代码or搬砖20 分钟前
SQL核心语法总结:从基础操作到高级窗口函数
java·数据库·sql
26 分钟前
TIDB——TIKV——读写与coprocessor
数据库·分布式·tidb·
大猫和小黄1 小时前
若依微服务全面适配PostgreSQL-OpenGauss数据库
数据库·微服务·postgresql·若依
老徐电商数据笔记1 小时前
技术复盘第二篇:电商数据主题域划分企业级实践
大数据·数据库·数据仓库·零售·教育电商·技术面试
jfqqqqq1 小时前
postgres查询、重设自增序列的起始值
数据库·sql·postgres·自增序列
杰克崔1 小时前
进程内mmap锁相互干扰问题
linux·运维·服务器·车载系统
木泽八1 小时前
python实现pdf拆分与合并
服务器·python·pdf
2 小时前
TIDB——PD(placement Driver)
java·数据库·分布式·tidb·