发表于: 2020-07-29 23:26:37

1 1467


今天完成的事情:

1.学习Zuul网关。

什么时Zuul?

Zuul包含了对请求的路由和过滤两个最主要的功能:

其中路由功能负责将外部请求转发到具体微服务上,是实现外部访问统一入口的基础,而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验,服务聚合等功能的基础。Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,即以后访问微服务都是通过Zuul进行跳转后获得。


引入依赖:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <parent>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-parent</artifactId>
       <version>2.3.2.RELEASE</version>
       <relativePath/> <!-- lookup parent from repository -->
   </parent>
   <groupId>com.jnshu</groupId>
   <artifactId>springcloud_zuul9527</artifactId>
   <version>1.0</version>
   <name>springcloud_zuul9527</name>
   <description>Demo project for Spring Boot</description>

   <properties>
       <java.version>1.8</java.version>
   </properties>

   <dependencies>
       <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-netflix-zuul -->
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
           <version>2.2.3.RELEASE</version>
       </dependency>
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
           <version>2.2.3.RELEASE</version>
       </dependency>
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-web</artifactId>
       </dependency>
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter</artifactId>
       </dependency>

       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-devtools</artifactId>
           <scope>runtime</scope>
           <optional>true</optional>
       </dependency>
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-test</artifactId>
           <scope>test</scope>
           <exclusions>
               <exclusion>
                   <groupId>org.junit.vintage</groupId>
                   <artifactId>junit-vintage-engine</artifactId>
               </exclusion>
           </exclusions>
       </dependency>
   </dependencies>

   <build>
       <plugins>
           <plugin>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-maven-plugin</artifactId>
           </plugin>
       </plugins>
   </build>

</project>

主要需要eureka客户端和zuul依赖。


编写配置文件:

server:
port: 1234

spring:
application:
name: Zuul

#Eureka的配置,服务注册到哪里
eureka:
client:
register-with-eureka: true
   fetch-registry: true
   service-url:
defaultZone: http://localhost:8888/eureka/
instance:
instance-id: springcloud_zuul9527
prefer-ip-address: true

info:
app.name: server
company.name: com.jnshu.zuul


在主启动类上加@EnableEurekaClient注解。

启动:

这里由于我的9527端口被占用了,临时改为1234.

使用zuul之后通过zuul的端口也可以访问8080服务端提供的服务。

通过配置文件可以更改具体路径:

zuul:
routes:
mydept.serviceId: service
mydept.path: /mydepy/**

还可以配置忽略原路径:

ignored-services: service

此时再通过原路径访问就会报错了:


这么看起来zuul感觉跟nginx有点像。


查了一下它们有什么区别。

Nginx与Zuul的区别

相同点:Zuul和Nginx都可以实现负载均衡、反向代理(隐藏真实ip地址),过滤请求,实现网关的效果

不同点:Nginx--c语言开发

               Zuul--java语言开发

Zuul负载均衡实现:采用ribbon+eureka实现本地负载均衡

Nginx负载均衡实现:采用服务器实现负载均衡

Nginx相比zuul功能会更加强大,因为Nginx整合一些脚本语言(Nginx+lua)

Nginx适合于服务器端负载均衡

Zuul适合微服务中实现网关


明天计划完成的事情:

深度思考


返回列表 返回列表
评论

    分享到