跳转到主要内容

traefik-gateway-dashboard

本文为dashboard用法,基础用法请参考:traefik-gateway

重要bug提醒:截止至2023-06-22,如果动态创建的服务发现,少于1个中间件,则会出错,既需要保证整个项目至少要有一个中间件。可以随便写一个,但是必须要有一个。

三个镜像

2023-06-21:无需再部署dashboard

  • traefik

    • swr.cn-south-1.myhuaweicloud.com/vp-whdev/all-in-devops/traefik:v1.4.20231227
      • 内置插件:rewritebody
      • 内置插件:rewriteHeaders

    更新日志:2023-12-27

    • 增加环境变量: "INDEX_ROOT=/root/"

    以支持动态创建首页不是从根目录开始。既不再需要单独挂载配置以设置首页不是从根目录开始,注意路径需要 /dir/ 的前后2个反斜杠(/)都需要。因为内部方式为字符串替换, sed -i 's|/traefik-dashboard/|'${INDEX_ROOT}'traefik-dashboard/|g' /etc/traefik/conf.d/traefik-dashboard.yaml 应用程序不会处理任何额外的内容。你也可以继续使用外挂文件自行处理首页不是根目录(不推荐)。

    • 增加环境变量:'PASSWRD=admin:httpwd'

    可以在外部设置用户名和密码,密码使用htpasswd方式是生成,在线生成网址:http://www.jsons.cn/htpasswd/ 注意,由于设置放置于环境变量,需要将($)特殊符号进行处理,($)使用($$)

    更新日志:2023-06-26

    • 修改内置插件偶尔会失效的问题
  • 动态服务发现

    • swr.cn-south-1.myhuaweicloud.com/vp-whdev/all-in-devops/traefik-service-discovery:v1.4.20231227

    更新日志:2023-12-27

    • 增加监控和告警功能
    • 修改配置文件值

    spring.profiles.active = dev|prod|sqlite-dev|sqlite-prod dev和prod为mysql数据库,sqlite-dev和sqlite-prod为sqlite数据库。由于sqlite数据不支持某些特性,将被弃用。

    更新日志:2023-06-28

    • 动态服务发现静态资源添加服务监控前端代码
    • 修复镜像包运行entrypoint.sh文件不存在问题
    • mysql数据脚本调整

    更新日志:2023-06-21:

    • 打包dashboard面板到一个服务,无需再部署dashboard
    • 增加服务监控
  • dashboard面板

    • swr.cn-south-1.myhuaweicloud.com/vp-whdev/all-in-devops/traefik-service-discovery-dashboard-front:stage

    更新日志:2023-06-21

    • dashboard面板已经集成到动态服务发现,无需部署

安装部署说明

  • 部署: traefik
# 建议服务名:traefik-gateway
# 端口开放
# 80,http端口
# 443,https端口
# 8080,traefik自带的dashboard端口,可以不开放
  • 部署traefik-service-discovery
# 服务名必须为 traefik-service-discovery


# 端口开放
# 8080,非必须

# 环境变量

spring.profiles.active = prod|sqlite-prod

# prod,使用mysql数据库,sqlite-prod,使用sqlite数据库,sqlite不支持服务监控,不推荐使用,在未来的版本中,sqlite数据库将被弃用。
# 如果使用sqlite数据库,需要注意数据库持久化路径,容器目录/data,容器初始化时会自动复制初始化数据库文件。


# 设置mysql数据库配置

app.datasource.host =
app.datasource.name=
app.datasource.password =
app.datasource.username =

  • 数据库初始化脚本

