国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

SpringCloud(第 020 篇)Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)

Dogee / 1452人閱讀

摘要:注意注解能注冊(cè)到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔猓撌且粋€(gè)復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。

SpringCloud(第 020 篇)Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)到客戶端負(fù)載均衡的能力

-

一、大致介紹
1、本章節(jié)添加另外一個(gè)屬性 listOfServers 來(lái)給 zuul 賦上異樣的功能色彩,提供負(fù)載均衡的能力;
2、而其實(shí)說(shuō)到底 zuul 的負(fù)載能力還是在于 ribbon,因?yàn)?ribbon 才是真正做到讓 zuul 達(dá)到客戶端負(fù)載均衡能力的本質(zhì);
二、實(shí)現(xiàn)步驟 2.1 添加 maven 引用包


    4.0.0

    springms-gateway-zuul-cluster
    1.0-SNAPSHOT
    jar

    
        com.springms.cloud
        springms-spring-cloud
        1.0-SNAPSHOT
    

    
        
        
            org.springframework.cloud
            spring-cloud-starter-zuul
        

        
        
            org.springframework.cloud
            spring-cloud-starter-eureka
        
    

2.2 添加應(yīng)用配置文件(springms-gateway-zuul-clustersrcmainresourcesapplication.yml)
spring:
  application:
    name: springms-gateway-zuul-cluster
server:
  port: 8165
eureka:
  datacenter: SpringCloud   # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Data center 顯示信息
  environment: Test         # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Environment 顯示信息
  client:
    service-url:
      defaultZone: http://admin:admin@localhost:8761/eureka
    healthcheck:  # 健康檢查
      enabled: true
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}


#####################################################################################################
# 測(cè)試一,API網(wǎng)關(guān)模塊發(fā)現(xiàn)應(yīng)用入口(添加 listOfServers 屬性,測(cè)試 zuul 的負(fù)載均衡功能)
zuul:
  routes:
    hmily:
      path: /custom-path/**
      serviceId: springms-provider-user

# 注意,這里在運(yùn)行的時(shí)候有個(gè)坑,如果以樹(shù)形展開(kāi)寫(xiě)法的話,那么就會(huì)出錯(cuò)了,所以這個(gè)配置還是避免用樹(shù)形寫(xiě)法
ribbon.eureka.enabled: false

springms-provider-user: # 這里是 ribbon 要請(qǐng)求的微服務(wù)的 service-id 值
  ribbon:
    listOfServers: http://localhost:7900,http://localhost:7899,http://localhost:7898
#####################################################################################################




#####################################################################################################
# 打印日志
logging:
  level:
    root: INFO
    com.springms: DEBUG
#####################################################################################################



#####################################################################################################
ribbon:
  ConnectTimeout: 3000
  ReadTimeout: 60000
#####################################################################################################




#####################################################################################################
# 解決第一次請(qǐng)求報(bào)超時(shí)異常的方案,因?yàn)?hystrix 的默認(rèn)超時(shí)時(shí)間是 1 秒,因此請(qǐng)求超過(guò)該時(shí)間后,就會(huì)出現(xiàn)頁(yè)面超時(shí)顯示 :
#
# 這里就介紹大概三種方式來(lái)解決超時(shí)的問(wèn)題,解決方案如下:
#
# 第一種方式:將 hystrix 的超時(shí)時(shí)間設(shè)置成 5000 毫秒
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000
#
# 或者:
# 第二種方式:將 hystrix 的超時(shí)時(shí)間直接禁用掉,這樣就沒(méi)有超時(shí)的一說(shuō)了,因?yàn)橛肋h(yuǎn)也不會(huì)超時(shí)了
# hystrix.command.default.execution.timeout.enabled: false
#
# 或者:
# 第三種方式:索性禁用feign的hystrix支持
# feign.hystrix.enabled: false ## 索性禁用feign的hystrix支持

# 超時(shí)的issue:https://github.com/spring-cloud/spring-cloud-netflix/issues/768
# 超時(shí)的解決方案: http://stackoverflow.com/questions/27375557/hystrix-command-fails-with-timed-out-and-no-fallback-available
# hystrix配置: https://github.com/Netflix/Hystrix/wiki/Configuration#execution.isolation.thread.timeoutInMilliseconds
#####################################################################################################
2.3 添加zuul服務(wù)網(wǎng)關(guān)微服務(wù)啟動(dòng)類(springms-gateway-zuul-clustersrcmainjavacomspringmscloudMsGatewayZuulClusterApplication.java)
package com.springms.cloud;

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

/**
 * Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)到客戶端負(fù)載均衡的能力。
 *
 * 注意 EnableZuulProxy 注解能注冊(cè)到 eureka 服務(wù)上,是因?yàn)樵撟⒔獍?eureka 客戶端的注解,該 EnableZuulProxy 是一個(gè)復(fù)合注解。
 *
 * @EnableZuulProxy --> { @EnableCircuitBreaker、@EnableDiscoveryClient } 包含了 eureka 客戶端注解,同時(shí)也包含了 Hystrix 斷路器模塊注解。
 *
 * http://localhost:8165/routes 地址可以查看該zuul微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的serviceId。
 *
 * @author hmilyylimh
 *
 * @version 0.0.1
 *
 * @date 2017/9/24
 *
 */
