загрузить значения маршрутов netflix zuul из базы данных

Я изучал технологию шлюза API netflix zuul. Я разобрался со всем на месте и смог направить свой API с zuul URL-адресом прокси. Ниже мой код:

Основной класс

package com.example.springbootzuulgatwayproxy;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
import org.springframework.context.annotation.Bean;

import com.example.springbootzuulgatwayproxy.filters.ErrorFilter;
import com.example.springbootzuulgatwayproxy.filters.PostFilter;
import com.example.springbootzuulgatwayproxy.filters.PreFilter;
import com.example.springbootzuulgatwayproxy.filters.RouteFilter;

@SpringBootApplication
@EnableZuulProxy
public class SpringBootZuulgatwayproxyApplication {

    public static void main(String[] args) {

        SpringApplication.run(SpringBootZuulgatwayproxyApplication.class, args);
    }

    @Bean
    public PreFilter preFilter() {
        return new PreFilter();
    }
    @Bean
    public PostFilter postFilter() {
        return new PostFilter();
    }
    @Bean
    public ErrorFilter errorFilter() {
        return new ErrorFilter();
    }
    @Bean
    public RouteFilter routeFilter() {
        return new RouteFilter();
    }
}

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.example</groupId>
    <artifactId>spring-boot-zuulgatwayproxy</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>spring-boot-zuulgatwayproxy</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.4.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Dalston.SR2</spring-cloud.version>
    </properties>

    <dependencies>
        <!-- <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> 
            </dependency> -->
        <!-- <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> 
            </dependency> -->


        <dependency>
            <groupId>commons-configuration</groupId>
            <artifactId>commons-configuration</artifactId>
            <version>1.9</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-zuul</artifactId>
        </dependency>






        <!-- <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-rest</artifactId> 
            </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> 
            </dependency> -->

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>


</project>

application.properties

zuul.routes.employee.url=http://localhost:8090
zuul.routes.employee2.url=http://localhost:8090
server.port=8080

а затем есть 4 класса фильтров (Pre, Route, Post и Error), все из которых расширяют класс ZuulFilter.

все работает нормально. но теперь требуется, чтобы все поля zuul.routes.[entity].url в файле application.properties были загружены из базы данных вместе с их значениями url. Как я могу выполнить это требование. Пожалуйста посоветуй. Я попытался предварительно заполнить/обновить файл application.properties с аналогичными ключами. Удалось обновить/записать файл application.properties, но реальных эффектов во время выполнения не происходит. Что мне делать, чтобы установить эти ключи маршрута, определенные в файле свойств, для динамической загрузки из базы данных mysql.


person JPG    schedule 28.06.2018    source источник


Ответы (2)


Обновление маршрутов в application.properties не приводит к автоматической перезагрузке компонента ZuulProperties. Независимо от того, где хранятся маршруты, вам понадобится bean-компонент, похожий на:

@Primary @Bean(name = "zuulConfigProperties") @RefreshScope @ConfigurationProperties("zuul") public ZuulProperties zuulProperties() { ... }

ОБНОВЛЕНИЕ для включения конфигурации маршрутов:

zuul:
  ignoredServices: "*"
  routes:
    zuulDemo1:
      path: /zuul2/**
      serviceId: demo-zuul-api1
# stripPrefix set to true if context path is set to /
      stripPrefix: true

Это описано в сообщении блога, которое я написал, Маршрутизация запросов и динамическое обновление маршрутов с помощью Spring Cloud Zuul Server, хотя он не сохраняет маршруты в БД, но в файле с поддержкой Bitbucket, в котором есть WebHook, который отправляет запрос POST на сервер Zuul, который затем публикует сообщение брокеру (RabbitMQ), чтобы подписчики могли получить набор изменений.

person ootero    schedule 28.06.2018
comment
извините, я не могу понять вашу архитектуру здесь, вы используете стороннюю конфигурацию @ConfigurationProperties("zuul") с методом zuulProperties(). Но я хотел знать, как я могу загрузить эти свойства (аналогичные application.properties, упомянутым в вопросе выше), в этом специальном методе, возвращающем ZuulProperties. - person JPG; 01.07.2018
comment
можно ли что-то сделать с Route Filter? вы также можете объяснить мне, используя Map вместо db - person JPG; 01.07.2018

Если вы хотите сохранить значение маршрута в базе данных, вы можете проверить этот блог.

https://programmer.group/spring-cloud-gateway-service-zuul-three-dynamic-routing.html

Структура базы данных

CREATE TABLE `sys_zuul_route` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'router Id',
  `path` varchar(255) NOT NULL COMMENT 'Routing path',
  `service_id` varchar(255) NOT NULL COMMENT 'Service name',
  `url` varchar(255) DEFAULT NULL COMMENT 'url agent',
  `strip_prefix` char(1) DEFAULT '1' COMMENT 'Forward without prefix',
  `retryable` char(1) DEFAULT '1' COMMENT 'Do you want to retry?',
  `enabled` char(1) DEFAULT '1' COMMENT 'Is it enabled?',
  `sensitiveHeaders_list` varchar(255) DEFAULT NULL COMMENT 'Sensitive request header',
  `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'Creation time',
  `update_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT 'Update time',
  `del_flag` char(1) DEFAULT '0' COMMENT 'Remove identity (0-normal,1-Delete)',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='Dynamic routing configuration table'
person Theara    schedule 07.05.2021