-- ----------------------------
-- Table structure for traefik-gateway
-- ----------------------------
DROP TABLE IF EXISTS `traefik_gateway_config`;
CREATE TABLE `traefik_gateway_config` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `route_name` varchar(255) DEFAULT NULL COMMENT '路由名称',
  `host_name` varchar(255) DEFAULT NULL COMMENT '主机名',
  `access_path` varchar(255) DEFAULT NULL COMMENT '访问路径',
  `service_type` int(2) DEFAULT NULL COMMENT '后端服务类型: 1:http 2:tcp 3:udp',
  `service_address` varchar(255) DEFAULT NULL COMMENT '后端服务地址',
  `middleware` text COMMENT '中间件',
  `status` int(255) DEFAULT NULL COMMENT '启用/禁用状态: 0:禁用 1:启用',
  `deleted` int(255) DEFAULT '0' COMMENT '删除状态: 0:不删除 1:删除',
  PRIMARY KEY (`id`) USING BTREE
) COMMENT='网关配置';

-- ----------------------------
-- Table structure for global_middleware
-- ----------------------------
DROP TABLE IF EXISTS `global_middleware`;
CREATE TABLE `global_middleware` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `global_middleware` longtext COMMENT '全局中间件',
  PRIMARY KEY (`id`) USING BTREE
) COMMENT='全局中间件';

