springcloud(十四)Consul

Spring Cloud Consul作为注册中心

consul官方文档:https://www.consul.io/docs/acl/index.html

spring cloud官方资料:https://spring.io/projects/spring-cloud-consul

https://cloud.spring.io/spring-cloud-consul/reference/html/

一、安装consul

1. 下载地址:https://www.consul.io/downloads.html

2. window下安装,解压文件到D:\software\consul1.5.3目录

3. 运行cmd命令,cd到D:\software\consul1.5.3目录

4. 执行命令consul agent -dev(运行consul)

查看请求http://127.0.0.1:8500 (consul默认端口为8500)

到此安装成功

二、配置consul服务提供者

1. 创建spring-cloud-consul-provider工程,pom.xml文件内容

<?xml version="1.0" encoding="UTF-8"?>
<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>

    <groupId>com.zsx</groupId>
    <artifactId>spring-cloud-consul-provider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>spring-cloud-consul-provider</name>
    <description>Spring Cloud Consul Provider project</description>
    <properties>
        <spring-boot-admin-starter-client.version>2.1.6</spring-boot-admin-starter-client.version>
    </properties>
    <parent>
        <groupId>com.zsx</groupId>
        <artifactId>spring-cloud-customize-dependencies</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <relativePath>../spring-cloud-customize-dependencies/pom.xml</relativePath>
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-zipkin</artifactId>
        </dependency>
        <dependency>
            <groupId>de.codecentric</groupId>
            <artifactId>spring-boot-admin-starter-client</artifactId>
            <version>${spring-boot-admin-starter-client.version}</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.zsx.ConsulProviderApplication</mainClass>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

2. application.yml配置文件

server:
  port: 8094
spring:
  application:
    name: spring-cloud-consul-provider
  boot:
    admin:
      client:
        url: http://localhost:8092
  zipkin:
    base-url: http://localhost:8080
  cloud:
    consul:
      host: localhost
      port: 8500
management:
  endpoints:
    web:
      exposure:
        include: '*'
  endpoint:
    health:
      show-details: always

3. api接口类

package com.zsx.api.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("api/v1/provider")
public class ConsulProviderTestController {

    @Value("${server.port}")
    private String port;

    @GetMapping("/{message}")
    public ResponseEntity get(@PathVariable("message") String message) {
        return new ResponseEntity(String.format("The message content is : %s, Service port is : %s", message, port), HttpStatus.OK);
    }
}

4. 引导类

