springcloud微服務實戰:Eureka+Zuul+Feign/Ribbon+Hystrix Turbine+SpringConfig+sleuth+zipkin

 

相信如今已經有不少小夥伴已經或者準備使用springcloud微服務了,接下來爲你們搭建一個微服務框架,後期能夠本身進行擴展。會提供一個小案例: 服務提供者和服務消費者 ,消費者會調用提供者的服務,新建的項目都是用springboot,附源碼下載,推薦使用coding地址下載,由於能夠切換分支,後期能夠及時更新。html

coding倉庫地址(推薦下載): coding地址 csdn下載地址: csdn下載地址 遠程配置倉庫地址 遠程配置倉庫地址java

若是有問題請在下邊評論,或者200909980加羣交流。mysql

Eureka/Consul:服務發現 (根據狀況選擇一個) 
Hystrix:斷路器 
Zuul:智能路由 
Ribbon/Feign:客戶端負載均衡 (Feign用的更多) 
Turbine:集羣監控 
Springcloud-config:遠程獲取配置文件nginx

接下來,咱們開始搭建項目,首先咱們到spring爲咱們提供的一個網站快速搭建springboot項目,點擊訪問,我這裏用的是gradle,若是各位客官喜歡用maven,好吧你能夠到http://mvnrepository.com/查看對應的依賴,點我訪問git

1、搭建eureka-server服務springcloud-eureka-server

使用 spring-cloud-consul 做爲服務發現 請參考 點擊查看使用springcloud consul 做爲服務發現web

eureka-server做爲服務發現的核心,第一個搭建,後面的服務都要註冊到eureka-server上,意思是告訴eureka-server本身的服務地址是啥。固然還能夠用zookeeper或者springconsul。redis

  • 1.修改build.gradle文件

若是是maven項目請對應的修改pom.xmlspring

//加入阿里的私服倉庫地址
maven { url "http://maven.aliyun.com/nexus/content/groups/public/" }

 

//加入依賴  
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka-server', version: '1.3.4.RELEASE'
//加入security,是由於訪問eureka-server須要用戶名和密碼訪問,爲了安全
compile group: 'org.springframework.boot', name: 'spring-boot-starter-security', version: '1.5.6.RELEASE'

 

還有幾點須要修改的,你們對應圖片看看,就是springboot打包的時候會提示找不到主累。 
sql

  • 2.修改 application.yml,建議用yml。
server:
  port: 8761
eureka:
  datacenter: trmap
  environment: product
  client:
    healthcheck:
      enabled: true
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
    register-with-eureka: false #關閉本身做爲客戶端註冊
    fetch-registry: false
security:
  basic:
    enabled: true
  user:
    name: root #用戶名和密碼,等會訪問的時候,會要求你登陸,服務註冊的時候也須要帶着用戶名和密碼
    password: booszy

 

  • 3.修改程序的主類,建議修改類名,要加如eureka的 @EnableEurekaServer 註解,而後運行main方法。
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

 

http://localhost:8761/ 這個是eureka-server的頁面地址,到這裏,說明eureka-server搭建好了,簡單吧,這一步必定要成功,不然後面的就不能繼續進行下去了,後邊基本相似。數據庫

2、搭建config-server服務springcloud-config-server

springcloud-config-server是用來將遠程git倉庫的配置文件動態拉下來,這樣配置文件就能夠動態的維護了。固然也能夠選擇本地倉庫。

新建一個springboot項目,修改maven私服地址,並加入一下依賴。

  • 1.修改build.gradle文件
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-config-server', version: '1.3.2.RELEASE'
compile group: 'org.springframework.boot', name: 'spring-boot-actuator', version: '1.5.6.RELEASE'
//鏈接config-server也須要用戶名和密碼
compile group: 'org.springframework.boot', name: 'spring-boot-starter-security', version: '1.5.6.RELEASE'

 

  • 2.修改application.yml文件
server:
  port: 8500
