SpringCloud开发之路——服务注册与发现之Consul

2019-10-13  本文已影响0人  我是顾子晨

由于eureka官方已经正式宣布:自2.0起不再维护该项目。https://github.com/Netflix/eureka
所以这里使用Consul 代码Eureka

Consule安装-单机部署:

1.摘取镜像及安装

# 检索镜像
docker search consul
docker pull consule
# 查看镜像
docker images
# 安装
docker run --name consul -p 8500:8500 -v $PWD/data/:/consul/data/ -v$PWD/config:/consul/config -d consul

Consule安装-集群部署:

mkdir /data/docker/consul
touch docker-compose.yml
vim docker-compose.yml

加入如下内容:

version: '3.6'
services:
  consul1:
    image: consul:1.3.0
    container_name: consul1
    restart: always
    network_mode: mynet
    command: agent -server -client=0.0.0.0 -bootstrap-expect=3 -node=consul1 
  consul2:
    image: consul:1.3.0
    container_name: consul2
    network_mode: mynet
    restart: always
    command: agent -server -client=0.0.0.0 -retry-join=consul1 -node=consul2
  consul3:
    image: consul:1.3.0
    container_name: consul3
    network_mode: mynet
    restart: always
    command: agent -server -client=0.0.0.0 -retry-join=consul1 -node=consul3
  consul4:
    image: consul:1.3.0
    container_name: consul4
    network_mode: mynet
    restart: always
    ports:
      - 8500:8500
    command: agent -client=0.0.0.0 -retry-join=consul1 -ui -node=client1

启动:

docker-compose up -d

创建maven工程

结构如下
spring-cloud-consul-parent
----provider
----consumer


image.png

parent pom.xml

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Finchley.SR1</spring-cloud.version>
    </properties>
    
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

provider相关配置

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
        </dependency>
        <!--服务发现依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
        </dependency>
        <!--用于consul配置-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-config</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.6</version>
        </dependency>
    </dependencies>
server:
  port: 9201
spring:
  application:
    name: springtest-service
  cloud:
    consul:
      host: 192.168.199.214
      port: 8500
      discovery:
        register: true
        hostname: 192.168.199.140
        serviceName: ${spring.application.name}
        port: ${server.port}
        healthCheckPath: /home
        healthCheckInterval: 15s
        tags: urlprefix-/${spring.application.name}
        instanceId: ${spring.application.name}
@EnableDiscoveryClient
@RestController
@SpringBootApplication
public class SpringtestServiceApplication {

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

    @GetMapping("/home")
    public String home() {
        return "Hello World";
    }

    @GetMapping("/test")
    public String test(@RequestParam(value = "id") Integer id) {
        return "test" + id;
    }
}

consumer 相关配置

    <dependencies>
      <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</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-start</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <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</artifactId>
        </dependency>
    </dependencies>
server:
  port: 9202

spring:
  application:
    name: springtest-client
  cloud:
    consul:
      host: 192.168.199.214
      port: 8500
      discovery:
        register: false
@FeignClient(name = "springtest-service", fallback = HystrixFeignFallback.class)
public interface MyFeignClient {

    @GetMapping("/home")
    String home();

    @GetMapping("/test")
    String test(@RequestParam("id") Integer id);
}
public class HystrixFeignFallback implements MyFeignClient {
    @Override
    public String home() {
        return "home failure";
    }

    @Override
    public String test(Integer id) {
        return "test failure "+id;
    }
}

@EnableDiscoveryClient
@RestController
@SpringBootApplication
@EnableFeignClients
public class SpringtestClientApplication {

    @Autowired
    private MyFeignClient myFeignClient;

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

    /**
     * 调用test
     *
     * @param id
     * @return
     */
    @GetMapping("/test")
    public String test(@RequestParam Integer id) {
        return myFeignClient.test(id);
    }

    /**
     * 调用home
     *
     * @return
     */
    @GetMapping("/home")
    public String home() {
        return myFeignClient.home();
    }
}
上一篇 下一篇

猜你喜欢

热点阅读