package com.zsx;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableDiscoveryClient
public class ConsulProviderApplication {

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

5. 启动引导类主程序

C:\software\jdk-11.0.3\bin\java.exe -XX:TieredStopAtLevel=1 -noverify -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-javaagent:C:\software\JetBrains\IntelliJ IDEA 2019.1.3\lib\idea_rt.jar=3776:C:\software\JetBrains\IntelliJ IDEA 2019.1.3\bin" -Dfile.encoding=UTF-8 -classpath F:\IdeaProjects\spring-cloud\spring-cloud-consul-provider\target\classes;D:\repository\org\springframework\cloud\spring-cloud-starter-consul-discovery\2.1.2.RELEASE\spring-cloud-starter-consul-discovery-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-consul\2.1.2.RELEASE\spring-cloud-starter-consul-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-commons\2.1.2.RELEASE\spring-cloud-commons-2.1.2.RELEASE.jar;D:\repository\org\springframework\security\spring-security-crypto\5.1.5.RELEASE\spring-security-crypto-5.1.5.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-context\2.1.2.RELEASE\spring-cloud-context-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-consul-core\2.1.2.RELEASE\spring-cloud-consul-core-2.1.2.RELEASE.jar;D:\repository\com\ecwid\consul\consul-api\1.4.1\consul-api-1.4.1.jar;D:\repository\com\google\code\gson\gson\2.8.5\gson-2.8.5.jar;D:\repository\org\apache\httpcomponents\httpclient\4.5.9\httpclient-4.5.9.jar;D:\repository\commons-codec\commons-codec\1.11\commons-codec-1.11.jar;D:\repository\org\apache\httpcomponents\httpcore\4.4.11\httpcore-4.4.11.jar;D:\repository\org\springframework\cloud\spring-cloud-consul-discovery\2.1.2.RELEASE\spring-cloud-consul-discovery-2.1.2.RELEASE.jar;D:\repository\commons-configuration\commons-configuration\1.8\commons-configuration-1.8.jar;D:\repository\commons-lang\commons-lang\2.6\commons-lang-2.6.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-hystrix\2.1.2.RELEASE\spring-cloud-netflix-hystrix-2.1.2.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-autoconfigure\2.1.6.RELEASE\spring-boot-autoconfigure-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter-aop\2.1.6.RELEASE\spring-boot-starter-aop-2.1.6.RELEASE.jar;D:\repository\org\aspectj\aspectjweaver\1.9.4\aspectjweaver-1.9.4.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-netflix-ribbon\2.1.2.RELEASE\spring-cloud-starter-netflix-ribbon-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter\2.1.2.RELEASE\spring-cloud-starter-2.1.2.RELEASE.jar;D:\repository\org\springframework\security\spring-security-rsa\1.0.7.RELEASE\spring-security-rsa-1.0.7.RELEASE.jar;D:\repository\org\bouncycastle\bcpkix-jdk15on\1.60\bcpkix-jdk15on-1.60.jar;D:\repository\org\bouncycastle\bcprov-jdk15on\1.60\bcprov-jdk15on-1.60.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-ribbon\2.1.2.RELEASE\spring-cloud-netflix-ribbon-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-archaius\2.1.2.RELEASE\spring-cloud-netflix-archaius-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-netflix-archaius\2.1.2.RELEASE\spring-cloud-starter-netflix-archaius-2.1.2.RELEASE.jar;D:\repository\com\netflix\archaius\archaius-core\0.7.6\archaius-core-0.7.6.jar;D:\repository\com\google\code\findbugs\jsr305\3.0.1\jsr305-3.0.1.jar;D:\repository\com\netflix\ribbon\ribbon\2.3.0\ribbon-2.3.0.jar;D:\repository\com\netflix\ribbon\ribbon-transport\2.3.0\ribbon-transport-2.3.0.jar;D:\repository\io\reactivex\rxnetty-contexts\0.4.9\rxnetty-contexts-0.4.9.jar;D:\repository\io\reactivex\rxnetty-servo\0.4.9\rxnetty-servo-0.4.9.jar;D:\repository\com\netflix\hystrix\hystrix-core\1.5.18\hystrix-core-1.5.18.jar;D:\repository\org\hdrhistogram\HdrHistogram\2.1.9\HdrHistogram-2.1.9.jar;D:\repository\javax\inject\javax.inject\1\javax.inject-1.jar;D:\repository\io\reactivex\rxnetty\0.4.9\rxnetty-0.4.9.jar;D:\repository\com\google\guava\guava\16.0.1\guava-16.0.1.jar;D:\repository\com\netflix\ribbon\ribbon-core\2.3.0\ribbon-core-2.3.0.jar;D:\repository\com\netflix\ribbon\ribbon-httpclient\2.3.0\ribbon-httpclient-2.3.0.jar;D:\repository\commons-collections\commons-collections\3.2.2\commons-collections-3.2.2.jar;D:\repository\com\sun\jersey\jersey-client\1.19.1\jersey-client-1.19.1.jar;D:\repository\com\sun\jersey\jersey-core\1.19.1\jersey-core-1.19.1.jar;D:\repository\javax\ws\rs\jsr311-api\1.1.1\jsr311-api-1.1.1.jar;D:\repository\com\sun\jersey\contribs\jersey-apache-client4\1.19.1\jersey-apache-client4-1.19.1.jar;D:\repository\com\netflix\servo\servo-core\0.12.21\servo-core-0.12.21.jar;D:\repository\com\netflix\netflix-commons\netflix-commons-util\0.3.0\netflix-commons-util-0.3.0.jar;D:\repository\com\netflix\ribbon\ribbon-loadbalancer\2.3.0\ribbon-loadbalancer-2.3.0.jar;D:\repository\com\netflix\netflix-commons\netflix-statistics\0.1.1\netflix-statistics-0.1.1.jar;D:\repository\io\reactivex\rxjava\1.3.8\rxjava-1.3.8.jar;D:\repository\joda-time\joda-time\2.10.2\joda-time-2.10.2.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-zipkin\2.1.2.RELEASE\spring-cloud-starter-zipkin-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-sleuth\2.1.2.RELEASE\spring-cloud-starter-sleuth-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-sleuth-core\2.1.2.RELEASE\spring-cloud-sleuth-core-2.1.2.RELEASE.jar;D:\repository\org\aspectj\aspectjrt\1.9.4\aspectjrt-1.9.4.jar;D:\repository\io\zipkin\brave\brave\5.6.5\brave-5.6.5.jar;D:\repository\io\zipkin\brave\brave-context-log4j2\5.6.5\brave-context-log4j2-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-spring-web\5.6.5\brave-instrumentation-spring-web-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-http\5.6.5\brave-instrumentation-http-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-spring-rabbit\5.6.5\brave-instrumentation-spring-rabbit-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-kafka-clients\5.6.5\brave-instrumentation-kafka-clients-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-httpclient\5.6.5\brave-instrumentation-httpclient-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-httpasyncclient\5.6.5\brave-instrumentation-httpasyncclient-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-spring-webmvc\5.6.5\brave-instrumentation-spring-webmvc-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-servlet\5.6.5\brave-instrumentation-servlet-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-jms\5.6.5\brave-instrumentation-jms-5.6.5.jar;D:\repository\org\springframework\cloud\spring-cloud-sleuth-zipkin\2.1.2.RELEASE\spring-cloud-sleuth-zipkin-2.1.2.RELEASE.jar;D:\repository\io\zipkin\zipkin2\zipkin\2.14.2\zipkin-2.14.2.jar;D:\repository\io\zipkin\reporter2\zipkin-reporter\2.8.4\zipkin-reporter-2.8.4.jar;D:\repository\io\zipkin\reporter2\zipkin-sender-kafka\2.8.4\zipkin-sender-kafka-2.8.4.jar;D:\repository\io\zipkin\reporter2\zipkin-sender-amqp-client\2.8.4\zipkin-sender-amqp-client-2.8.4.jar;D:\repository\de\codecentric\spring-boot-admin-starter-client\2.1.6\spring-boot-admin-starter-client-2.1.6.jar;D:\repository\de\codecentric\spring-boot-admin-client\2.1.6\spring-boot-admin-client-2.1.6.jar;D:\repository\org\springframework\boot\spring-boot-starter-actuator\2.1.6.RELEASE\spring-boot-starter-actuator-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-actuator-autoconfigure\2.1.6.RELEASE\spring-boot-actuator-autoconfigure-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-actuator\2.1.6.RELEASE\spring-boot-actuator-2.1.6.RELEASE.jar;D:\repository\io\micrometer\micrometer-core\1.1.5\micrometer-core-1.1.5.jar;D:\repository\org\latencyutils\LatencyUtils\2.0.3\LatencyUtils-2.0.3.jar;D:\repository\org\jolokia\jolokia-core\1.6.1\jolokia-core-1.6.1.jar;D:\repository\com\googlecode\json-simple\json-simple\1.1.1\json-simple-1.1.1.jar;D:\repository\org\springframework\boot\spring-boot-starter-web\2.1.6.RELEASE\spring-boot-starter-web-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter\2.1.6.RELEASE\spring-boot-starter-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot\2.1.6.RELEASE\spring-boot-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter-logging\2.1.6.RELEASE\spring-boot-starter-logging-2.1.6.RELEASE.jar;D:\repository\ch\qos\logback\logback-classic\1.2.3\logback-classic-1.2.3.jar;D:\repository\ch\qos\logback\logback-core\1.2.3\logback-core-1.2.3.jar;D:\repository\org\apache\logging\log4j\log4j-to-slf4j\2.11.2\log4j-to-slf4j-2.11.2.jar;D:\repository\org\apache\logging\log4j\log4j-api\2.11.2\log4j-api-2.11.2.jar;D:\repository\org\slf4j\jul-to-slf4j\1.7.26\jul-to-slf4j-1.7.26.jar;D:\repository\javax\annotation\javax.annotation-api\1.3.2\javax.annotation-api-1.3.2.jar;D:\repository\org\yaml\snakeyaml\1.23\snakeyaml-1.23.jar;D:\repository\org\springframework\boot\spring-boot-starter-json\2.1.6.RELEASE\spring-boot-starter-json-2.1.6.RELEASE.jar;D:\repository\com\fasterxml\jackson\core\jackson-databind\2.9.9\jackson-databind-2.9.9.jar;D:\repository\com\fasterxml\jackson\core\jackson-annotations\2.9.0\jackson-annotations-2.9.0.jar;D:\repository\com\fasterxml\jackson\core\jackson-core\2.9.9\jackson-core-2.9.9.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.9.9\jackson-datatype-jdk8-2.9.9.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.9.9\jackson-datatype-jsr310-2.9.9.jar;D:\repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.9.9\jackson-module-parameter-names-2.9.9.jar;D:\repository\org\springframework\boot\spring-boot-starter-tomcat\2.1.6.RELEASE\spring-boot-starter-tomcat-2.1.6.RELEASE.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-core\9.0.21\tomcat-embed-core-9.0.21.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-el\9.0.21\tomcat-embed-el-9.0.21.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-websocket\9.0.21\tomcat-embed-websocket-9.0.21.jar;D:\repository\org\hibernate\validator\hibernate-validator\6.0.17.Final\hibernate-validator-6.0.17.Final.jar;D:\repository\javax\validation\validation-api\2.0.1.Final\validation-api-2.0.1.Final.jar;D:\repository\org\jboss\logging\jboss-logging\3.3.2.Final\jboss-logging-3.3.2.Final.jar;D:\repository\com\fasterxml\classmate\1.4.0\classmate-1.4.0.jar;D:\repository\org\springframework\spring-web\5.1.8.RELEASE\spring-web-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-beans\5.1.8.RELEASE\spring-beans-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-webmvc\5.1.8.RELEASE\spring-webmvc-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-aop\5.1.8.RELEASE\spring-aop-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-context\5.1.8.RELEASE\spring-context-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-expression\5.1.8.RELEASE\spring-expression-5.1.8.RELEASE.jar;D:\repository\org\slf4j\slf4j-api\1.7.26\slf4j-api-1.7.26.jar;D:\repository\org\springframework\spring-core\5.1.8.RELEASE\spring-core-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-jcl\5.1.8.RELEASE\spring-jcl-5.1.8.RELEASE.jar;D:\repository\org\glassfish\jaxb\jaxb-core\2.3.0.1\jaxb-core-2.3.0.1.jar;D:\repository\javax\xml\bind\jaxb-api\2.3.1\jaxb-api-2.3.1.jar;D:\repository\javax\activation\javax.activation-api\1.2.0\javax.activation-api-1.2.0.jar;D:\repository\org\glassfish\jaxb\txw2\2.3.1\txw2-2.3.1.jar;D:\repository\com\sun\istack\istack-commons-runtime\3.0.5\istack-commons-runtime-3.0.5.jar;D:\repository\com\sun\xml\bind\jaxb-impl\2.3.2\jaxb-impl-2.3.2.jar com.zsx.ConsulProviderApplication
2019-08-09 10:17:24.943  INFO [-,,,] 7352 --- [           main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration' of type [org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration$$EnhancerBySpringCGLIB$$74de456a] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.1.6.RELEASE)

2019-08-09 10:17:25.143  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] com.zsx.ConsulProviderApplication        : No active profile set, falling back to default profiles: default
2019-08-09 10:17:25.529  WARN [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.boot.actuate.endpoint.EndpointId     : Endpoint ID 'service-registry' contains invalid characters, please migrate to a valid format.
2019-08-09 10:17:25.670  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.cloud.context.scope.GenericScope     : BeanFactory id=b76eba98-17b8-37a5-b214-63ff752ae9b3
2019-08-09 10:17:25.799  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration' of type [org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration$$EnhancerBySpringCGLIB$$74de456a] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)
2019-08-09 10:17:25.990  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8094 (http)
2019-08-09 10:17:26.006  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2019-08-09 10:17:26.006  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.21]
2019-08-09 10:17:26.091  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2019-08-09 10:17:26.091  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 937 ms
2019-08-09 10:17:26.169  WARN [spring-cloud-consul-provider,,,] 7352 --- [           main] c.n.c.sources.URLConfigurationSource     : No URLs will be polled as dynamic configuration sources.
2019-08-09 10:17:26.169  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] c.n.c.sources.URLConfigurationSource     : To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
2019-08-09 10:17:26.173  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] c.netflix.config.DynamicPropertyFactory  : DynamicPropertyFactory is initialized with configuration sources: com.netflix.config.ConcurrentCompositeConfiguration@ddffa6c
2019-08-09 10:17:26.910  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.b.a.e.web.ServletEndpointRegistrar   : Registered '/actuator/jolokia' to jolokia-actuator-endpoint
2019-08-09 10:17:26.937  WARN [spring-cloud-consul-provider,,,] 7352 --- [           main] c.n.c.sources.URLConfigurationSource     : No URLs will be polled as dynamic configuration sources.
2019-08-09 10:17:26.937  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] c.n.c.sources.URLConfigurationSource     : To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
2019-08-09 10:17:27.120  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.s.concurrent.ThreadPoolTaskExecutor  : Initializing ExecutorService 'applicationTaskExecutor'
2019-08-09 10:17:27.321  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.s.c.ThreadPoolTaskScheduler          : Initializing ExecutorService
2019-08-09 10:17:27.411  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.s.c.ThreadPoolTaskScheduler          : Initializing ExecutorService 'catalogWatchTaskScheduler'
2019-08-09 10:17:27.712  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.b.a.e.web.EndpointLinksResolver      : Exposing 21 endpoint(s) beneath base path '/actuator'
2019-08-09 10:17:27.798  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8094 (http) with context path ''
2019-08-09 10:17:27.804  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] o.s.c.c.s.ConsulServiceRegistry          : Registering service with consul: NewService{id='spring-cloud-consul-provider-8094', name='spring-cloud-consul-provider', tags=[secure=false], address='172.20.202.43', meta=null, port=8094, enableTagOverride=null, check=Check{script='null', interval='10s', ttl='null', http='http://172.20.202.43:8094/actuator/health', method='null', header={}, tcp='null', timeout='null', deregisterCriticalServiceAfter='null', tlsSkipVerify=null, status='null'}, checks=null}
2019-08-09 10:17:27.811  INFO [spring-cloud-consul-provider,,,] 7352 --- [           main] com.zsx.ConsulProviderApplication        : Started ConsulProviderApplication in 3.406 seconds (JVM running for 3.852)
2019-08-09 10:17:28.330  INFO [spring-cloud-consul-provider,,,] 7352 --- [2)-192.168.56.1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2019-08-09 10:17:28.330  INFO [spring-cloud-consul-provider,,,] 7352 --- [2)-192.168.56.1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2019-08-09 10:17:28.344  INFO [spring-cloud-consul-provider,,,] 7352 --- [2)-192.168.56.1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 14 ms

