springcloud-zuul配置路由网关

Zuul的主要功能是路由转发和过滤器。客户端请求通过路由网关调用相应的服务。这样客户端只需要和网关交互,而无需直接调用特定微服务的接口,而且方便监控,易于认证,减少客户端和各个微服务之间的交互次数。

实现Zuul的方式如下:

1. 配置pom

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

这里我们引入Eureka,需要将zuul注册到注册中心上去这样才能拉取服务列表。

2. 创建启动类

启动类上需要添加@EnableZuulProxy

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

3. 增加配置文件

server:
  port: 3001
eureka:
  instance:
    preferIpAddress:true
  client:
    serviceUrl:
      defaultZone: http://localhost:7001/eureka/
spring:
  application:
    name: Zuul3001
zuul: 
  prefix: /nikola                   
  routes:
    ribbon:
      path: /ribbonClass/**
      serviceId: GateView8001
    feign:
      path: /feignClass/**
      serviceId: GateView8001
 

路由规则为前缀为/nikola。serviceId对应注册到Eureka的服务实例名。path为访问该服务的请求路径。

3. 测试

在浏览器中输入:http://localhost:3001/nikola/feignClass/class; 回车显示

[{“id”:1,“classcode”:“001”,“classname”:“class1”,“description”:“good class”,“operator”:“admin”,“makedate”:1557759681000,“modifydate”:1557759681000,“bak1”:null,“bak2”:null,“bak3”:null,“bak4”:null,“bak5”:null}]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值