@SpringBootApplication
@EnableZuulProxy
public class MsGatewayZuulClusterApplication {

    public static void main(String[] args) {
        SpringApplication.run(MsGatewayZuulClusterApplication.class, args);
        System.out.println("【【【【【【 GatewayZuulCluster微服務(wù) 】】】】】】已啟動(dòng).");
    }
}
三、測(cè)試
/****************************************************************************************
 一、Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)到客戶端負(fù)載均衡的能力:

 1、編寫(xiě) application.yml 文件,添加應(yīng)用程序的注解 EnableZuulProxy 配置;
     # 測(cè)試一,API網(wǎng)關(guān)模塊發(fā)現(xiàn)應(yīng)用入口(添加 listOfServers 屬性,測(cè)試 zuul 的負(fù)載均衡功能)
     zuul:
         routes:
             hmily:
                 path: /user-serviceId/**
                 serviceId: springms-provider-user

     # 注意,這里在運(yùn)行的時(shí)候有個(gè)坑,如果以樹(shù)形展開(kāi)寫(xiě)法的話,那么就會(huì)出錯(cuò)了,所以這個(gè)配置還是避免用樹(shù)形寫(xiě)法
     ribbon.eureka.enabled: false

     springms-provider-user: # 這里是 ribbon 要請(qǐng)求的微服務(wù)的 service-id 值
         ribbon:
            listOfServers: http://localhost:7900,http://localhost:7899,http://localhost:7898
 2、啟動(dòng) springms-discovery-eureka 模塊服務(wù),啟動(dòng)1個(gè)端口;
 3、啟動(dòng) springms-provider-user 模塊服務(wù),啟動(dòng)1個(gè)端口(application.yml 文件中的 appname 屬性不去掉的話,測(cè)試一是無(wú)法測(cè)試通過(guò)的);
 4、啟動(dòng) springms-gateway-zuul-cluster 模塊服務(wù);

 5、新起網(wǎng)頁(yè)頁(yè)簽,輸入 http://localhost:7900/simple/5 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái);

 總結(jié)一:第5步正常,說(shuō)明 springms-provider-user 服務(wù)目前正常;

 6、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8165/springms-provider-user/simple/6,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái);

 總結(jié)二:第6步也能正常打印用戶信息,說(shuō)明 API 網(wǎng)關(guān)已經(jīng)生效了,可以通過(guò)API服務(wù)器地址鏈接各個(gè)微服務(wù)的 http://localhost:8150/serviceId/path 這樣的路徑來(lái)訪問(wèn)了;

 7、新起網(wǎng)頁(yè)頁(yè)簽,然后輸入 http://localhost:8165/user-serviceId/simple/1,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來(lái);

 總結(jié)三:path、serviceId 設(shè)置的反向代理路徑也通了;

 8、清除 springms-provider-user 模塊控制臺(tái)的所有的日志,然后刷新 9 次該地址 http://localhost:8165/user-serviceId/simple/1 的網(wǎng)頁(yè),然后會(huì)發(fā)現(xiàn) 3 個(gè)用戶服務(wù)都各打印了3次,再多刷新幾次,會(huì)發(fā)現(xiàn)該負(fù)載均衡的調(diào)度的算法是輪論調(diào),依次輪詢調(diào)用每個(gè)用戶服務(wù)微服務(wù);

 總結(jié)四:listOfServers 屬性也生效了,從而說(shuō)明添加 listOfServers 也可以達(dá)到 zuul 負(fù)載均衡的能力;
 ****************************************************************************************/
四、下載地址

