spring cloud微服务快速教程之(五) ZUUL API网关中心

0-前言

  咱们一个个微服务构建好了,外部的应用如何来访问内部各类各样的微服务呢?在微服务架构中,后端服务每每不直接开放给调用端,而是经过一个API网关根据请求的url,路由到相应的服务。当添加API网关后,在第三方调用端和服务提供方之间就建立了一个代理层,这个代理层直接与调用方通讯进行权限控制,后将请求均衡分发给后台服务端。git

  Zuul:就是一个API中间代理层,能够用来执行认证、动态路由、服务前移、负载均衡、安全、动态响应处理等;好比/api/user转发到到user服务,/api/order转发到到shop服务。zuul默认使用Ribbon实现负载均衡;github

 

1、ZUUL的简单使用

1.一、建立ZUUL模块,添加依赖:spring

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

1.二、建立配置文件,增长配置后端

server:
  port: 8081
spring:
  application:
    name: zuul
# 配置Eureka地址
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
  instance:
    prefer-ip-address: true
# 构建路由地址
zuul:
  prefix: /api
  routes:
    # 这里能够自定义
    user:
      # 匹配的路由规则
      path: /user/**
      # 路由的目标服务名
      serviceId: user
    order:
      # 匹配的路由规则
      path: /order/**
      # 路由的目标服务名
      serviceId: order

1.三、启动类增长 @EnableZuulProxy 注解api

@SpringBootApplication
@EnableZuulProxy
@EnableEurekaClient
public class application
{
    public  static void main(String[] args)
    {
        SpringApplication.run(application.class);
    }
}

完成安全

1.四、运行测试架构

 

 

 

 能够看到,ZUUL已经按照配置文件的路由规则进行了路由转发,并对服务实现了负载均衡;app

ZUUL简单使用完毕;负载均衡

 GITdemo地址:https://github.com/anson-yang/springclouddemo微服务

相关文章
相关标签/搜索