最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
SpringCLoud搭建Zuul网关集群过程解析
时间:2020-03-11 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下SpringCLoud搭建Zuul网关集群过程解析,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
1.使用技术
Springboot,SpringCloud,Zuul,Nignx
2.目的
使用Zuul搭建微服务高可用的网关
3.项目创建
3.1 创建注册中心(略)
3.2 创建一个hello-service的服务工程
3.3 创建springcloud-zuul-ha网关服务
3.3.1 创建工程(略)
3.3.2 pom.xml
4.0.0 qinfeng.zheng springcloud-zuul-ha 0.0.1-SNAPSHOT jar springcloud-zuul-ha Demo project for Spring Boot org.springframework.boot spring-boot-starter-parent 1.4.2.RELEASE UTF-8 UTF-8 1.8 org.springframework.cloud spring-cloud-starter-zuul org.springframework.cloud spring-cloud-starter-eureka org.springframework.cloud spring-cloud-dependencies Brixton.SR7 pom import org.springframework.boot spring-boot-maven-plugin
3.3.3 application.yml
###服务注册地址 eureka: client: serviceUrl: defaultZone: http://localhost:8763/eureka/ ###api网关端口号 server: port: 82 ###网关名称 spring: application: name: service-zuul zuul: routes: ###定义转发服务规则 api-a: path: /api-hello/** #请求路径中含有api-hello,都会转发到hello-service服务 ###服务别名 zuul网关默认整合ribbon 自动实现负载均衡轮训效果 serviceId: hello-service
3.3.4 定义一个过滤器
qinfeng.zheng.filter.AccessFilter
import com.netflix.zuul.ZuulFilter; import com.netflix.zuul.context.RequestContext; import org.apache.commons.lang.StringUtils; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import javax.servlet.http.HttpServletRequest; /** * 创建时间: 16:07 2018/7/16 * 修改时间: * 编码人员: ZhengQf * 版 本: 0.0.1 * 功能描述: 自定义一个Zuul Filter,它在请求路由之前进行过滤 * * 补: zuul两大功能: 1.路由请求 * 2.过滤 */ @Component public class AccessFilter extends ZuulFilter { @Value("${server.port}") private String serverPort; /** * 过滤器的类型,它决定过滤器在请求的哪个生命周期中执行, * pre:请求被路由之前做一些前置工作 ,比如请求和校验 * routing : 在路由请求时被调用,路由请求转发,即是将请求转发到具体的服务实例上去. * post : 在routing 和 error过滤器之后被调用..所以post类型的过滤器可以对请求结果进行一些加工 * error :处理请求发生错误时调用 */ @Override public String filterType() { return "pre"; // } /** *过滤器的执行顺序. *在一个阶段有多个过滤器时,需要用此指定过滤顺序 * 数值越小优先级越高 */ @Override public int filterOrder() { return 0; } /** * 判断过滤器是否执行,直接返回true,代表对所有请求过滤 * 此方法指定过滤范围 * @return */ @Override public boolean shouldFilter() { return true; } /** * 过滤的具体逻辑 * @return */ @Override public Object run() { // 1.获取上下文 RequestContext currentContext = RequestContext.getCurrentContext(); // 2.获取 Request HttpServletRequest request = currentContext.getRequest(); // 3.获取token 的时候 从请求头中获取 String token = request.getParameter("token"); request.setAttribute("serverPort", serverPort); if (StringUtils.isEmpty(token)) { // 不会继续执行... 不会去调用服务接口,网关服务直接响应给客户端 currentContext.setSendZuulResponse(false); currentContext.setResponseBody("token is null"); currentContext.setResponseStatusCode(401); return null; // 返回一个错误提示 } // 正常执行调用其他服务接口... System.out.println("网关执行端口号:" + serverPort); return null; } }
3.3.5 启动类
import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.cloud.netflix.zuul.EnableZuulProxy; @EnableZuulProxy @EnableEurekaClient @SpringBootApplication public class SpringcloudZuulHaApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudZuulHaApplication.class, args); } }
3.3.6 启动网关项目
使用server.port模拟两个网关项目,端口号分别为81,82 -------> 测试网关高可用
使用server.port模拟两个hello-service项目,端口号分别为8080,8081 ---->测试zuul的路由时,自动负载均衡
查看注册中心,一共有四个服务:
3.4 nginx配置负载均衡,然后 cmd ,start nginx.exe启动nginx服务
upstream backServer{ server 127.0.0.1:81; server 127.0.0.1:82; } server { listen 80; server_name qinfeng.zheng.com; location / { ### 指定上游服务器负载均衡服务器 proxy_pass http://backServer/; index index.html index.htm; } }
3.5 在本地host文件中配置qinfeng.zheng.com 的域名
4.测试
第一次请求: http://qinfeng.zheng.com/api-hello/hello/index?token=123
第二次请求:http://qinfeng.zheng.com/api-hello/hello/index?token=123
5.总结
1.使用nignx负载均衡和反向代理技术可以实现网关的高可用
2.zuul网关自动集成ribbon客户端,实现路由的负载均衡
相关文章
- SpringBoot自定义bean绑定解析 10-24
- Javaweb工程运行报错HTTP Status 404解决教程 10-20
- JAVA获取jvm和操作系统相关信息方法 10-20
- BeanFactory和FactoryBean的区别讲解 10-20
- 微信小程序的宿主环境实现教程 10-10
- dispatchEvent解决重叠元素响应事件教程 10-10