SpringCloud 中使用 Ribbon
SpringCloud 中使用 Ribbon
在前兩章已經給大家講解了Ribbon負載均衡的規則 以及 如何搭建Ribbon並呼叫服務,那麼在這一章呢 將會給大家說一說如何在SpringCloud中去使用Ribbon。在搭建之前 我們需要做一些準備工作。
1. 搭建Eureka伺服器:springCloud-ribbon-server(專案名稱)
2. 服務提供者:springCloud-ribbon-police(專案名稱)
3. 服務呼叫者:springCloud-ribbon-person(專案名稱)
搭建Eureka伺服器
配置 pom.xml,加入springCloud核心依賴、配置及eureka伺服器依賴
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.13.RELEASE</version> </parent> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Dalston.SR5</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency> </dependencies>
配置 application.yml( 紅色部分是必須要寫的 ,黑色部分不寫也能正常執行 但是建議寫上,在這裡筆者將官網的程式碼貼上)
server: port: 8761 eureka: instance: hostname: localhost client: registerWithEureka: false禁止向eureka註冊服務,因為它自己本身就是伺服器 fetchRegistry: false這裡不需要抓取登錄檔 serviceUrl: defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
建立啟動類:Application.java(將服務跑起來放著,稍後會用到)配置 pom.xml,加入springCloud核心依賴、配置及eureka服務依賴
@SpringBootApplication @EnableEurekaServer public class Application { public static void main(String[] args) { new SpringApplicationBuilder(Application.class).web(true).run(args); } }
服務提供者
配置 pom.xml,加入springCloud核心依賴、配置及eureka客戶端依賴
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.13.RELEASE</version> </parent> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Dalston.SR5</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> </dependencies>
配置 application.yml(需要使用 defaultZone 向伺服器註冊服務,否則就算該服務執行起來了,但沒有向伺服器註冊服務,也是使用不了的)( name 這個名稱是顯示在服務列表中的名稱,養成好習慣,一定要起有意義的名稱 )
spring: application: name: springCloud-ribbon-police eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/
因為該服務是提供服務的,所以下面會建一個實體類及Controller用來對外提供服務,建立實體類:Police.java
public class Police { private String id;// 警察編號,用來儲存使用者輸入的引數 private String url;// 處理請求的伺服器url private String message;// 提示資訊 public String getId() { return id; } public void setId(String id) { this.id = id; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } }
建立對外提供服務的Controller:PoliceController.java(@RestController註解中包含了@Controller+@ResponseBody)
@RestController public class PoliceController { @RequestMapping(value="/getPolice", method=RequestMethod.GET, produces=MediaType.APPLICATION_JSON_VALUE) public Police getPolice(HttpServletRequest request){ Police p = new Police(); p.setUrl(request.getRequestURL().toString()); p.setMessage("警察派出成功"); return p; } @RequestMapping(value="/getPoliceById/{id}", method=RequestMethod.GET, produces=MediaType.APPLICATION_JSON_VALUE) public Police getPolice(HttpServletRequest request, @PathVariable("id") String id){ Police p = new Police(); p.setId(id); p.setUrl(request.getRequestURL().toString()); p.setMessage("指定警察派出成功"); return p; } }
因為我們要測試負載均衡,所以這裡的服務提供者需要開啟多個服務例項,下面我們用讀取手動輸入埠號的方法,啟動多個服務例項,筆者在這裡啟動了兩個服務例項:8080、8081
@SpringBootApplication @EnableEurekaClient public class PoliceApplication { public static void main(String[] args) { Scanner scan = new Scanner(System.in); String port = scan.nextLine(); new SpringApplicationBuilder(PoliceApplication.class).properties("server.port="+port).run(args); } }
如下圖,出現了兩個服務例項,分別是:8080、8081,紅色的資訊咱們先不管他,如果實在有看著不順眼的小夥伴,可以配置心跳(簡單的來說,就是配置伺服器每隔多久檢查一次服務例項狀態,如果某個服務因為某些原因停掉 不能用了,那麼就將該服務 從服務列表中移除掉)
服務呼叫者
配置 pom.xml,加入springCloud核心依賴、配置及eureka客戶端依賴、Ribbon依賴
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.13.RELEASE</version> </parent> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Dalston.SR5</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> </dependency> </dependencies>
配置 application.yml(這裡也將該服務註冊到伺服器,一定要進行註冊)
server: port: 9090 spring: application: name: springCloud-ribbon-person eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/
建立呼叫服務Controller:PersonController.java
RestTemplate 是由 Spring Web 模組提供的工具類,與 SpringCloud 無關,是獨立存在的
因 SpringCloud 對 RestTemplate 進行了一定的擴充套件,所以 RestTemplate 具備了負載均衡的功能
@RestController @Configuration public class PersonController { @Bean @LoadBalanced public RestTemplate getRestTemplate(){ return new RestTemplate(); } @RequestMapping("/getPolice") public String getPolice(){ RestTemplate rt = getRestTemplate(); String result = rt.getForObject("http://springCloud-ribbon-police/getPolice", String.class); return result; } @RequestMapping("/getPoliceById/{id}") public String getPoliceById(@PathVariable("id") String id){ RestTemplate rt = getRestTemplate(); String result = rt.getForObject("http://springCloud-ribbon-police/getPoliceById/"+id, String.class); return result; } }
建立啟動類:PersonApplication.java
@SpringBootApplication @EnableEurekaClient public class PersonApplication { public static void main(String[] args) { new SpringApplicationBuilder(PersonApplication.class).web(true).run(args); } }
到目前為止,eureka伺服器、服務提供者、服務呼叫者(負載均衡)就已經全寫好了,下面我們訪問介面,來試一下 服務到底能不能調通
我們分別呼叫: http://localhost:9090/getPolice 、 http://localhost:9090/getPoliceById/100
通過這個簡單的例子,希望可以幫到大家,感謝大家的支援!