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

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

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

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

項(xiàng)目規(guī)劃,2個(gè)服務(wù)端,1個(gè)客戶端

首先來看服務(wù)端,

一:服務(wù)端1:

項(xiàng)目依賴

<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是為了項(xiàng)目可以訪問/health 路徑來判斷服務(wù)是否健康

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 

看過我之前文章的,應(yīng)該對這些配置很清楚了。這樣,一個(gè)服務(wù)端就配置寫好了。

由于我們增加了@EnableDiscoveryClient注解,所以,系統(tǒng)啟動(dòng)的時(shí)候,就會(huì)向consul注冊一個(gè)服務(wù),服務(wù)的名字為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 
} 

二:服務(wù)端2

項(xiàng)目依賴和上面一樣 

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 

三:客戶端

項(xiàng)目依賴,只需要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)啟動(dòng)的時(shí)候,會(huì)向consul注冊一個(gè)服務(wù)

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; 
   
  /** 
   * 從所有服務(wù)中選擇一個(gè)服務(wù)(輪詢) 
   */ 
  @RequestMapping("/discover") 
  public Object discover() { 
    return loadBalancer.choose("tomcat").getUri().toString(); 
  } 
   
  /** 
   * 獲取所有服務(wù) 
   */ 
  @RequestMapping("/services") 
  public Object services() { 
    return discoveryClient.getInstances("tomcat"); 
  } 
   
  public static void main( String[] args ) { 
    SpringApplication.run(ConsulClient.class, args); 
  } 
} 

啟動(dòng)之后,就可以訪問/discover,/services 查看效果了。

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

相關(guān)文章

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

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

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

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

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

    JDBC的ResultSet使用說明

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

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

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

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

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

    關(guān)于IDEA2020.1新建項(xiàng)目maven PKIX 報(bào)錯(cuò)問題解決方法

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

    Java精品項(xiàng)目瑞吉外賣之員工新增篇

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

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

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

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

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

    Mybatis的詳細(xì)使用教程

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

最新評論