欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解使用Spring Cloud Consul實現(xiàn)服務的注冊和發(fā)現(xiàn)

 更新時間:2018年06月11日 09:42:20   作者:西夏一品堂  
這篇文章主要介紹了詳解使用Spring Cloud Consul實現(xiàn)服務的注冊和發(fā)現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

首先安裝consul環(huán)境,參照之前的文章:http://www.dbjr.com.cn/article/141789.htm

項目規(guī)劃,2個服務端,1個客戶端

首先來看服務端,

一:服務端1:

項目依賴

<dependencyManagement> 
  <dependencies> 
    <dependency> 
      <groupId>org.springframework.cloud</groupId> 
      <artifactId>spring-cloud-consul-dependencies</artifactId> 
      <version>1.0.1.RELEASE</version> 
      <type>pom</type> 
      <scope>import</scope> 
    </dependency> 
  </dependencies> 
</dependencyManagement> 
 
<dependencies> 
  <dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-actuator</artifactId> 
    <version>1.3.5.RELEASE</version> 
  </dependency> 
  <dependency> 
    <groupId>org.springframework.cloud</groupId> 
    <artifactId>spring-cloud-starter-consul-discovery</artifactId> 
  </dependency> 
</dependencies> 

注意,增加spring-boot-actuator是為了項目可以訪問/health 路徑來判斷服務是否健康

package com.pp.consul1; 
 
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RestController; 
 
@SpringBootApplication 
@EnableDiscoveryClient 
@RestController 
public class ConsulApp { 
   
  @RequestMapping("/home") 
  public Object home() { 
    System.out.println("1111111111111"); 
    return "OK11"; 
  } 
   
  public static void main( String[] args ) { 
    SpringApplication.run(ConsulApp.class, args); 
  } 
} 

application.properties 配置內(nèi)容

server.port=9955  
spring.application.name=Consul-Server-1 
spring.cloud.consul.host=192.168.1.100 
spring.cloud.consul.port=8500 
spring.cloud.consul.enabled=true 
spring.cloud.consul.discovery.enabled=true 
spring.cloud.consul.discovery.instanceId=tomcat1 
spring.cloud.consul.discovery.serviceName=tomcat 
spring.cloud.consul.discovery.hostname=192.168.2.95 
spring.cloud.consul.discovery.port=${server.port} 
spring.cloud.consul.discovery.healthCheckUrl=http://192.168.2.95:9955/health 
spring.cloud.consul.discovery.healthCheckInterval=10s 
spring.cloud.consul.discovery.tags=dev 

看過我之前文章的,應該對這些配置很清楚了。這樣,一個服務端就配置寫好了。

由于我們增加了@EnableDiscoveryClient注解,所以,系統(tǒng)啟動的時候,就會向consul注冊一個服務,服務的名字為tomcat, ID為tomcat1

訪問consul的HTTP API /v1/catalog/service/tomcat 輸出如下:

{ 
  "Node":"192.168.1.100", 
  "Address":"192.168.1.100", 
  "ServiceID":"tomcat1", 
  "ServiceName":"tomcat", 
  "ServiceTags":["dev"], 
  "ServiceAddress":"192.168.2.95", 
  "ServicePort":9955, 
  "ServiceEnableTagOverride":false, 
  "CreateIndex":993, 
  "ModifyIndex":1057 
} 

二:服務端2

項目依賴和上面一樣 

package com.pp.consul2;  
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RestController; 
 
@SpringBootApplication 
@EnableDiscoveryClient 
@RestController 
public class ConsulApp { 
   
  @RequestMapping("/home") 
  public Object home() { 
    System.out.println("2222222222222222"); 
    return "OK22"; 
  } 
   
  public static void main( String[] args ) { 
    SpringApplication.run(ConsulApp.class, args); 
  } 
} 

application.properties 配置內(nèi)容:

server.port=9966 
 
spring.application.name=Consul-Server-2 
spring.cloud.consul.host=192.168.1.100 
spring.cloud.consul.port=8500 
spring.cloud.consul.enabled=true 
spring.cloud.consul.discovery.enabled=true 
spring.cloud.consul.discovery.instanceId=tomcat2 
spring.cloud.consul.discovery.serviceName=tomcat 
spring.cloud.consul.discovery.hostname=192.168.2.95 
spring.cloud.consul.discovery.port=${server.port} 
spring.cloud.consul.discovery.healthCheckUrl=http://192.168.2.95:9966/health 
spring.cloud.consul.discovery.healthCheckInterval=10s 
spring.cloud.consul.discovery.tags=test 