6. 查看请求http://127.0.0.1:8500/ui/dc1/services

7. 查看请求http://localhost:8094/api/v1/provider/hello

到此服务提供者配置完成

三、配置consul服务消费者

1. 创建工程spring-cloud-consul-consumer,pom.xml文件内容

<?xml version="1.0" encoding="UTF-8"?>
<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>

    <groupId>com.zsx</groupId>
    <artifactId>spring-cloud-consul-consumer</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>spring-cloud-consul-consumer</name>
    <description>Spring Cloud Consul Consumer project</description>
    <properties>
        <spring-boot-admin-starter-client.version>2.1.6</spring-boot-admin-starter-client.version>
    </properties>
    <parent>
        <groupId>com.zsx</groupId>
        <artifactId>spring-cloud-customize-dependencies</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <relativePath>../spring-cloud-customize-dependencies/pom.xml</relativePath>
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-zipkin</artifactId>
        </dependency>
        <dependency>
            <groupId>de.codecentric</groupId>
            <artifactId>spring-boot-admin-starter-client</artifactId>
            <version>${spring-boot-admin-starter-client.version}</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.zsx.ConsulConsumerApplication</mainClass>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

2. application.yml文件内容

server:
  port: 8096
spring:
  application:
    name: spring-cloud-consul-consumer
  boot:
    admin:
      client:
        url: http://localhost:8092
  zipkin:
    base-url: http://localhost:8080
  cloud:
    consul:
      host: localhost
      port: 8500
