简单spring cloud服务升级实现
生活随笔
收集整理的這篇文章主要介紹了
简单spring cloud服务升级实现
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、升級原則
- 隔離性:v1升級到v2時,相互獨立,互不不干擾。
- 穩定性:服務不停止,完成升級。接口保持暢通。
2、具體實現
2.1 eureka項目
搭建eureka,網上很多,就省略了。
2.2 feign接口項目
2.2.1 依賴
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.spring.cloud.pro</groupId><artifactId>com.spring.cloud.pro</artifactId><version>1.0.0.RELEASE</version></parent><artifactId>com.spring.cloud.pro.facade</artifactId><description>接口</description><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency></dependencies> </project>2.2.2 接口定義
import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam;import com.spring.pro.model.User;/** * @Title: UserFacade.java * @ProjectName com.spring.cloud.pro.facade* @Description: * @author ybwei * @date 2019年1月11日 下午4:18:09 */ @FeignClient("eureka-provider${version}") //name等于服務提供者的spring.application.name public interface UserFacade {/** * @Description: * @Param: @param id* @Param: @return* @Param: @throws Exception* @return: User* @Author: ybwei* @Date: 2019年1月11日 下午4:20:59*/ @GetMapping("/getUser")public User getUser(@RequestParam("id") Integer id) throws Exception; } import lombok.Data;/** * @Title: User.java * @ProjectName com.spring.cloud.pro.facade* @Description: * @author ybwei * @date 2019年1月11日 下午4:18:49 */ @Data public class User {private Integer id;private String name;private Integer age;}2.3 生產者
2.3.1 依賴
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.spring.cloud.pro</groupId><artifactId>com.spring.cloud.pro</artifactId><version>1.0.0.RELEASE</version></parent><artifactId>com.spring.cloud.provider</artifactId><version>1.0.1.RELEASE</version><description>服務提供者</description><dependencies><dependency><groupId>${project.parent.groupId}</groupId><artifactId>com.spring.cloud.pro.facade</artifactId><version>${project.parent.version}</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies><build><finalName>${project.artifactId}</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build> </project>2.3.2?application.yml配置
version: '@project.version@' #項目版本 server:port: 8083 spring:application:name: eureka-provider${version} eureka:client:service-url:defaultZone: http://localhost:8761/eureka hystrix:command:default:execution:timeout:enabled: false #hystrix禁止超時設置2.3.3 代碼
package com.spring.pro.controller;import org.springframework.web.bind.annotation.RestController;import com.spring.pro.facade.UserFacade; import com.spring.pro.model.User;/** * @Title: UserController.java * @ProjectName com.spring.cloud.provider* @Description: * @author ybwei * @date 2019年1月11日 下午4:25:19 */ @RestController public class UserController implements UserFacade {@Overridepublic User getUser(Integer id) throws Exception {User user=new User();user.setId(id);user.setName("李四");user.setAge(21);return user;}}2.4 消費者
2.4.1 依賴
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.spring.cloud.pro</groupId><artifactId>com.spring.cloud.pro</artifactId><version>1.0.0.RELEASE</version></parent><artifactId>com.spring.cloud.pro.consumer</artifactId><version>1.0.1.RELEASE</version><description>消費者</description><dependencies><dependency><groupId>${project.parent.groupId}</groupId><artifactId>com.spring.cloud.pro.facade</artifactId><version>${project.parent.version}</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies><build><finalName>${project.artifactId}</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build> </project>2.4.2?application.yml配置
version: '@project.version@' #項目版本 server:port: 8084 spring:application:name: eureka-consumer${version} eureka:client:service-url:defaultZone: http://localhost:8761/eureka feign: hystrix:enabled: true #啟用hystrix hystrix:command:default:execution:timeout:enabled: false #hystrix禁止超時設置2.4.3 代碼
package com.spring.pro.controller;import javax.annotation.Resource;import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController;import com.spring.pro.facade.UserFacade; import com.spring.pro.model.User;/*** @Title: UserController.java* @ProjectName com.spring.cloud.pro.consumer* @Description:* @author ybwei* @date 2019年1月11日 下午4:27:14*/ @RestController public class UserController {@Resourceprivate UserFacade userFacade;@GetMapping("/getUser")public User getUser(Integer id) throws Exception {return userFacade.getUser(id);} }3、說明
3.1 核心邏輯
消費者調用的的生產者是spring.application.name+版本號。
3.2 升級過程
當系統進行從v1升級到v2:
注意:示例中生產者、消費者項目使用的pom.xml中的版本號,也可以使用常量(如1.0),只要保持兩者一致即可。
3.3 適用場景
- 接口v1版本與v2版本不兼容時,app強制更新,適用。
- 接口v1版本與v2版本兼容,app不需要更新,適用。
3.4 版本控制
3.4.1 命名規范
參考軟件版本命名規范
3.4.2 注意
多團隊開發時,版本號盡量由一個人來控制,避免沖突。同一天上線,為統一版本號。不同時間上線為不同版本號。
總結
以上是生活随笔為你收集整理的简单spring cloud服务升级实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Gradle 2.0 用户指南翻译——第
- 下一篇: 核密度估计_拔剑-浆糊的传说_新浪博客