eureka:
  client:
    service-url:
      #註冊服務到eureka上,記住這裏要加上eureka-server的用戶名和密碼
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    #可能比較長,複製的時候請寫在一行
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-config-server
spring:
  application:
    name: springcloud-config-server
  cloud:
    config:
      server:
        git:
          #這是其餘項目配置文件的git倉庫地址
          uri: https://git.coding.net/yirenyishi/springcloud-config-profile
          searchPaths: '{application}'
security:
  basic:
    enabled: true
  user:
    #這是config-server的用戶名和密碼
    name: root
    password: booszy

 

  • 3.修改啓動類

修改啓動類,要加入這三個註解,由於要註冊到eureka-server上,因此須要@EnableEurekaClient這個註解

 
  
@SpringBootApplication
@EnableConfigServer
@EnableEurekaClient
public class ConfigServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConfigServerApplication.class, args);
    }
}
 
  

 

 
  

而後運行啓動springboot項目,等啓動成功後訪問eureka的頁面,會發現springcloud-config-server已經註冊到上面了,若是啓動報錯,請檢查錯誤信息。

3、搭建服務提供者服務springcloud-provider-config

編寫一個服務提供者,提供兩個接口,即獲取單個用戶的信息和獲取一個用戶列表。用到了spring-data-jpa 和 spring-webmvc ,固然大家公司用什麼你仍是繼續用什麼。

  • 注意 : 這裏除了application.xml,還須要一個bootstrap.yml, 由於bootstrap.yml得加載順序是在application.xml前邊

    1. 修改build.gradle文件
compile('org.springframework.boot:spring-boot-starter-data-jpa')
compile('org.springframework.boot:spring-boot-starter-web')
compile("com.alibaba:druid-spring-boot-starter:1.1.2")
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'
compile group: 'org.springframework.boot', name: 'spring-boot-actuator', version: '1.5.6.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-config', version: '1.3.2.RELEASE'
compile group: 'org.springframework.session', name: 'spring-session-data-redis', version: '1.3.1.RELEASE'
runtime('mysql:mysql-connector-java')

 

  • 2.編寫配置文件bootstrap.yml

* 注意 : 這裏除了application.xml,還須要一個bootstrap.yml

application.xml我是放到遠程倉庫地址的,你們能夠直接到個人遠程倉庫,根據項目名(springcloud-provider-config)查詢。配置文件的倉庫地址:點擊訪問

spring:
  application:
    name: springcloud-provider-config
  cloud:
    config:
      #config-server的配置,不須要硬編碼config-server的地址,使用service-id去eureka-server獲取cong-server的地址
      discovery:
        enabled: true
        service-id: springcloud-config-server
      fail-fast: true
      username: root
      password: booszy
      profile: dev
eureka:
  client:
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-provider-config

 

  • 3.編寫代碼

編寫主類

@SpringBootApplication
@EnableEurekaClient
public class ProviderApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }
}

 

新建UserController, 考慮篇幅 UserService 和 UserRepository就不貼代碼了,想看的能夠下載個人代碼。

@RequestMapping("user")
@RestController
public class UserController {

    @Autowired
    private UserService userService;