# 打开断路器,否则仪表盘监测不到数据
feign:
  hystrix:
    enabled: true
management:
  endpoints:
    web:
      # actuator的前缀地址
      base-path: /
      exposure:
        include: '*'
  endpoint:
    health:
      show-details: always

3. api接口类

package com.zsx.api.controller;

import com.zsx.service.ConsumerTestService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("consul/consumer/")
public class ConsumerTestController {

    @Autowired
    private ConsumerTestService consumerTestService;

    @GetMapping("/{message}")
    public ResponseEntity get(@PathVariable("message") String message) {
        return new ResponseEntity(consumerTestService.get(message), HttpStatus.OK);
    }
}

4. 消费者调用服务提供者接口类

package com.zsx.service;

import com.zsx.hystrix.ConsumerTestHystrix;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;

@FeignClient(value = "spring-cloud-consul-provider", fallback = ConsumerTestHystrix.class)
public interface ConsumerTestService {

    @GetMapping(value = "/api/v1/provider/{message}")
    String get(@PathVariable("message") String message);
}

5. 熔断器实现类

package com.zsx.hystrix;

import com.zsx.service.ConsumerTestService;
import org.springframework.stereotype.Component;

@Component
public class ConsumerTestHystrix implements ConsumerTestService {

    @Override
    public String get(String message) {
        return "Failed to get message";
    }
}

