ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

春季-Zuul为多个zuul路由实现Multiple ZuulFallbackProvider

2019-11-11 19:19:28  阅读:225  来源: 互联网

标签:spring-cloud-netflix spring-boot netflix-zuul netflix spring


我如何实现多个zuul路由的多个zuulFallbackProvider.
除了公开restcontroller并使用hystrixcommand实现方法外,我看不到如何使用属性的答案.

我可以使用自己的zuulFallBackProvider bean提供每项服务吗?

application.yml

    server:
      port: 8080

    hystrix:
      command:
        default:
          execution:
            isolation:
              thread:
                timeoutInMilliseconds: 20000

    ribbon:
      ReadTimeout: 20000
      ConnectTimeout: 20000

    zuul:
      prefix: /api
      ignoredServices: '*'
      host:
        connect-timeout-millis: 20000
        socket-timeout-millis: 20000
      routes:
        kicks-service:
          path: /kicks/**
          serviceId: kicks-service
          stripPrefix: false
          sensitiveHeaders:
        kicks-inventory:
          path: /inventory/**
          serviceId: kicks-inventory
          stripPrefix: false
          sensitiveHeaders: 

这是我的示例应用

    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableZuulProxy
    public class GatewayApplication {

        public static void main(String[] args) {
            SpringApplication.run(GatewayApplication.class, args);
        }

        @Bean
        public Prefilter prefilter(){
            return new Prefilter();
        }

        @Bean
        public ZuulFallbackProvider zuulFallbackProvider() {
            return new ZuulFallbackProvider() {
                @Override
                public String getRoute() {
                    return "kicks-inventory";
                }

                @Override
                public ClientHttpResponse fallbackResponse() {
                    return new ClientHttpResponse() {
                        @Override
                        public HttpStatus getStatusCode() throws IOException {
                            return HttpStatus.OK;
                        }

                        @Override
                        public int getRawStatusCode() throws IOException {
                            return 200;
                        }

                        @Override
                        public String getStatusText() throws IOException {
                            return "OK";
                        }

                        @Override
                        public void close() {

                        }

                        @Override
                        public InputStream getBody() throws IOException {
                            return new ByteArrayInputStream("fallback".getBytes());
                        }

                        @Override
                        public HttpHeaders getHeaders() {
                            HttpHeaders headers = new HttpHeaders();
                            headers.setContentType(MediaType.APPLICATION_JSON);
                            return headers;
                        }
                    };
                }
            };
        }
    }

解决方法:

每条路线将需要一个单独的bean.他们应该为getRoute方法返回不同的路由.

请检查此-http://tachniki.blogspot.in/2017/02/generic-ZuulFallbackProvider.html.希望它会使其更容易一些.

标签:spring-cloud-netflix,spring-boot,netflix-zuul,netflix,spring
来源: https://codeday.me/bug/20191111/2021864.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有