遷移到spring cloud方案思考

現(xiàn)狀

  • 請求經(jīng)過zuul,反向代理到內(nèi)部其他子服務(wù) [需要網(wǎng)關(guān)后臺配置子服務(wù)IP]
  • 內(nèi)部服務(wù)調(diào)用dubbo;內(nèi)部框架新項(xiàng)目已經(jīng)全部遷移到spring-boot
現(xiàn)狀.png
  • 服務(wù)配置ip,一兩臺服務(wù)沒問題,40臺怎么辦?引入注冊中心

遷移思路

  • 首先引進(jìn) Eureka,作為注冊中心
  • 網(wǎng)關(guān)轉(zhuǎn)發(fā)集成 Eureka (解決配置ip問題)
  • 對于內(nèi)部dubbo調(diào)用,可以嘗試在提供一套spring cloud api
  • 嘗試所有的服務(wù)都使用jar包啟動
  • 所有都http,方便測試

最小spring cloud

image.png

Eureka部署

  • 線上需要部署三臺或者兩臺,集群部署

遷移步驟

首先解決網(wǎng)關(guān)Eureka集成問題

  • 動態(tài)添加新服務(wù)(還是走網(wǎng)關(guān)后臺)【不用再配置IP】
  • 灰度策略修改,使用Eureka
 DynamicServerListLoadBalancer
 

統(tǒng)一ribbon復(fù)雜均衡灰度功能

首先規(guī)范eureka的metamap所需要的信息

遷移

  • 在工程中創(chuàng)建一個新的模塊upms-cloud-api
  • upms-cloud-api引用原來給dubbo服務(wù)的upms-api
image.png
  • 配置eureka

*這樣就只需要添加一套api的接口,dto和其他的都不用改變

  • 接口的寫法如下
/**
 * @date: 17/10/24
 */
@FeignClient("upms-service")
@RequestMapping("/upms/skillGroup")
public interface SkillGroupApi {


  /**
   * 獲取員工所屬技能組
   *
   * @param jobNo 員工工號
   * @return
   */
  @GetMapping("/getListByJobNo")
  GrootResult<List<SkillGroupInfoDto>> getListByJobNo(@RequestParam("jobNo") String jobNo);

}
  • 關(guān)于微服務(wù)命名的規(guī)范:業(yè)務(wù)服務(wù)都有 xxx-upms-service 命名 xxx最好是業(yè)務(wù)組
  • 消費(fèi)方調(diào)用這個接口的時候 引入jar包
      <dependency>
            <groupId>com.yyfq.groot.upms</groupId>
            <artifactId>upms-cloud-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
  • 同時配置Feign
@EnableFeignClients(
    basePackageClasses = SkillGroupApi.class
)
@Configurable
public class ApiConfig {

}
  • 消費(fèi)方調(diào)用 例子
/**
 * @date: 17/10/24
 */
@Api(tags = "test", description = "測試")
@RestController
@RequestMapping("/test")
public class TestController extends AbstractController {

 // 注入 SkillGroupApi 即可
  @Autowired
  private SkillGroupApi skillGroupApi;


  @ApiOperation("獲取技能組")
  @GetMapping("skillGroup")
  public List<SkillGroupInfoDto> skillGroup(String jobNo) {

    GrootResult<List<SkillGroupInfoDto>> result = skillGroupApi.getListByJobNo(jobNo);

    return result.getResult();
  }
}

服務(wù)調(diào)用規(guī)范

  • 是否需要安裝業(yè)務(wù)組,每個組同zuul提供唯一的對外接口
  • 組內(nèi)服務(wù)的內(nèi)部調(diào)用使用feign
  • 組內(nèi)服務(wù)是否需要分層,下層服務(wù)不能調(diào)用上層服務(wù)
  • 通過擴(kuò)展ribbon使用metadata,控制服務(wù)調(diào)用

集成分布式追蹤

  • 使用zipkin
  • 部署zipkin server
<dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-server</artifactId>
        </dependency>

        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-autoconfigure-ui</artifactId>
        </dependency>
@SpringBootApplication
@EnableZipkinServer
public class ZipkinApplication {

  public static void main(String[] args) {
    SpringApplication.run(ZipkinApplication.class, args);
  }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容