Zuul网关_vue动态路由和静态路由的区别

Zuul网关_vue动态路由和静态路由的区别1.微服务架构所面临的问题?1)针对某个功能,客户端在微服务架构的情况下需要请求多个模块接口2)针对于身份认证、日志、流量控制等公共模块每个微服务都需要做一遍,不利于业务与非业务的拆分针对于这些问题,Zuul可完美解决,我们可用Zuul做:1)客户端只需要知道网关而不需要知道具体模块的地址,所有服务由网关对外提供2)身份认证类…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1.微服务架构所面临的问题?

    1)针对某个功能,客户端在微服务架构的情况下需要请求多个模块接口

    2)针对于身份认证、日志、流量控制等公共模块每个微服务都需要做一遍,不利于业务与非业务的拆分

    针对于这些问题,Zuul可完美解决,我们可用Zuul做:

    1)客户端只需要知道网关而不需要知道具体模块的地址,所有服务由网关对外提供

    2)身份认证类的东西单独抽象出来,业务模块只做业务

2.Zuul网关构建

    1)在SpringBoot工程 part-1-website 中添加依赖,如下

		<!-- spring-cloud-starter-hystrix -->
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-zuul</artifactId>
	</dependency>
        
    <parent>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-parent</artifactId>
		<version>Dalston.SR1</version>
		<relativePath />
	</parent>

    2)在Application上添加@EnableZuulProxy注解,开启Zuul网关服务

@EnableZuulProxy
public class WebsiteApp {
}

    3)设置该工程应用名称、端口号等信息

# 应用名称
spring:
  application:
    name: part-1-website
#端口
server:
  port: 1102

    以上即成功构建应用,以下为请求路由方式

3.Zuul的几种请求路由方式

    准备工作:

        1)启动一个高可用的Eureka-server

        2)创建一个服务应用,以对外提供接口服务

        3)复制一份该服务端服务,除了端口号不一致其他都保持一致,尤其spring.application.name要保持一致,用于验证在外部请求到达时是否负载均衡

        具体可参考笔者另一篇文章 Ribbon负载均衡的使用方式与配置方式详解_恐龙弟旺仔的博客-CSDN博客_ribbon设置负载方式    

        笔者在本示例中服务应用名称设置为 part-1-sms-interface ,全部四个应用启动后,访问eureka可看到Zuul网关_vue动态路由和静态路由的区别

    以上:PART-1-EUREKA即为高可用eureka-server;PART-1-SMS-INTERFACE即为对外服务应用,提供/sms/test服务

    1)传统路由

    * 单实例配置(通过zuul.routes.<route>.path和zuul.routes.<route>.url参数对的方式来配置)

    在application.properties文件中添加路由规则即可

