當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
SpringCloud学习笔记(6)----Spring Cloud Netflix之负载均衡-Ribbon的使用
生活随笔
收集整理的這篇文章主要介紹了
SpringCloud学习笔记(6)----Spring Cloud Netflix之负载均衡-Ribbon的使用
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 什么是負載均衡?
負載均衡,就是分發請求流量到不同的服務器。
負載均衡一般分為兩種
1. 服務器端負載均衡(nginx)
2. 客戶端負載均衡(Ribbon)
2. 服務提供者(spring-cloud-provider)
實體類User:
package com.wangx.cloud.model;import java.util.Date; public class User { private Integer id; private String name; private Date date; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Date getDate() { return date; } public void setDate(Date date) { this.date = date; } @Override public String toString() { return "User{" + "id=" + id + ", name='" + name + '\'' + ", date=" + date + '}'; } }Controller接口:
package com.wangx.cloud.controller;import com.wangx.cloud.model.User; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import java.util.Date; @RestController @RequestMapping("/api/user") public class UserController { @RequestMapping(value = "/{id}", method = RequestMethod.GET) public User view(@PathVariable int id) { User user = new User(); user.setId(id); user.setName("小張"); user.setDate(new Date()); System.out.println(user); return user; } }3. 服務消費者(spring-cloud-consumer)
package com.wangx.cloud.controller;import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate; @RestController @RequestMapping(value = "/user", method = RequestMethod.POST) public class UserController { private static final String URL = "http://localhost:7777/api/user/{id}"; @Autowired private RestTemplate restTemplate; @RequestMapping(value = "/{id}", method = RequestMethod.GET) public String get(@PathVariable(value = "id") int id) { return restTemplate.getForObject(URL, String.class, id); } }
分別查看兩個服務是否能正常調用。
4. 如何通過Ribbon進行調用
1. 在創建RestTemplate bean的方法上添加注解@LoadBalanced
@Bean@LoadBalanced //默認的負載策略是輪詢算法public RestTemplate restTemplate() {return new RestTemplate(); }
2. 修改調用的URL為URL=http://spring-cloud-provider/api/user/{id}
注意:控制臺的應用名為大寫,我們統一為小寫,更不能大小寫都存在
5. 如何實現負載均衡
啟動多個提供者,進行測試
為了區分,可以修改實體類User的name屬性,
注意:修改應用的時候,端口也要修改
?6. 結論
1. Ribbon通過@LoadBalanced進行負載均衡
2.? 默認的負載策略是輪詢算法
原文 SpringCloud學習筆記(6)----Spring Cloud Netflix之負載均衡-Ribbon的使用
轉載于:https://www.cnblogs.com/xiaoshen666/p/10844165.html
總結
以上是生活随笔為你收集整理的SpringCloud学习笔记(6)----Spring Cloud Netflix之负载均衡-Ribbon的使用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java实现回形数,只利用数组、循环和i
- 下一篇: 洛谷 P3367 【模板】并查集