6. 仪表盘servlet注册类

package com.zsx.config;

import com.netflix.hystrix.contrib.metrics.eventstream.HystrixMetricsStreamServlet;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class HystrixServletDefinitions {

    @Bean(name = "hystrixRegistrationBean")
    public ServletRegistrationBean servletRegistrationBean() {
        ServletRegistrationBean registration = new ServletRegistrationBean(
                new HystrixMetricsStreamServlet(), "/hystrix.stream");
        registration.setName("hystrixServlet");
        registration.setLoadOnStartup(1);
        return registration;
    }
}

7. 引导类

package com.zsx;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
import org.springframework.cloud.openfeign.EnableFeignClients;

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@EnableHystrixDashboard
public class ConsulConsumerApplication {

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

8. 依次运行consul注册中心,consul服务提供者(运行2个)、consul消费者主程序

C:\software\jdk-11.0.3\bin\java.exe -XX:TieredStopAtLevel=1 -noverify -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-javaagent:C:\software\JetBrains\IntelliJ IDEA 2019.1.3\lib\idea_rt.jar=5987:C:\software\JetBrains\IntelliJ IDEA 2019.1.3\bin" -Dfile.encoding=UTF-8 -classpath F:\IdeaProjects\spring-cloud\spring-cloud-consul-consumer\target\classes;D:\repository\org\springframework\cloud\spring-cloud-starter-openfeign\2.1.2.RELEASE\spring-cloud-starter-openfeign-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter\2.1.2.RELEASE\spring-cloud-starter-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-context\2.1.2.RELEASE\spring-cloud-context-2.1.2.RELEASE.jar;D:\repository\org\springframework\security\spring-security-rsa\1.0.7.RELEASE\spring-security-rsa-1.0.7.RELEASE.jar;D:\repository\org\bouncycastle\bcpkix-jdk15on\1.60\bcpkix-jdk15on-1.60.jar;D:\repository\org\bouncycastle\bcprov-jdk15on\1.60\bcprov-jdk15on-1.60.jar;D:\repository\org\springframework\cloud\spring-cloud-openfeign-core\2.1.2.RELEASE\spring-cloud-openfeign-core-2.1.2.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-autoconfigure\2.1.6.RELEASE\spring-boot-autoconfigure-2.1.6.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-ribbon\2.1.2.RELEASE\spring-cloud-netflix-ribbon-2.1.2.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter-aop\2.1.6.RELEASE\spring-boot-starter-aop-2.1.6.RELEASE.jar;D:\repository\org\aspectj\aspectjweaver\1.9.4\aspectjweaver-1.9.4.jar;D:\repository\io\github\openfeign\form\feign-form-spring\3.8.0\feign-form-spring-3.8.0.jar;D:\repository\io\github\openfeign\form\feign-form\3.8.0\feign-form-3.8.0.jar;D:\repository\commons-fileupload\commons-fileupload\1.4\commons-fileupload-1.4.jar;D:\repository\commons-io\commons-io\2.2\commons-io-2.2.jar;D:\repository\org\springframework\spring-web\5.1.8.RELEASE\spring-web-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-beans\5.1.8.RELEASE\spring-beans-5.1.8.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-commons\2.1.2.RELEASE\spring-cloud-commons-2.1.2.RELEASE.jar;D:\repository\org\springframework\security\spring-security-crypto\5.1.5.RELEASE\spring-security-crypto-5.1.5.RELEASE.jar;D:\repository\io\github\openfeign\feign-core\10.2.3\feign-core-10.2.3.jar;D:\repository\io\github\openfeign\feign-slf4j\10.2.3\feign-slf4j-10.2.3.jar;D:\repository\org\slf4j\slf4j-api\1.7.26\slf4j-api-1.7.26.jar;D:\repository\io\github\openfeign\feign-hystrix\10.2.3\feign-hystrix-10.2.3.jar;D:\repository\com\netflix\archaius\archaius-core\0.7.6\archaius-core-0.7.6.jar;D:\repository\com\google\code\findbugs\jsr305\3.0.1\jsr305-3.0.1.jar;D:\repository\com\google\guava\guava\16.0\guava-16.0.jar;D:\repository\com\fasterxml\jackson\core\jackson-annotations\2.9.0\jackson-annotations-2.9.0.jar;D:\repository\com\fasterxml\jackson\core\jackson-core\2.9.9\jackson-core-2.9.9.jar;D:\repository\com\netflix\hystrix\hystrix-core\1.5.18\hystrix-core-1.5.18.jar;D:\repository\org\hdrhistogram\HdrHistogram\2.1.9\HdrHistogram-2.1.9.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-netflix-hystrix-dashboard\2.1.2.RELEASE\spring-cloud-starter-netflix-hystrix-dashboard-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-hystrix-dashboard\2.1.2.RELEASE\spring-cloud-netflix-hystrix-dashboard-2.1.2.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter-freemarker\2.1.6.RELEASE\spring-boot-starter-freemarker-2.1.6.RELEASE.jar;D:\repository\org\freemarker\freemarker\2.3.28\freemarker-2.3.28.jar;D:\repository\org\springframework\spring-context-support\5.1.8.RELEASE\spring-context-support-5.1.8.RELEASE.jar;D:\repository\org\apache\httpcomponents\httpclient\4.5.9\httpclient-4.5.9.jar;D:\repository\commons-codec\commons-codec\1.11\commons-codec-1.11.jar;D:\repository\com\netflix\hystrix\hystrix-metrics-event-stream\1.5.18\hystrix-metrics-event-stream-1.5.18.jar;D:\repository\com\netflix\hystrix\hystrix-serialization\1.5.18\hystrix-serialization-1.5.18.jar;D:\repository\com\fasterxml\jackson\module\jackson-module-afterburner\2.9.9\jackson-module-afterburner-2.9.9.jar;D:\repository\org\webjars\jquery\2.1.1\jquery-2.1.1.jar;D:\repository\org\webjars\d3js\3.4.11\d3js-3.4.11.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-netflix-archaius\2.1.2.RELEASE\spring-cloud-starter-netflix-archaius-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-archaius\2.1.2.RELEASE\spring-cloud-netflix-archaius-2.1.2.RELEASE.jar;D:\repository\commons-configuration\commons-configuration\1.8\commons-configuration-1.8.jar;D:\repository\commons-lang\commons-lang\2.6\commons-lang-2.6.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-consul-discovery\2.1.2.RELEASE\spring-cloud-starter-consul-discovery-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-consul\2.1.2.RELEASE\spring-cloud-starter-consul-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-consul-core\2.1.2.RELEASE\spring-cloud-consul-core-2.1.2.RELEASE.jar;D:\repository\com\ecwid\consul\consul-api\1.4.1\consul-api-1.4.1.jar;D:\repository\com\google\code\gson\gson\2.8.5\gson-2.8.5.jar;D:\repository\org\apache\httpcomponents\httpcore\4.4.11\httpcore-4.4.11.jar;D:\repository\org\springframework\cloud\spring-cloud-consul-discovery\2.1.2.RELEASE\spring-cloud-consul-discovery-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-netflix-hystrix\2.1.2.RELEASE\spring-cloud-netflix-hystrix-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-netflix-ribbon\2.1.2.RELEASE\spring-cloud-starter-netflix-ribbon-2.1.2.RELEASE.jar;D:\repository\com\netflix\ribbon\ribbon\2.3.0\ribbon-2.3.0.jar;D:\repository\com\netflix\ribbon\ribbon-transport\2.3.0\ribbon-transport-2.3.0.jar;D:\repository\io\reactivex\rxnetty-contexts\0.4.9\rxnetty-contexts-0.4.9.jar;D:\repository\io\reactivex\rxnetty-servo\0.4.9\rxnetty-servo-0.4.9.jar;D:\repository\javax\inject\javax.inject\1\javax.inject-1.jar;D:\repository\io\reactivex\rxnetty\0.4.9\rxnetty-0.4.9.jar;D:\repository\com\netflix\ribbon\ribbon-core\2.3.0\ribbon-core-2.3.0.jar;D:\repository\com\netflix\ribbon\ribbon-httpclient\2.3.0\ribbon-httpclient-2.3.0.jar;D:\repository\commons-collections\commons-collections\3.2.2\commons-collections-3.2.2.jar;D:\repository\com\sun\jersey\jersey-client\1.19.1\jersey-client-1.19.1.jar;D:\repository\com\sun\jersey\jersey-core\1.19.1\jersey-core-1.19.1.jar;D:\repository\javax\ws\rs\jsr311-api\1.1.1\jsr311-api-1.1.1.jar;D:\repository\com\sun\jersey\contribs\jersey-apache-client4\1.19.1\jersey-apache-client4-1.19.1.jar;D:\repository\com\netflix\servo\servo-core\0.12.21\servo-core-0.12.21.jar;D:\repository\com\netflix\netflix-commons\netflix-commons-util\0.3.0\netflix-commons-util-0.3.0.jar;D:\repository\com\netflix\ribbon\ribbon-loadbalancer\2.3.0\ribbon-loadbalancer-2.3.0.jar;D:\repository\com\netflix\netflix-commons\netflix-statistics\0.1.1\netflix-statistics-0.1.1.jar;D:\repository\io\reactivex\rxjava\1.3.8\rxjava-1.3.8.jar;D:\repository\joda-time\joda-time\2.10.2\joda-time-2.10.2.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-zipkin\2.1.2.RELEASE\spring-cloud-starter-zipkin-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-starter-sleuth\2.1.2.RELEASE\spring-cloud-starter-sleuth-2.1.2.RELEASE.jar;D:\repository\org\springframework\cloud\spring-cloud-sleuth-core\2.1.2.RELEASE\spring-cloud-sleuth-core-2.1.2.RELEASE.jar;D:\repository\org\aspectj\aspectjrt\1.9.4\aspectjrt-1.9.4.jar;D:\repository\io\zipkin\brave\brave\5.6.5\brave-5.6.5.jar;D:\repository\io\zipkin\brave\brave-context-log4j2\5.6.5\brave-context-log4j2-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-spring-web\5.6.5\brave-instrumentation-spring-web-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-http\5.6.5\brave-instrumentation-http-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-spring-rabbit\5.6.5\brave-instrumentation-spring-rabbit-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-kafka-clients\5.6.5\brave-instrumentation-kafka-clients-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-httpclient\5.6.5\brave-instrumentation-httpclient-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-httpasyncclient\5.6.5\brave-instrumentation-httpasyncclient-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-spring-webmvc\5.6.5\brave-instrumentation-spring-webmvc-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-servlet\5.6.5\brave-instrumentation-servlet-5.6.5.jar;D:\repository\io\zipkin\brave\brave-instrumentation-jms\5.6.5\brave-instrumentation-jms-5.6.5.jar;D:\repository\org\springframework\cloud\spring-cloud-sleuth-zipkin\2.1.2.RELEASE\spring-cloud-sleuth-zipkin-2.1.2.RELEASE.jar;D:\repository\io\zipkin\zipkin2\zipkin\2.14.2\zipkin-2.14.2.jar;D:\repository\io\zipkin\reporter2\zipkin-reporter\2.8.4\zipkin-reporter-2.8.4.jar;D:\repository\io\zipkin\reporter2\zipkin-sender-kafka\2.8.4\zipkin-sender-kafka-2.8.4.jar;D:\repository\io\zipkin\reporter2\zipkin-sender-amqp-client\2.8.4\zipkin-sender-amqp-client-2.8.4.jar;D:\repository\de\codecentric\spring-boot-admin-starter-client\2.1.6\spring-boot-admin-starter-client-2.1.6.jar;D:\repository\de\codecentric\spring-boot-admin-client\2.1.6\spring-boot-admin-client-2.1.6.jar;D:\repository\org\springframework\boot\spring-boot-starter-actuator\2.1.6.RELEASE\spring-boot-starter-actuator-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-actuator-autoconfigure\2.1.6.RELEASE\spring-boot-actuator-autoconfigure-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-actuator\2.1.6.RELEASE\spring-boot-actuator-2.1.6.RELEASE.jar;D:\repository\io\micrometer\micrometer-core\1.1.5\micrometer-core-1.1.5.jar;D:\repository\org\latencyutils\LatencyUtils\2.0.3\LatencyUtils-2.0.3.jar;D:\repository\org\jolokia\jolokia-core\1.6.1\jolokia-core-1.6.1.jar;D:\repository\com\googlecode\json-simple\json-simple\1.1.1\json-simple-1.1.1.jar;D:\repository\org\springframework\boot\spring-boot-starter-web\2.1.6.RELEASE\spring-boot-starter-web-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter\2.1.6.RELEASE\spring-boot-starter-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot\2.1.6.RELEASE\spring-boot-2.1.6.RELEASE.jar;D:\repository\org\springframework\boot\spring-boot-starter-logging\2.1.6.RELEASE\spring-boot-starter-logging-2.1.6.RELEASE.jar;D:\repository\ch\qos\logback\logback-classic\1.2.3\logback-classic-1.2.3.jar;D:\repository\ch\qos\logback\logback-core\1.2.3\logback-core-1.2.3.jar;D:\repository\org\apache\logging\log4j\log4j-to-slf4j\2.11.2\log4j-to-slf4j-2.11.2.jar;D:\repository\org\apache\logging\log4j\log4j-api\2.11.2\log4j-api-2.11.2.jar;D:\repository\org\slf4j\jul-to-slf4j\1.7.26\jul-to-slf4j-1.7.26.jar;D:\repository\javax\annotation\javax.annotation-api\1.3.2\javax.annotation-api-1.3.2.jar;D:\repository\org\yaml\snakeyaml\1.23\snakeyaml-1.23.jar;D:\repository\org\springframework\boot\spring-boot-starter-json\2.1.6.RELEASE\spring-boot-starter-json-2.1.6.RELEASE.jar;D:\repository\com\fasterxml\jackson\core\jackson-databind\2.9.9\jackson-databind-2.9.9.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.9.9\jackson-datatype-jdk8-2.9.9.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.9.9\jackson-datatype-jsr310-2.9.9.jar;D:\repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.9.9\jackson-module-parameter-names-2.9.9.jar;D:\repository\org\springframework\boot\spring-boot-starter-tomcat\2.1.6.RELEASE\spring-boot-starter-tomcat-2.1.6.RELEASE.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-core\9.0.21\tomcat-embed-core-9.0.21.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-el\9.0.21\tomcat-embed-el-9.0.21.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-websocket\9.0.21\tomcat-embed-websocket-9.0.21.jar;D:\repository\org\hibernate\validator\hibernate-validator\6.0.17.Final\hibernate-validator-6.0.17.Final.jar;D:\repository\javax\validation\validation-api\2.0.1.Final\validation-api-2.0.1.Final.jar;D:\repository\org\jboss\logging\jboss-logging\3.3.2.Final\jboss-logging-3.3.2.Final.jar;D:\repository\com\fasterxml\classmate\1.4.0\classmate-1.4.0.jar;D:\repository\org\springframework\spring-webmvc\5.1.8.RELEASE\spring-webmvc-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-aop\5.1.8.RELEASE\spring-aop-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-context\5.1.8.RELEASE\spring-context-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-expression\5.1.8.RELEASE\spring-expression-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-core\5.1.8.RELEASE\spring-core-5.1.8.RELEASE.jar;D:\repository\org\springframework\spring-jcl\5.1.8.RELEASE\spring-jcl-5.1.8.RELEASE.jar;D:\repository\org\glassfish\jaxb\jaxb-core\2.3.0.1\jaxb-core-2.3.0.1.jar;D:\repository\javax\xml\bind\jaxb-api\2.3.1\jaxb-api-2.3.1.jar;D:\repository\javax\activation\javax.activation-api\1.2.0\javax.activation-api-1.2.0.jar;D:\repository\org\glassfish\jaxb\txw2\2.3.1\txw2-2.3.1.jar;D:\repository\com\sun\istack\istack-commons-runtime\3.0.5\istack-commons-runtime-3.0.5.jar;D:\repository\com\sun\xml\bind\jaxb-impl\2.3.2\jaxb-impl-2.3.2.jar com.zsx.ConsulConsumerApplication
2019-08-09 11:40:30.884  INFO [-,,,] 10128 --- [           main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration' of type [org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration$$EnhancerBySpringCGLIB$$7577e53] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.1.6.RELEASE)

2019-08-09 11:40:31.074  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] com.zsx.ConsulConsumerApplication        : No active profile set, falling back to default profiles: default
2019-08-09 11:40:31.485  WARN [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.boot.actuate.endpoint.EndpointId     : Endpoint ID 'service-registry' contains invalid characters, please migrate to a valid format.
2019-08-09 11:40:31.669  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.cloud.context.scope.GenericScope     : BeanFactory id=d78085fc-748d-32cc-9766-9fbbd5a7821d
2019-08-09 11:40:31.779  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration' of type [org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration$$EnhancerBySpringCGLIB$$7577e53] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)
2019-08-09 11:40:31.968  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8096 (http)
2019-08-09 11:40:31.982  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2019-08-09 11:40:31.982  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.21]
2019-08-09 11:40:32.057  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2019-08-09 11:40:32.057  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 970 ms
2019-08-09 11:40:32.064  WARN [spring-cloud-consul-consumer,,,] 10128 --- [           main] c.n.c.sources.URLConfigurationSource     : No URLs will be polled as dynamic configuration sources.
2019-08-09 11:40:32.064  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] c.n.c.sources.URLConfigurationSource     : To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
2019-08-09 11:40:32.066  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] c.netflix.config.DynamicPropertyFactory  : DynamicPropertyFactory is initialized with configuration sources: com.netflix.config.ConcurrentCompositeConfiguration@3f0ce0d1
2019-08-09 11:40:33.099  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.b.a.e.web.ServletEndpointRegistrar   : Registered '/actuator/jolokia' to jolokia-actuator-endpoint
2019-08-09 11:40:33.274  WARN [spring-cloud-consul-consumer,,,] 10128 --- [           main] c.n.c.sources.URLConfigurationSource     : No URLs will be polled as dynamic configuration sources.
2019-08-09 11:40:33.274  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] c.n.c.sources.URLConfigurationSource     : To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
2019-08-09 11:40:33.468  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.s.concurrent.ThreadPoolTaskExecutor  : Initializing ExecutorService 'applicationTaskExecutor'
2019-08-09 11:40:33.681  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.s.c.ThreadPoolTaskScheduler          : Initializing ExecutorService
2019-08-09 11:40:33.751  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.s.c.ThreadPoolTaskScheduler          : Initializing ExecutorService 'catalogWatchTaskScheduler'
2019-08-09 11:40:33.991  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.b.a.e.web.EndpointLinksResolver      : Exposing 21 endpoint(s) beneath base path '/actuator'
2019-08-09 11:40:34.077  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8096 (http) with context path ''
2019-08-09 11:40:34.083  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] o.s.c.c.s.ConsulServiceRegistry          : Registering service with consul: NewService{id='spring-cloud-consul-consumer-8096', name='spring-cloud-consul-consumer', tags=[secure=false], address='172.20.202.43', meta=null, port=8096, enableTagOverride=null, check=Check{script='null', interval='10s', ttl='null', http='http://172.20.202.43:8096/actuator/health', method='null', header={}, tcp='null', timeout='null', deregisterCriticalServiceAfter='null', tlsSkipVerify=null, status='null'}, checks=null}
2019-08-09 11:40:34.092  INFO [spring-cloud-consul-consumer,,,] 10128 --- [           main] com.zsx.ConsulConsumerApplication        : Started ConsulConsumerApplication in 3.729 seconds (JVM running for 4.169)
2019-08-09 11:40:34.321  INFO [spring-cloud-consul-consumer,,,] 10128 --- [3)-192.168.56.1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2019-08-09 11:40:34.322  INFO [spring-cloud-consul-consumer,,,] 10128 --- [3)-192.168.56.1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2019-08-09 11:40:34.337  INFO [spring-cloud-consul-consumer,,,] 10128 --- [3)-192.168.56.1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 15 ms

 9. 查看注册中心http://127.0.0.1:8500/ui/dc1/services

10. 查看服务提供者

11. 查看仪表盘http://localhost:8096/hystrix

12. 查看请求(多次刷新)http://localhost:8096/consul/consumer/hello

从以上结果可以看出实现了客户端负载均衡,到此配置结束 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值