DROP TABLE IF EXISTS `QRTZ_JOB_DETAILS`;
CREATE TABLE QRTZ_JOB_DETAILS(
  SCHED_NAME VARCHAR(120) NOT NULL,
  JOB_NAME VARCHAR(200) NOT NULL,
  JOB_GROUP VARCHAR(200) NOT NULL,
  DESCRIPTION VARCHAR(250) NULL,
  JOB_CLASS_NAME VARCHAR(250) NOT NULL,
  IS_DURABLE VARCHAR(1) NOT NULL,
  IS_NONCONCURRENT VARCHAR(1) NOT NULL,
  IS_UPDATE_DATA VARCHAR(1) NOT NULL,
  REQUESTS_RECOVERY VARCHAR(1) NOT NULL,
  JOB_DATA BLOB NULL,
  PRIMARY KEY (SCHED_NAME,JOB_NAME,JOB_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_TRIGGERS`;
CREATE TABLE QRTZ_TRIGGERS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  TRIGGER_NAME VARCHAR(200) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  JOB_NAME VARCHAR(200) NOT NULL,
  JOB_GROUP VARCHAR(200) NOT NULL,
  DESCRIPTION VARCHAR(250) NULL,
  NEXT_FIRE_TIME BIGINT(13) NULL,
  PREV_FIRE_TIME BIGINT(13) NULL,
  PRIORITY INTEGER NULL,
  TRIGGER_STATE VARCHAR(16) NOT NULL,
  TRIGGER_TYPE VARCHAR(8) NOT NULL,
  START_TIME BIGINT(13) NOT NULL,
  END_TIME BIGINT(13) NULL,
  CALENDAR_NAME VARCHAR(200) NULL,
  MISFIRE_INSTR SMALLINT(2) NULL,
  JOB_DATA BLOB NULL,
  PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
  FOREIGN KEY (SCHED_NAME,JOB_NAME,JOB_GROUP)
  REFERENCES QRTZ_JOB_DETAILS(SCHED_NAME,JOB_NAME,JOB_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_SIMPLE_TRIGGERS`;
CREATE TABLE QRTZ_SIMPLE_TRIGGERS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  TRIGGER_NAME VARCHAR(200) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  REPEAT_COUNT BIGINT(7) NOT NULL,
  REPEAT_INTERVAL BIGINT(12) NOT NULL,
  TIMES_TRIGGERED BIGINT(10) NOT NULL,
  PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
  FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
  REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_CRON_TRIGGERS`;
CREATE TABLE QRTZ_CRON_TRIGGERS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  TRIGGER_NAME VARCHAR(200) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  CRON_EXPRESSION VARCHAR(120) NOT NULL,
  TIME_ZONE_ID VARCHAR(80),
  PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
  FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
  REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_SIMPROP_TRIGGERS`;  
CREATE TABLE QRTZ_SIMPROP_TRIGGERS
(
  SCHED_NAME VARCHAR(120) NOT NULL,
  TRIGGER_NAME VARCHAR(200) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  STR_PROP_1 VARCHAR(512) NULL,
  STR_PROP_2 VARCHAR(512) NULL,
  STR_PROP_3 VARCHAR(512) NULL,
  INT_PROP_1 INT NULL,
  INT_PROP_2 INT NULL,
  LONG_PROP_1 BIGINT NULL,
  LONG_PROP_2 BIGINT NULL,
  DEC_PROP_1 NUMERIC(13,4) NULL,
  DEC_PROP_2 NUMERIC(13,4) NULL,
  BOOL_PROP_1 VARCHAR(1) NULL,
  BOOL_PROP_2 VARCHAR(1) NULL,
  PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
  FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
  REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_BLOB_TRIGGERS`;
CREATE TABLE QRTZ_BLOB_TRIGGERS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  TRIGGER_NAME VARCHAR(200) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  BLOB_DATA BLOB NULL,
  PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
  INDEX (SCHED_NAME,TRIGGER_NAME, TRIGGER_GROUP),
  FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
  REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_CALENDARS`;
CREATE TABLE QRTZ_CALENDARS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  CALENDAR_NAME VARCHAR(200) NOT NULL,
  CALENDAR BLOB NOT NULL,
  PRIMARY KEY (SCHED_NAME,CALENDAR_NAME))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_PAUSED_TRIGGER_GRPS`;  
CREATE TABLE QRTZ_PAUSED_TRIGGER_GRPS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  PRIMARY KEY (SCHED_NAME,TRIGGER_GROUP))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_FIRED_TRIGGERS`;
CREATE TABLE QRTZ_FIRED_TRIGGERS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  ENTRY_ID VARCHAR(95) NOT NULL,
  TRIGGER_NAME VARCHAR(200) NOT NULL,
  TRIGGER_GROUP VARCHAR(200) NOT NULL,
  INSTANCE_NAME VARCHAR(200) NOT NULL,
  FIRED_TIME BIGINT(13) NOT NULL,
  SCHED_TIME BIGINT(13) NOT NULL,
  PRIORITY INTEGER NOT NULL,
  STATE VARCHAR(16) NOT NULL,
  JOB_NAME VARCHAR(200) NULL,
  JOB_GROUP VARCHAR(200) NULL,
  IS_NONCONCURRENT VARCHAR(1) NULL,
  REQUESTS_RECOVERY VARCHAR(1) NULL,
  PRIMARY KEY (SCHED_NAME,ENTRY_ID))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_SCHEDULER_STATE`;
CREATE TABLE QRTZ_SCHEDULER_STATE (
  SCHED_NAME VARCHAR(120) NOT NULL,
  INSTANCE_NAME VARCHAR(200) NOT NULL,
  LAST_CHECKIN_TIME BIGINT(13) NOT NULL,
  CHECKIN_INTERVAL BIGINT(13) NOT NULL,
  PRIMARY KEY (SCHED_NAME,INSTANCE_NAME))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

DROP TABLE IF EXISTS `QRTZ_LOCKS`;
CREATE TABLE QRTZ_LOCKS (
  SCHED_NAME VARCHAR(120) NOT NULL,
  LOCK_NAME VARCHAR(40) NOT NULL,
  PRIMARY KEY (SCHED_NAME,LOCK_NAME))
  ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4;

CREATE INDEX IDX_QRTZ_J_REQ_RECOVERY ON QRTZ_JOB_DETAILS(SCHED_NAME,REQUESTS_RECOVERY);
CREATE INDEX IDX_QRTZ_J_GRP ON QRTZ_JOB_DETAILS(SCHED_NAME,JOB_GROUP);

CREATE INDEX IDX_QRTZ_T_J ON QRTZ_TRIGGERS(SCHED_NAME,JOB_NAME,JOB_GROUP);
CREATE INDEX IDX_QRTZ_T_JG ON QRTZ_TRIGGERS(SCHED_NAME,JOB_GROUP);
CREATE INDEX IDX_QRTZ_T_C ON QRTZ_TRIGGERS(SCHED_NAME,CALENDAR_NAME);
CREATE INDEX IDX_QRTZ_T_G ON QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_GROUP);
CREATE INDEX IDX_QRTZ_T_STATE ON QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_STATE);
CREATE INDEX IDX_QRTZ_T_N_STATE ON QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP,TRIGGER_STATE);
CREATE INDEX IDX_QRTZ_T_N_G_STATE ON QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_GROUP,TRIGGER_STATE);
CREATE INDEX IDX_QRTZ_T_NEXT_FIRE_TIME ON QRTZ_TRIGGERS(SCHED_NAME,NEXT_FIRE_TIME);
CREATE INDEX IDX_QRTZ_T_NFT_ST ON QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_STATE,NEXT_FIRE_TIME);
CREATE INDEX IDX_QRTZ_T_NFT_MISFIRE ON QRTZ_TRIGGERS(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME);
CREATE INDEX IDX_QRTZ_T_NFT_ST_MISFIRE ON QRTZ_TRIGGERS(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME,TRIGGER_STATE);
CREATE INDEX IDX_QRTZ_T_NFT_ST_MISFIRE_GRP ON QRTZ_TRIGGERS(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME,TRIGGER_GROUP,TRIGGER_STATE);

CREATE INDEX IDX_QRTZ_FT_TRIG_INST_NAME ON QRTZ_FIRED_TRIGGERS(SCHED_NAME,INSTANCE_NAME);
CREATE INDEX IDX_QRTZ_FT_INST_JOB_REQ_RCVRY ON QRTZ_FIRED_TRIGGERS(SCHED_NAME,INSTANCE_NAME,REQUESTS_RECOVERY);
CREATE INDEX IDX_QRTZ_FT_J_G ON QRTZ_FIRED_TRIGGERS(SCHED_NAME,JOB_NAME,JOB_GROUP);
CREATE INDEX IDX_QRTZ_FT_JG ON QRTZ_FIRED_TRIGGERS(SCHED_NAME,JOB_GROUP);
CREATE INDEX IDX_QRTZ_FT_T_G ON QRTZ_FIRED_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP);
CREATE INDEX IDX_QRTZ_FT_TG ON QRTZ_FIRED_TRIGGERS(SCHED_NAME,TRIGGER_GROUP);

DROP TABLE IF EXISTS `traefik_alarm_log`;
CREATE TABLE `traefik_alarm_log` (
  `id` varchar(32) NOT NULL DEFAULT '0' COMMENT '主键id',
  `project_id` varchar(32) DEFAULT NULL COMMENT '项目ID',
  `service_id` varchar(32) DEFAULT NULL COMMENT '服务ID',
  `receive_mobile` varchar(255) DEFAULT NULL COMMENT '接收手机号',
  `receive_email` varchar(255) DEFAULT NULL COMMENT '接收邮箱',
  `send_state` tinyint(1) DEFAULT NULL COMMENT '发送状态 0:成功 1:失败',
  `alarm_time` datetime DEFAULT NULL COMMENT '报警时间',
  `err_msg` text COMMENT '错误信息',
  PRIMARY KEY (`id`)
) COMMENT='服务报警日志';

DROP TABLE IF EXISTS `traefik_monitor_contacts`;
CREATE TABLE `traefik_monitor_contacts` (
  `id` varchar(32) NOT NULL DEFAULT '0' COMMENT '主键id',
  `project_id` varchar(32) DEFAULT NULL COMMENT '项目ID',
  `contacts` varchar(64) DEFAULT NULL COMMENT '联系人',
  `contact_type` tinyint(1) DEFAULT NULL COMMENT '联系方式(1:手机,2:邮箱)',
  `contact_no` varchar(128) DEFAULT NULL COMMENT '联系号码',
  PRIMARY KEY (`id`)
) COMMENT='项目联系人';

DROP TABLE IF EXISTS `traefik_project_management`;
CREATE TABLE `traefik_project_management` (
  `id` varchar(32) NOT NULL DEFAULT '0' COMMENT '主键id',
  `project_name` varchar(64) DEFAULT NULL COMMENT '项目名称',
  `threshold` int(2) DEFAULT NULL COMMENT '阈值',
  `monitoring_frequency` tinyint(5) DEFAULT NULL COMMENT '监控频率',
  `status` tinyint(1) DEFAULT '0' COMMENT '启用/禁用状态: 0:禁用 1:启用',
  `job_id` varchar(32) DEFAULT NULL COMMENT '定时任务ID',
  `deleted` int(255) DEFAULT '0' COMMENT '删除状态: 0:未删除 1:删除',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) COMMENT='项目管理';

DROP TABLE IF EXISTS `traefik_service_monitor`;
CREATE TABLE `traefik_service_monitor` (
  `id` varchar(32) NOT NULL DEFAULT '0' COMMENT '主键id',
  `project_id` varchar(32) DEFAULT NULL COMMENT '项目ID',
  `sevice_name` varchar(64) DEFAULT NULL COMMENT '服务名称',
  `listening_address` varchar(255) DEFAULT NULL COMMENT '监听接口地址',
  `service_type` tinyint(1) DEFAULT '1' COMMENT '接口类型: 0:POST 1:GET',
  `status` tinyint(1) DEFAULT '0' COMMENT '启用/禁用状态: 0:禁用 1:启用',
  `deleted` int(255) DEFAULT '0' COMMENT '删除状态: 0:未删除 1:删除',
  `delete_time` datetime DEFAULT NULL COMMENT '删除时间',
  `latest_alarm_time` datetime DEFAULT NULL COMMENT '最新报警时间',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  `service_status` tinyint(1) DEFAULT '0' COMMENT '服务状态: 0:成功 1:失败',
  `restart_number` int(6) DEFAULT '0' COMMENT '失败重启次数',
  PRIMARY KEY (`id`)
) COMMENT='服务监听';


  • traefik-service-discovery-dashboard-fron
# 2023-06-21,本服务已经集成到traefik-service-discovery,不需要部署
# 端口开放:80
# 访问路径/front/
  • 负载均衡配置
路径 服务 说明 备注
/ traefik 网站根目录 必须
/traefik-dashboard/ traefik traefik内置的dashboard 非必须,如果没有配置网站根目录则需要
/traefikconfig-dashboard/ traefik traefik动态路由dashboard 非必须,如果没有配置网站根目录则需要
/traefik-service-discovery/ traefik 动态路由api 非必须,如果没有配置网站根目录则需要

首页不是从根目录开始

如果你的首页不是从根目录开始,则需要做一些单独的配置,实现原理为,将dashboard需要用到的3个路径处理为所需要的目录。

复制下面的配置文件,挂载到traefik-gatewy的容器路径

# 使用k8s集群时,建议使用配置映射卷

./index-not-root.yaml:/etc/traefik/conf.d/conf2/index-not-root.yaml

需要在负载均衡加入配置

路径 服务 说明 备注
/minio/ traefik 业务路由入口 必须
/_minio/ traefik 面板路由入口 如果配置了下面三个路径,则是非必须
/_minio/traefik-dashboard/ traefik traefik内置的dashboard 非必须,如果没有配置面板入口则需要
/_minio/traefikconfig-dashboard/ traefik 动态路由dashboard 非必须,如果没有配置面板入口则需要
/_minio/traefik-service-discovery/ traefik 动态路由api 非必须,如果没有配置面板入口则需要

http:
  routers:
    # 首页不是根目录
    index-not-root:
    # 注意路由匹配前缀,填写你的实际路径,为了保证一致性,建议本服务使用 _ 开头
    # 注意中间件中的路径前缀,应该和路由路径一致,
    # 注意重写header的前缀,应该和路由路径一致。
    # 根据本路由规则,可以看出是将服务又重定向到traefik-gateway,即多了一层不必要的代理,会带来性能损失。
    # 由此,这个额外的路由,只应该用于处理traefik控制面板
    # 真正的服务不应该由此处理,而应该直接指向到traefik-gateway
    # 既你需要配置面板路由路径,应该与你的服务路径,使用不通的名称
    # 本次使用的是 _minio ,请将本文的_minio 替换为你需要的
      # rule: "PathPrefix(`/_minio/`)" 
    # 2023-06-22,:只处理dashboard相关的3个路径,以开启面板,业务路由在面板进行配置,以解决多了一层代理问题   
      rule: "PathPrefix(`/_minio/traefik-dashboard/`) || PathPrefix(`/_minio/traefikconfig-dashboard/`) || PathPrefix(`/_minio/traefik-service-discovery/`)"  
      service: index-not-root
      middlewares:
        - stripPrefix-index-not-root
        - rewritebody-index-not-root
        - rewriteHeaders-index-not-root
  services:
    index-not-root:
      loadBalancer:
        servers:
          - url: http://traefik-gateway:80    # 部署的traefik主程序必须叫这个名字或者修改为实际部署的名字
  middlewares:
  # 去除前缀  
    stripPrefix-index-not-root:
      stripPrefix:
        prefixes:
          - "/_minio/"
  # 正文路径改写
    rewritebody-index-not-root:
      plugin:
        plugin-rewritebody:                   # 要和静态配置文件的插件名称对应上
          rewrites:
            - regex: "/traefik-service-discovery/api/"
              replacement: "/_minio/traefik-service-discovery/api/"
            - regex: "/traefik-dashboard/api"
              replacement: "/_minio/traefik-dashboard/api"
            - regex: "/_minio/dashboard/"
              replacement: "/_minio/traefik-dashboard/dashboard/"
  # Header重定向改写
    rewriteHeaders-index-not-root:
      plugin:
        plugin-rewriteHeaders:                # 要和静态配置文件的插件名称对应上
          rewrites:
            - header: "Location"
              regex: "/_minio/dashboard/"
              replacement: "/_minio/traefik-dashboard/dashboard/"



插件使用

插件参考网址

middlewares:
# 删除路径前前缀,traefik默认会把整个URL路径全部传过来,会导致与后端路径不一致,需要进行路径删除处理
  stripPrefix-traefikconfig-dashboard:
    stripPrefix:
      prefixes:
        - "/traefikconfig-dashboard/"

# 增加路径前缀,对应与后端服务,即使在填写URL路径,traefik也不会处理后端路径,会导致与后端路径不一致,需要增加实际路径
  addPrefixFront-traefikconfig-dashboard:
    addPrefix:
      prefix: "/front/"

# 正文路径改写,由于某些情况下服务没有使用相对路径,需要对在页面写死的路径进行正则替换
  rewritebody-traefikconfig-dashboard:
      plugin:
        plugin-rewritebody: # 要和静态配置文件的插件名称对应上,本镜像仅能使用这个名字
          rewrites:
            - regex: "/api/"
              replacement: "/traefik-service-discovery/api/"   

# 基础身份验证
  basicAuth-traefikconfig-dashboard:
      basicAuth:
        removeHeader: true
        users:
          - "admin:" # 在线生成 http://www.jsons.cn/htpasswd/


# 发送到后端时修改header,例如后端限制了域名
  headers-peisong:
    headers:
      customRequestHeaders:
        host: "peisong.gxzszs.cn"

# 重写 header,对响应的head进行处理,例如写死的重定向
  rewriteHeaders-peisong:
    plugin:
      plugin-rewriteHeaders: # 要和静态配置文件的插件名称对应上,本镜像仅能使用这个名字
        rewrites:
          - header: "Location"
            regex: "peisong.gxzszs.cn"
            replacement: "peisong.gxfusui.com"
          - header: "Location"
            regex: "http://peisong.gxfusui.com/plugin.php"
            replacement: "/plugin.php"