wmic service 未被引用服务路径_微服务必备,zuul作为网关用起来太方便了,spring cloud实践(7)...

01 注册eureka

02 eureka后台监控加权限

03 feign使用

04 引用common组件

05 hystrix 应用

06 ribbon应用

ribbon是针对微服务之间的负载均衡机制,如果从外部进来的请求需要访问内部服务的时候,就需要zuul来帮助我们了。他可以帮我们做外部访问的负载均衡和过滤的工作。

1f631d217b87d44469eedd2b1d1a0016.png

用户请求zuul的时候会先经过pre过滤器,然后再通过route过滤器,他会通过路由配置把请求导入到对应的微服务,然后再通过post过滤器,最后返回给用户。

建立zuul 服务

先建立一个zuul的项目,一路向导达到目的。

485f84d3c3f002c156eb8fde4e9e60d8.png

然后就是三板斧。

依赖项,pom.xml 配置

org.springframework.boot spring-boot-starter-parent 1.5.6.RELEASE1.8Dalston.SR4org.springframework.cloud spring-cloud-starter-eurekaorg.springframework.cloud spring-cloud-starter-zuul

配置项,application.yml。即然zuul是一个网关就会拦截外部浏览器对服务的请求,起到了过滤器的作用。制定一个zuul的名字,端口号,以及要注册的服务中心。

spring: application: name: demo-gateway-zuulserver: port: 7600eureka: client: service-url: defaultZone: http://root:123456@localhost:7776/eureka/zuul: routes: demo-eureka-client-consumer: /user/**

这里要注意的是,在zuul.routes的定义中需要把访问服务的名字和路径定义起来。也就是说当访问 demo-eureka-client-consumer 的/user/ 路径的时候就可以被服务感知。

启动项

在启动的class上面打上annotation,告诉程序这个作为zuul的gateway。

c8ba951593e0722c2b09831ed1e27c93.png

测试结果

测试之前再回顾一下,我们之前的服务器端口号。

eureka server 7776

provider 8081

provider2 8083

consumer 8082

zuul 7600

现在我们要通过访问zuul的7600 端口,然后由zuul帮我们路由到 consumer 8082 上面去。

f63c1400fcb19aa0cdc4dbe8e390151f.png

这里我们通过zuul的7600 服务,路由从原来的userlogin 更改成了 /user/userlogin zuul帮我们路由到了 consumer的 /userlogin 上面去了。

回头看看 zuul也注册到中心了。

ace99c20995965fd0d41316eb6b8ed2c.png

过滤器filter 测试

这里建立一个filter的class,继承于ZuulFilter

017005a2cc1976b62506b5316b5bc53a.png

主要是选择过滤器的类型,优先级,是否生效,过滤器运行的内容,如下。

@Componentpublic class PreFilter extends ZuulFilter{ @Override public String filterType() {//过滤器类型 return FilterConstants.PRE_TYPE; } @Override public int filterOrder() {//同类型过滤器优先级,数字越小优先级越高 return 0; } @Override public boolean shouldFilter() {//过滤器是否生效 return true; } @Override public Object run() {//出发过滤条件时运行的内容 RequestContext context = RequestContext.getCurrentContext(); HttpServletRequest request = context.getRequest(); String token = request.getHeader("token"); if (token == null || token.equals("")){ context.setSendZuulResponse(false); context.setResponseStatusCode(401); context.setResponseBody("{"message":"no permission, need to login!"}"); return "access denied"; } return "access succeed"; }}

然后再运行zuul,并且通过zuul访问consumer 服务。

访问的时候如果token为空那么,访问失败并且提示信息如下。

4e0ffe2c1f2e3000903bae6855e1a809.png

然后,我们在token中随便填写一些内容。

e279d1eae820deb26e9a3206996e2baa.png

得到正确的结果。

搞定收工。

如果喜欢点个关注,转发一下。

谢谢各位。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值