https://gitee.com/ylimhhmily/SpringCloudTutorial.git

SpringCloudTutorial交流QQ群: 235322432

SpringCloudTutorial交流微信群: 微信溝通群二維碼圖片鏈接

歡迎關(guān)注,您的肯定是對(duì)我最大的支持!!!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/70553.html

相關(guān)文章

  • SpringCloud 022 Zuul 網(wǎng)關(guān)微服務(wù)的regexmapper屬性測(cè)試, 類似

    摘要:地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。微服務(wù)已啟動(dòng)使用提供和之間的綁定它使用正則表達(dá)式組來(lái)從提取變量然后注入到路由表達(dá)式中。 SpringCloud(第 022 篇)Zuul 網(wǎng)關(guān)微服務(wù)的 regexmapper 屬性測(cè)試, 類似測(cè)試 zuul 的自定義路徑規(guī)則一樣 - 一、大致介紹 1、本章節(jié)將 Zuul 的 regexmapper 屬性單獨(dú)拿出來(lái),主要是這種配置規(guī)則,可以在一...

    cyqian 評(píng)論0 收藏0
  • SpringCloud 018 Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理

    摘要:注意注解能注冊(cè)到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔猓撌且粋€(gè)復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。 SpringCloud(第 018 篇)Zuul 服務(wù) API 網(wǎng)關(guān)微服務(wù)之代理與反向代理 - 一、大致介紹 1、API 服務(wù)網(wǎng)關(guān)顧名思義就是統(tǒng)一入口,類似 nginx、F5 等功能一樣,統(tǒng)一代理控制請(qǐng)求入口,弱化各個(gè)微服務(wù)被客戶端記憶功能; 2、本章節(jié)主要講解了使用...

    YancyYe 評(píng)論0 收藏0
  • SpringCloud 019 Zuul 網(wǎng)關(guān)微服務(wù)的一些屬性應(yīng)用測(cè)試

    SpringCloud(第 019 篇)Zuul 網(wǎng)關(guān)微服務(wù)的一些屬性應(yīng)用測(cè)試 - 一、大致介紹 1、本章節(jié)根據(jù)官網(wǎng)資料,嘗試了一些其它屬性的設(shè)置,比如 path、serviceId、prefix、strip-prefix 等應(yīng)用; 2、這些組合試用的場(chǎng)景大多數(shù)在一些地址方面需要重新映射或者針對(duì)特殊地址做特殊處理等,至于其它一些深層次的應(yīng)用大家做過(guò)知道的話也可以告盡情回帖讓大家都來(lái)學(xué)習(xí)學(xué)習(xí)。 二、...

    imtianx 評(píng)論0 收藏0
  • springCloud學(xué)習(xí)4(Zuul服務(wù)路由)

    摘要:但是如果將負(fù)載均衡器置于所有服務(wù)前便不是一個(gè)好主意,會(huì)造成瓶頸。服務(wù)超時(shí)使用的和庫(kù)來(lái)進(jìn)行請(qǐng)求。支持以下四種過(guò)濾器前置過(guò)濾器在將請(qǐng)求發(fā)送到目的地之前被調(diào)用。通常用于記錄從目標(biāo)服務(wù)返回的響應(yīng)處理錯(cuò)誤或?qū)徍嗣舾行畔ⅰ? showImg(https://segmentfault.com/img/remote/1460000019531578); springcloud 總集:https://ww...

    wuaiqiu 評(píng)論0 收藏0
  • SpringCloud 021 Zuul 的過(guò)濾器 ZuulFilter 的使用

    摘要:第篇的過(guò)濾器的使用一大致介紹我們?cè)趯W(xué)的時(shí)候,就有過(guò)濾器和攔截器的使用,而同樣也有過(guò)濾器的使用,本章節(jié)我們指在如何簡(jiǎn)單使用。是否執(zhí)行該過(guò)濾器。說(shuō)明需要過(guò)濾說(shuō)明不要過(guò)濾過(guò)濾器的具體邏輯。請(qǐng)求的添加服務(wù)網(wǎng)關(guān)微服務(wù)啟動(dòng)類的過(guò)濾器的使用。 SpringCloud(第 021 篇)Zuul 的過(guò)濾器 ZuulFilter 的使用 - 一、大致介紹 1、我們?cè)趯W(xué) Spring 的時(shí)候,就有過(guò)濾器和攔...

    kumfo 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

Dogee

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<