如何详细解析使用SpringCloud搭建Zuul网关集群的步骤?
- 内容介绍
- 文章标签
- 相关推荐
本文共计774个文字,预计阅读时间需要4分钟。
1. 技术选型:Springboot, SpringCloud, Zuul, Nginx
2.目标:使用Zuul搭建高可用微服务网关
3.项目创建
3.1 创建注册中心(Eureka) 3.2 创建hello-service服务工程 3.3 创建springcloud-zuul-ha网关服务 3.3.1 创建网关服务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
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="maven.apache.org/POM/4.0.0" xmlns:xsi="www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="maven.apache.org/POM/4.0.0 maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>qinfeng.zheng</groupId> <artifactId>springcloud-zuul-ha</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>springcloud-zuul-ha</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <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> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <!--Dalston.RC1这个高版本的zuul依赖有问题--> <version>Brixton.SR7</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
3.3.3 application.yml
###服务注册地址 eureka: client: serviceUrl: defaultZone: 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.backServer/; index index.html index.htm; } }
3.5 在本地host文件中配置qinfeng.zheng.com 的域名
4.测试
第一次请求: qinfeng.zheng.com/api-hello/hello/index?token=123
第二次请求:qinfeng.zheng.com/api-hello/hello/index?token=123
5.总结
1.使用nignx负载均衡和反向代理技术可以实现网关的高可用
2.zuul网关自动集成ribbon客户端,实现路由的负载均衡
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。
本文共计774个文字,预计阅读时间需要4分钟。
1. 技术选型:Springboot, SpringCloud, Zuul, Nginx
2.目标:使用Zuul搭建高可用微服务网关
3.项目创建
3.1 创建注册中心(Eureka) 3.2 创建hello-service服务工程 3.3 创建springcloud-zuul-ha网关服务 3.3.1 创建网关服务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
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="maven.apache.org/POM/4.0.0" xmlns:xsi="www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="maven.apache.org/POM/4.0.0 maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>qinfeng.zheng</groupId> <artifactId>springcloud-zuul-ha</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>springcloud-zuul-ha</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <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> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <!--Dalston.RC1这个高版本的zuul依赖有问题--> <version>Brixton.SR7</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
3.3.3 application.yml
###服务注册地址 eureka: client: serviceUrl: defaultZone: 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.backServer/; index index.html index.htm; } }
3.5 在本地host文件中配置qinfeng.zheng.com 的域名
4.测试
第一次请求: qinfeng.zheng.com/api-hello/hello/index?token=123
第二次请求:qinfeng.zheng.com/api-hello/hello/index?token=123
5.总结
1.使用nignx负载均衡和反向代理技术可以实现网关的高可用
2.zuul网关自动集成ribbon客户端,实现路由的负载均衡
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