    /**
     * @param id
     * @return
     */
    @GetMapping("{id}")
    public User getuser(@PathVariable String id) {
        User user = null;
        try {
            System.out.println(id);
            user = userService.find(id);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return user;
    }

    /**
     * @return
     */
    @GetMapping("list")
    public List<User> users() {
        try {
            List<User> user = userService.findAll();
            if (user != null && user.size() != 0) {
                return user;
            }
            return null;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
}

 

運行springboot項目,去eureka-server查看,有沒有註冊上。

咱們的springcloud-provider-config已經註冊到eureka上了,訪問接口,成功。

4、搭建消費者服務springcloud-consumer-ribbon-config-swagger

消費者要訪問服務提供者的服務,這裏用的是經過RestTemplate請求resetful接口,使用ribbon作客戶端負載均衡,hystrix作錯誤處理,swagger生成接口文檔。文章結尾處會更新feign的案例,feign和ribbon二選一,也能夠都用。 
仍是熟悉的配方,熟悉的味道,新建springboot項目,添加項目依賴。

  • 1.修改build.gradle文件
compile('org.springframework.boot:spring-boot-starter-web')
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'
compile group: 'org.springframework.boot', name: 'spring-boot-actuator', version: '1.5.6.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-config', version: '1.3.2.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix', version: '1.3.4.RELEASE'
compile(
    "io.springfox:springfox-swagger2:2.7.0",
    "io.springfox:springfox-swagger-ui:2.7.0"
)

 

  • 2.修改bootstrap.yml文件

application.yml 在git倉庫,請前往git倉庫查看。

spring:
  application:
    name: springcloud-consumer-config
  cloud:
    config:
      discovery:
        enabled: true
        service-id: springcloud-config-server
      fail-fast: true
      username: root
      password: booszy
      profile: dev
eureka:
  client:
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-consumer-config

 

  • 3.編寫代碼

啓動類代碼

@RibbonClient 指定服務使用的負載均衡類型,name不指定服務則爲全部的服務打開負載均衡,也能夠在用yml中進行配置。 
@EnableHystrix 是支持hystrix打開斷路器,在規定時間內失敗參數超過必定參數,就會打開斷路器,不會發起請求,而是直接進入到錯誤處理方法。

@SpringBootApplication
@EnableEurekaClient
@RibbonClient(name = "springcloud-provider-config", configuration = RibbonConfiguration.class)
@ComponentScan(excludeFilters = {@ComponentScan.Filter(type = FilterType.ANNOTATION, value = ExtendRibbon.class)})
@EnableHystrix
public class ConsumerApplication {
    @Autowired
    private RestTemplateBuilder builder;

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return builder.build();
    }

    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
}

 

新建UserController

ribbon一個坑,不能接受List類型,要使用數組接收。 
@Api xxx 是swagger的註解 
@HystrixCommand(fallbackMethod=」userFallbackMethod」) 
若是請求失敗,會進入userFallbackMethod這個方法,userFallbackMethod這個方法要求參數和返回值與回調他的方法保持一致。

ribbon這個方法就是經過service-id獲取獲取服務實際的地址,這樣服務的地址就不用硬編碼了。

@Api("springcloud consumer user 控制器")
@RequestMapping("user")
@RestController
public class UserController {

    @Autowired
    private RestTemplate restTemplate;

    @Autowired
    private LoadBalancerClient loadBalancerClient;

    /**
     * @param id
     * @return
     */
    @ApiOperation(value = "根據用戶id查詢用戶信息", httpMethod = "GET", produces = "application/json")
    @ApiResponse(code = 200, message = "success", response = User.class)
    @GetMapping("{id}")
    @HystrixCommand(fallbackMethod="userFallbackMethod")
    public User getUser(@ApiParam(name = "id", required = true, value = "用戶Id") @PathVariable String id) {
        return this.restTemplate.getForObject("http://springcloud-provider-config/user/" + id, User.class);
    }

    public User userFallbackMethod(String id){
        return null;
    }

    /**
     * 這塊ribbon不支持複雜數據類型list,因此要用數組接受,而後轉list
     * @return
     */
    @GetMapping("list")
    @HystrixCommand(fallbackMethod = "userList")
    public List<User> users(HttpServletRequest request) {
        try {
            User[] forObject = this.restTemplate.getForObject("http://springcloud-provider-config/user/list", User[].class);
            List<User> users = Arrays.asList(forObject);
            return users == null ? new ArrayList<User>() : users;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public List<User> userList(HttpServletRequest request) {
        return null;
    }

    /**
     * 經過服務id獲取服務的地址
     * @return
     */
    @GetMapping("ribbon")
    public String ribbon(){
        ServiceInstance serviceInstance = loadBalancerClient.choose("springcloud-provider-config");
        return serviceInstance.getUri().toString();
    }
}

 

運行springboot項目,先看有沒有註冊到eureka-server上。

註冊成功後,訪問接口,測試是否正確。

測試swagger-ui,訪問localhost:8200/swagger-ui.html

到這裏消費者服務就算是完成了,後邊你們本身進行擴展。

5、用zuul作路由轉發和負載均衡

這些微服務都是隱藏在後端的,用戶是看不到,或者不是直接接觸,能夠用nginx或者zuul進行路由轉發和負載均衡,zuul負載均衡默認用的是ribbon。

  • 1.修改build.gradle文件
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-zuul', version: '1.3.4.RELEASE'
compile group: 'org.springframework.boot', name: 'spring-boot-actuator', version: '1.5.6.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-config', version: '1.3.2.RELEASE'

 

  • 2.修改bootstrap.yml

仍是原來的配方,application.yml在git倉庫

spring:
  application:
    name: springcloud-zuul
  cloud:
    config:
      discovery:
        enabled: true
        service-id: springcloud-config-server
      fail-fast: true
      username: root
      password: booszy
      profile: dev
eureka:
  client:
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-zuul

 

  • 3.啓動類

@RefreshScope這個註解是當application.yml配置文件發生變化的時候,不須要手動的進行重啓,調用localhost:8400/refresh,就會加載新的配置文件,固然正在訪問的客戶並不影響仍是使用舊的配置文件,由於不是重啓,後來的用戶會使用新的配置文件。注意這塊的刷新要用post請求

@SpringBootApplication 

@EnableEurekaClient
@EnableZuulProxy
@RefreshScope
public class ZuulApplication {
    public static void main(String[] args) {
        SpringApplication.run(ZuulApplication.class, args);
    }

}

 

啓動springboot項目,訪問eureka-server

這時候,咱們就要經過zuul訪問微服務了,而不是直接去訪問微服務。 
應該訪問地址http://192.168.89.89:8400/springcloud-consumer-config/user/list,這塊你要換成你的zuul地址。

可是有些人就會說,這樣之後用戶請求會不會太長,比較反感,因此能夠經過配置進行修改訪問地址。

zuul:
  routes:
    springcloud-consumer-config: /consumer/**
    springcloud-provider-config: /provider/**

 

在application.yml中加入這樣一段配置,其實就是nginx中的反向代理,使用一下簡短的能夠代理這個微服務。這個時候咱們就能夠這樣去訪問了http://192.168.89.89:8400/consumer/user/list,是否是簡短了不少

6、用hystrix-turbine-dashboard 作集羣監控

項目在生產環境中,每一個服務的訪問量都不通,有些服務的訪問量比較大,有時候有些服務掛了,不能繼續服務,須要重啓的時候,咱們並不知道,因此這時候就須要使用hystrix-turbine-dashboard作一個監控,監控全部的微服務,能夠看到這個接口實時訪問量,和健康情況。 
新建一個springboot項目,老套路,加入以下依賴

  • 1 添加依賴
    compile('org.springframework.boot:spring-boot-starter-web')
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'
    compile group: 'org.springframework.cloud', name: 'spring-cloud-netflix-turbine', version: '1.3.4.RELEASE'
    compile group: 'org.springframework.boot', name: 'spring-boot-actuator', version: '1.5.6.RELEASE'
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix', version: '1.3.4.RELEASE'
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix-dashboard', version: '1.3.4.RELEASE'

 

  • 2 修改application.yml配置文件
server:
  port: 8900
eureka:
  client:
    healthcheck:
      enabled: true
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-turbine-dashboard
turbine:
  aggregator:
    clusterConfig: default
  appConfig: springcloud-consumer-config,springcloud-provider-config
  clusterNameExpression: "'default'"
spring:
  application:
    name: springcloud-turbine-dashboard

 

appConfig 後面是要檢測的註冊在eureka上的服務名,必需要有

  • 3 修改主類

@EnableTurbine ,@EnableHystrixDashboard 一個都不能少

@SpringBootApplication
@EnableTurbine
@EnableEurekaClient
@EnableHystrixDashboard
public class TurbineDashboardApplication {

    public static void main(String[] args) {
        SpringApplication.run(TurbineDashboardApplication.class, args);
    }
}

 

而後在那個網址的輸入框裏輸網址http://localhost:8900/turbine.stream,點擊monitor stream。剛打開的時候多是空的,什麼也沒有,這並不表示你已經錯了。這時候你訪問消費者服務的接口,例如訪問http://localhost:8200/user/list,多訪問幾回,而後看控制檯有沒有出現一個監控面板,沒有就等會刷新一次,若是一直不出現,應該是配置有問題。

後邊更新會追加到後邊,後邊隨時更新


2018-01-24 更新:補充使用feign


7、使用feign

在實際開發中,feign使用的仍是挺多的,feign底層仍是使用了ribbon。廢話很少說,直接上步驟,在服務消費者中使用feign訪問服務提供者。新建一個springboot項目,或者複製一個。

  • 1加入依賴

swagger不使用的話,能夠刪掉。

compile('org.springframework.boot:spring-boot-starter-web')
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'
    compile group: 'org.springframework.boot', name: 'spring-boot-actuator', version: '1.5.6.RELEASE'
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-config', version: '1.3.2.RELEASE'
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-feign', version: '1.3.4.RELEASE'
    compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix', version: '1.3.4.RELEASE'
    compile(
            "io.springfox:springfox-swagger2:2.7.0",
            "io.springfox:springfox-swagger-ui:2.7.0"
    )

 

  • 2修改配置文件

    這裏修改的是bootstrap.yml,這裏吧application.yml的配置也貼出來,這個是放在遠程倉庫的,經過config動態拉取下來。

spring:
  application:
    name: springcloud-consumer-feign
  cloud:
    config:
      discovery:
        enabled: true
        service-id: springcloud-config-server
      fail-fast: true
      username: root
      password: booszy
      profile: csdn
eureka:
  client:
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-consumer-feign

 

application.yml

server:
  port: 8201
logging:
  level:
    com.yasaka.stock.feign.MFeignClient: debug
feign:
  hystrix:
    enabled: true
ribbon:
  ReadTimeout:  30000
  ConnectTimeout:  15000
hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 10000

 

feign的默認請求超時時間是1s,因此常常會出現超時的問題,這裏我設置的是10s,由於個人數據庫服務器在美國,因此有時候請求會比較慢。ribbon的請求時間也要設置,由於feign用的是ribbon。

  • 3 編碼

一、主類註解

@EnableFeignClients 
@EnableCircuitBreaker 
@EnableHystrix

 

這三個都要,hystrix主要做用是斷路器,會進如fein的fallback中。

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
@EnableCircuitBreaker
@EnableHystrix
public class ConsumerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
}

 

二、編寫feign接口,MFeignClient.class

name是指要請求的服務名稱。這裏請求的是服務提供者 
fallback 是指請求失敗,進入斷路器的類,和使用ribbon是同樣的。 
configuration 是feign的一些配置,例如編碼器等。

@FeignClient(name = "springcloud-provider-config",fallback = HystrixFeignFallback.class, configuration = MFeignConfig.class)
public interface MFeignClient {

    //這裏是使用feign請求的地址
    @RequestMapping(method = RequestMethod.GET, value = "/user/{id}")
    User getUser(@PathVariable("id") String id);

    //新版本支持使用GetMapping,以前的老版本可能不支持
    @GetMapping(value = "/user/list")
    List<User> getUsers();
}

 

  • 3 MFeignConfig.class feign的配置

    這裏配置了feign的打印日誌等級

@Configuration
public class MFeignConfig {
    @Bean
    Logger.Level feignLoggerLevel() {
        return Logger.Level.FULL;
    }
}

 

  • 4 HystrixFeignFallback.class ,斷路器回調方法

    斷路器要實現上邊定義的MFeignClient接口,請求失敗,進入斷路器時,會回調這裏的方法。

@Component
public class HystrixFeignFallback implements MFeignClient {
    @Override
    public User getUser(String id) {
        User user = new User();
        user.setId("233");
        return user;
    }

    @Override
    public List<User> getUsers() {
        return new ArrayList<User>();
    }
}

 

  • 5 在controller中使用feign
@Api("springcloud consumer user 控制器")
@RequestMapping("user")
@RestController
public class UserController {

    @Autowired
    private MFeignClient feignClient;

    /**
     * @param id
     * @return
     */
    @ApiOperation(value = "根據用戶id查詢用戶信息", httpMethod = "GET", produces = "application/json")
    @ApiResponse(code = 200, message = "success", response = User.class)
    @GetMapping("{id}")
    public User getUser(@ApiParam(name = "id",   required = true, value = "用戶Id") @PathVariable String id) {
        User user = feignClient.getUser(id);
        return user;
    }


    @GetMapping("list")
    public List<User> users(HttpServletRequest request) {
        try {
            List<User> users = feignClient.getUsers();
            return users == null ? new ArrayList<User>() : users;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
}

 


20180125更新: 補充使用sleuth+zipkin 實現鏈路追蹤服務


8、使用sleuth+zipkin 實現鏈路追蹤服務

在使用微服務的時候,咱們發現,有時候排錯很差排查,因此就給你們整個這個鏈路追蹤,很方便知道是哪個服務調用哪個服務出現了問題。由於有些項目可能服務比較多。

  • 1 添加依賴

    新建一個springboot項目 
    雖然其餘服務調用zipkin不是從eureka上動態過去服務地址,而是硬編碼,可是這塊仍是考慮吧zipkin註冊到eureka上。

compile group: 'io.zipkin.java', name: 'zipkin-server', version: '2.4.4'
compile group: 'io.zipkin.java', name: 'zipkin-autoconfigure-ui', version: '2.4.4'
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-eureka', version: '1.3.4.RELEASE'

 

  • 2 修改application配置文件
server:
  port: 9411
eureka:
  client:
    service-url:
      defaultZone: http://root:booszy@localhost:8761/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
    appname: springcloud-zipkin-server
spring:
  application:
    name: springcloud-zipkin-server

 

  • 3 主類註解添加

@EnableZipkinServer 主要是這個註解 
啓動服務後訪問http://localhost:9411,就能夠打開zipkin的控制檯頁面,這時候應該是什麼都沒有

@SpringBootApplication
@EnableZipkinServer
@EnableEurekaClient
public class ZipkinServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ZipkinServerApplication.class, args);
    }
}

 

  • 4 其餘服務中調用

這裏咱們在消費者服務和提供者服務裏都加入以下依賴

....
compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-sleuth', version: '1.3.1.RELEASE'
compile group: 'org.springframework.cloud', name: 'spring-cloud-sleuth-zipkin', version: '1.3.1.RELEASE'

 

而後修改配置文件,bootstrap.yml、 
這塊zipkin的地址是硬編碼的,目前還沒發現怎麼從服務註冊中心eureka上動態獲取,之後有解決方案,會更新帖子 
sleuth這個是配置提取率,能夠配置也能夠不配置

spring:
  zipkin:
    base-url: http://localhost:9411
  sleuth:
    sampler:
      percentage: 1.0

 

啓動服務,而後訪問消費者服務的接口,這時候訪問zipkin的控制檯http://localhost:9411

點擊依賴分析,能夠看到調用服務鏈,由於這塊只涉及到兩個服務,因此只有兩個,在實際生產環境中,這塊可能有不少,到時候看起來就特別直觀了。

參考:springcloud微服務實戰:Eureka+Zuul+Feign/Ribbon+Hystrix Turbine+SpringConfig+sleuth+zipkin

相關文章
相關標籤/搜索