(十五)java版spring cloud微服務架構b2b2c電子商務平臺-Zuul的使用

一、 Zuul的介紹

Zuul一個基於JVM路由和服務端的負載均衡器,在雲平臺上提供動態路由,監控,彈性,安全等邊緣服務的框架。
路由功能:相當於nginx的反向代理功能。

比如:/ 可能需要映射到你的web應用, /api/users 映射到用戶服務,/api/shop 映射到商城服務。

二、 新建項目
1、 加入依賴包

<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>

2、 配置文件

 server
server.port=9876
        
  spring
spring.application.name=spring-cloud-gateway

  eureka
#eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
eureka.client.serviceUrl.defaultZone=http://roncoo:123456@localhost:8761/eureka/

  info自定義
[email protected]@
[email protected]@
[email protected]@
[email protected]@
[email protected]@

eureka.instance.status-page-url-path=/info
eureka.instance.instanceId=${spring.application.name}:${random.value}
eureka.instance.prefer-ip-address=true

#設置拉取服務註冊信息時間,默認60s
eureka.client.registry-fetch-interval-seconds=30

#指定續約更新頻率,默認是30s
eureka.instance.lease-renewal-interval-in-seconds=15

#設置過期剔除時間,默認90s
eureka.instance.lease-expiration-duration-in-seconds=45

3、 主類

package com.roncoo.education;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@EnableZuulProxy
@SpringBootApplication
public class GatewayApplication {

        public static void main(String[] args) {
                SpringApplication.run(GatewayApplication.class, args);
        }
}

4、 啓動訪問:

localhost:7778/api/user/1

localhost:8886/feign/user/1

使用zuul

localhost:9876/spring-cloud-provider/api/user/1

localhost:9876/spring-cloud-consumer2/feign/user/1

說明:zull可以調用提供者,也可以調用消費者,這裏沒有固定的規則,符合業務需求即可。很多時候,提供者也會調用到另外的提供者(可能是多個),這裏建議,最好不要超過三個應用之間的調用。

例如:一個下單api服務,當用戶進行下單就會調用到訂單服務,訂單服務裏面會調用到用戶服務進行用戶信息的操作,也會調用積分服務進行積分的操作,也可能會有日誌服務進行日誌記錄,最終才能下單。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章