#route rule
zuul.routes.part-1-website.path=/part-1-website/**
zuul.routes.part-1-website.url=http://localhost:1109/

    注意:以上规则即说明,对当前website应用的所有以 /part-1-website开始的请求路径全部转发到http://localhost:1109上;

        如果是请求localhost:1102/part-1-website/sms/test即会转发到localhost:1109/sms/test上,即实现对PART-1-SMS-INTERFACE的服务访问

    * 多实例配置(通过zuul.routes.<route>.path和zuul.routes.<route>.serviceId参数对的方式来配置)

    在application.properties文件中添加如下路由规则即可

zuul.routes.part-1-website.path=/part-1-website/**
zuul.routes.part-1-website.serviceId=website
website.ribbon.listOfServers=http://localhost:1108/,http://localhost:1109/

    注意:与单实例不同就是:通过serviceId和listOfServers来确定path和url的对应关系;

          website读者可自定义,只要保持与listOfServers保持一致即可,servers值即PART-1-SMS-INTERFACE服务对应的应用IP:端口    

    2)服务路由配置

    通过Zuul和Eureka的整合,实现对服务实例的自动化维护

    在这种情况下,我们不需要像传统路由那样为serviceId指定具体的服务实例地址,只需要将path和serviceId对应上

    注意:实现这种方式,需要引入eureka依赖,并将zuul实例注册到eureka中

    在application.properties文件中添加如下路由规则

zuul.routes.part-1-website.path=/part-1-website/**
zuul.routes.part-1-website.service-id=part-1-sms-interface

eureka.client.service-url.defaultZone=http://eureka1:1001/eureka/

    注意:service-id即为要调用的服务名称;需要将本应用注册到eureka

4.过滤器

    过滤负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础。

    Zuul的过滤器使用方式如下:

    1)创建一个类,继承com.netflix.zuul.ZuulFilter

public class AccessFilter extends ZuulFilter{

	@Override
	public boolean shouldFilter() {
		return true;
	}

	@Override
	public Object run() {
		RequestContext context = RequestContext.getCurrentContext();
		HttpServletRequest request = context.getRequest();
		//也可获取其他参数,如response、
		String token = request.getParameter("accessToken");
		if(StringUtils.isEmpty(token)){
			context.setSendZuulResponse(false);
			context.setResponseStatusCode(401);
			context.setResponseBody("has no accessToken");
		}
		return null;
	}

	@Override
	public String filterType() {
		return "pre";
	}

	@Override
	public int filterOrder() {
		return 0;
	}
}

    注意:需实现ZuulFilter的abstract方法;

        shouldFilter:true表示需要过滤;false表示不需要

        filterType:

            * pre 请求被路由之前被调用(一般做一些前置加工)

            * route 在路由请求时调用(将外部请求转发到具体的服务实例上)

            * post 路由请求返回时调用(包装加工返回信息)

            * error 处理请求发生错误时调用

        filterOrder:通过数字来表示filter的执行顺序

        run:做真正的逻辑处理

    2)在Application下创建@Bean,将此Filter作为一个bean注入

	@Bean
	public AccessFilter accessFilter(){
		return new AccessFilter();
	}

    3)重启应用后,发出请求,如果request中没有添加AccessToken,则会收到报错,说明Filter生效

参考:Spring Cloud微服务实战

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/170620.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • vue中的双向数据绑定原理_vue nodejs

    vue中的双向数据绑定原理_vue nodejs简述    每当面试官问到Vue数据双向绑定原理的时候,我们都会简单的说:Vue内部通过Object.defineProperty方法属性拦截的方式,把data对象里每个数据的读写转化成getter/setter,当数据变化时通知视图更新。虽然一句话把大概原理概括了,但是其内部的实现方式还是值得深究的,本文就以通俗易懂的方式剖析Vue内部双向数据绑定原理的实现过程思路   …

  • c++ 0x8000ffff灾难性故障_硬盘出了故障就换?教你一招,不花一分钱就能修复!…[通俗易懂]

    c++ 0x8000ffff灾难性故障_硬盘出了故障就换?教你一招,不花一分钱就能修复!…[通俗易懂]前言目前市面上存在较多山寨的电脑店,为了大家的电脑安全,请一定前往电脑店官方地址进行下载,官方地址为u.diannaodian.com电脑故障出现的大部分原因都是由硬盘故障引起的。随着技术的进步,现在硬盘的容量越来越大,传输速度越来越快,体积也越来越小。但硬盘发生故障的概率比较高,因此我们掌握一些常见的硬盘故障排除方法是相当重要的。1硬盘故障的产生原因1、硬盘出现坏道硬盘出现坏…

  • databus mysql搭建_【databus】初识Databus

    databus mysql搭建_【databus】初识Databus1.简介Databus是一个低延迟、可靠的、支持事务的、保持一致性的数据变更抓取系统。由LinkedIn于2013年开源。Databus通过挖掘数据库日志的方式,将数据库变更实时、可靠的从数据库拉取出来,业务可以通过定制化client实时获取变更并进行其他业务逻辑。Databus有以下特点:数据源和消费者之间的隔离。数据传输能保证顺序性和至少一次交付的高可用性。从变化流的任意时间点进行消费,包括…

    2022年10月16日
  • Python实现翻译小工具「建议收藏」

    Python实现翻译小工具「建议收藏」一、背景利用Requests模块获取有道词典web页面的post信息,BeautifulSoup来获取需要的内容,通过tkinter模块生成gui界面。二、代码git源码地址fanyi.py代

  • SpringBoot整合JSP

    SpringBoot整合JSP以下整合jsp使用的开发工具为intellijidea。其他开发工具目录结构相同在pom.xml文件中加入注释部分的依赖&lt;dependencies&gt;&lt;dependency&gt;&lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;&lt;ar…

  • 微信公众号开发(一)服务器及接口的配置

    微信公众号开发(一)服务器及接口的配置微信公众号开发(一)服务器及接口的配置关于微信公众号中的订阅号和服务的区别这里不多加讨论,网上有很多资源可以搜到,这里直接进入正题,如果是个人开发者,这里建议使用测试号进行开发学习,测试号的权限要比个人订阅号要多的多,而本篇博客也是基于测试号进行开发的。在开始微信号开发之前需要准备好两样东西,1、需要一个测试号,2、需要一个拥有域名的服务器,下面将分别介绍怎样获取这两样东西。1、…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号