springcloud-ribbon

Ribbon簡介

Ribbon是Netflix發(fā)布的負載均衡器提完,它可以幫我們控制HTTP和TCP客戶端的行為乡括。只需為Ribbon配置服務(wù)提供者地址列表泪电,Ribbon就可基于負載均衡算法計算出要請求的目標服務(wù)地址弊知。

Ribbon默認為我們提供了很多的負載均衡算法握牧,例如輪詢容诬、隨機、響應(yīng)時間加權(quán)等——當然沿腰,為Ribbon自定義負載均衡算法也非常容易览徒,只需實現(xiàn) IRule 接口即可。

Ribbon入門

新建提供者模塊spring-cloud-provider:
pom:
<?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>com.example</groupId>
        <artifactId>spring-cloud-wsl</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <groupId>com.example</groupId>
    <artifactId>spring-cloud-provider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>spring-cloud-provider</name>
    <description>Demo project for Spring Cloud Provider</description>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- eureka服務(wù)端依賴jar包 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>
</project>
application.yml配置文件:
server:
  port: 8880
spring:
  application:
    name: provider
#eureka客戶端連接配置
eureka:
  client:
    service-url:
      #注冊中心地址
      defaultZone: http://localhost:8761/eureka/
  instance:
    #將ip注冊到eureka上
    prefer-ip-address: true
controller:
@RestController
public class TestController {
    @Value("${server.port}")
    private String port;

    // 注入配置文件上下文
    @Autowired
    private ConfigurableApplicationContext applicationContext;

    @GetMapping(value = "/test/{name}")
    public String test(@PathVariable String name) {
        return "success! hello: " + name + " i am from port " + port;
    }

    // 從上下文中讀取配置
    @GetMapping(value = "/hi")
    public String sayHi() {
        return "Hello " + applicationContext.getEnvironment().getProperty("user.name");
    }
}
啟動spring-cloud-provider模塊

先啟動spring-cloud-eureka颂龙,再啟動spring-cloud-provider


打開http://localhost:8761/
紅框部分說明已經(jīng)注冊到注冊中心

輸入http://localhost:8880/test/wangshilin
提供者調(diào)用成功
創(chuàng)建消費者模塊spring-cloud-consumer-ribbon:
pom:
<?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>com.example</groupId>
        <artifactId>spring-cloud-wsl</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <groupId>com.example</groupId>
    <artifactId>spring-cloud-consumer-ribbon</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>spring-cloud-consumer-ribbon</name>
    <description>Demo project for Spring Cloud Consumer Ribbon</description>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- eureka客戶端依賴jar包 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>
</project>
配置文件application.yml:
server:
  port: 8882
spring:
  application:
    name: consumer-ribbon
#eureka客戶端連接配置
eureka:
  client:
    service-url:
      #注冊中心地址
      defaultZone: http://localhost:8761/eureka/
  instance:
    #將ip注冊到eureka上
    prefer-ip-address: true
配置RestTemplate:
@Configuration
public class ConsumerConfiguration {
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}
controller:
@RestController
public class TestController {

    @Autowired
    private RestTemplate restTemplate;

    @Value("${spring.application.name}")
    private String appName;

    @GetMapping(value = "/test/app/name")
    public String test() {
        return restTemplate.getForObject("http://provider/test/{name}", String.class, appName);
    }
}
啟動spring-cloud-consumer-ribbon模塊:
啟動成功
瀏覽器輸入地址http://localhost:8882/test/app/name
先啟動eureka习蓬、provider模塊
為了測試負載均衡纽什,我們修改provider啟動配置

在Allow parallel run處打√


修改provider端口號為8881
再啟動provider模塊

目前啟動了兩個provider模塊,一個是8880端口躲叼,一個是8881端口

啟動consumer模塊:
瀏覽器中輸入:http://localhost:8882/test/app/name


刷新瀏覽器發(fā)現(xiàn)端口號變化

ribbon其實還有很多負載均衡的策略芦缰,在此不多說,網(wǎng)上教程一大堆枫慷,這里只講各個模塊如何搭建

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末让蕾,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子或听,更是在濱河造成了極大的恐慌探孝,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件誉裆,死亡現(xiàn)場離奇詭異再姑,居然都是意外死亡,警方通過查閱死者的電腦和手機找御,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門元镀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人霎桅,你說我怎么就攤上這事栖疑。” “怎么了滔驶?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵遇革,是天一觀的道長。 經(jīng)常有香客問我揭糕,道長萝快,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任著角,我火速辦了婚禮揪漩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘吏口。我一直安慰自己奄容,他們只是感情好,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布产徊。 她就那樣靜靜地躺著昂勒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪舟铜。 梳的紋絲不亂的頭發(fā)上戈盈,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機與錄音谆刨,去河邊找鬼塘娶。 笑死归斤,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的血柳。 我是一名探鬼主播官册,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼生兆,長吁一口氣:“原來是場噩夢啊……” “哼难捌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鸦难,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤根吁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后合蔽,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體击敌,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年拴事,在試婚紗的時候發(fā)現(xiàn)自己被綠了沃斤。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡刃宵,死狀恐怖衡瓶,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情牲证,我是刑警寧澤哮针,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站坦袍,受9級特大地震影響十厢,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜捂齐,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一蛮放、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧奠宜,春花似錦筛武、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至榴都,卻和暖如春待锈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背嘴高。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工竿音, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留和屎,地道東北人。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓春瞬,卻偏偏與公主長得像柴信,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子宽气,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353