三:客戶端

項目依賴,只需要spring-cloud-starter-consul-discovery

application.properties 配置內(nèi)容:

server.port=9977 
 
spring.application.name=Consul-Client 
spring.cloud.consul.host=192.168.1.100 
spring.cloud.consul.port=8500 
spring.cloud.consul.discovery.register=false 

注意,這里的spring.cloud.consul.discovery.register需要配置成false,否則系統(tǒng)啟動的時候,會向consul注冊一個服務

package com.pp.client; 
 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 
import org.springframework.cloud.client.discovery.DiscoveryClient; 
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; 
import org.springframework.cloud.client.loadbalancer.LoadBalancerClient; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RestController; 
 
@SpringBootApplication 
@EnableDiscoveryClient 
@RestController 
public class ConsulClient { 
   
  @Autowired 
  private LoadBalancerClient loadBalancer; 
   
  @Autowired 
  private DiscoveryClient discoveryClient; 
   
  /** 
   * 從所有服務中選擇一個服務(輪詢) 
   */ 
  @RequestMapping("/discover") 
  public Object discover() { 
    return loadBalancer.choose("tomcat").getUri().toString(); 
  } 
   
  /** 
   * 獲取所有服務 
   */ 
  @RequestMapping("/services") 
  public Object services() { 
    return discoveryClient.getInstances("tomcat"); 
  } 
   
  public static void main( String[] args ) { 
    SpringApplication.run(ConsulClient.class, args); 
  } 
} 

啟動之后,就可以訪問/discover,/services 查看效果了。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • java?Semaphore共享鎖實現(xiàn)原理解析

    java?Semaphore共享鎖實現(xiàn)原理解析

    這篇文章主要為大家介紹了Semaphore共享鎖實現(xiàn)原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • java打印表格 將ResultSet中的數(shù)據(jù)打印成表格問題

    java打印表格 將ResultSet中的數(shù)據(jù)打印成表格問題

    這篇文章主要介紹了java打印表格 將ResultSet中的數(shù)據(jù)打印成表格問題。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • JDBC的ResultSet使用說明

    JDBC的ResultSet使用說明

    今天小編就為大家分享一篇JDBC的ResultSet使用說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • mybatis plus開發(fā)過程中遇到的問題記錄及解決

    mybatis plus開發(fā)過程中遇到的問題記錄及解決

    這篇文章主要介紹了mybatis plus開發(fā)過程中遇到的問題記錄及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • java中?${}?和?#{}?有什么區(qū)別

    java中?${}?和?#{}?有什么區(qū)別

    本文主要介紹了java中${}和#{}有什么區(qū)別,${}和#{}都是MyBatis中用來替換參數(shù)的,它們都可以將用戶傳遞過來的參數(shù),替換到MyBatis最終生成的SQL中,但它們區(qū)別卻是很大的,感興趣的小伙伴可以一起來學習下面詳細內(nèi)容
    2022-08-08
  • 關于IDEA2020.1新建項目maven PKIX 報錯問題解決方法

    關于IDEA2020.1新建項目maven PKIX 報錯問題解決方法

    這篇文章主要介紹了關于IDEA2020.1新建項目maven PKIX 報錯問題解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • Java精品項目瑞吉外賣之員工新增篇

    Java精品項目瑞吉外賣之員工新增篇

    這篇文章主要為大家詳細介紹了java精品項目-瑞吉外賣訂餐系統(tǒng),此項目過大,分為多章獨立講解,本篇內(nèi)容為新增員工功能的實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • springboot讀取自定義配置文件節(jié)點的方法

    springboot讀取自定義配置文件節(jié)點的方法

    這篇文章主要介紹了springboot讀取自定義配置文件節(jié)點的方法,本文給大家介紹的非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2018-05-05
  • SpringBoot利用ThreadPoolTaskExecutor批量插入百萬級數(shù)據(jù)

    SpringBoot利用ThreadPoolTaskExecutor批量插入百萬級數(shù)據(jù)

    在處理大量數(shù)據(jù)時,為了提高效率和性能,通常需要采用批量插入的方式,本文主要介紹了SpringBoot利用ThreadPoolTaskExecutor批量插入百萬級數(shù)據(jù),具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • Mybatis的詳細使用教程

    Mybatis的詳細使用教程

    這篇文章主要介紹了Mybatis的詳細使用教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12

最新評論