微服务分布式(二、注册中心Consul)

首先我们需要安装consul,到官网下载Consul

Install | Consul | HashiCorp Developer

在解压的consul目录下 执行启动命令

consul agent -dev 启动服务

-dev表示开发模式 -server表示服务模式

启动后在浏览器访问8500端口
http://localhost:8500/可以看到服务管理界面

项目要注册到中心需要做一些改动

一、添加pom依赖

添加cloud依赖

复制代码
<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>

添加consul依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>

二、添加yml文件中的consul配置

复制代码
spring:
  application:
    name: test-demo  #注册到注册中心名称
  cloud:
    consul:
      host: localhost #注册中心服务ip
      port: 8500
      discovery:
        heartbeat:
          enabled: true
        service-name: ${spring.application.name}
        prefer-ip-address: true

三、启动类添加注解

复制代码
@EnableDiscoveryClient  应用可以自动注册到服务注册中心。
java 复制代码
@EnableDiscoveryClient
@SpringBootApplication
public class Mis001Application {

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

}

到这里我们就配置好了项目的注册,启动后该服务会自动注册到注册中心

启动项目后我们在注册中心可以看到注册的服务,可以看到我们注册的服务

通过

复制代码
LoadBalancerClient和DiscoveryClient 可以读取注册中心服务的信息

操作Consul的K/v存储

我们先在Consul中新建一个文件

写完之后点击下面的保存

下面我们修改我们的项目

1.首先我们在pom文件中添加依赖

XML 复制代码
		<!--consul 添加K/V存储-->
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-consul-config</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-bootstrap</artifactId>
		</dependency>

2.在配置文件中添加consul中的config配置信息

java 复制代码
spring:
  application:
    name: test-demo  #注册到注册中心名称
  cloud:
    consul:
      host: localhost #注册中心服务ip
      port: 8500
      discovery:
        heartbeat:
          enabled: true
        service-name: ${spring.application.name}
        prefer-ip-address: true
      config:
        profile-separator: ',' #默认的分隔符为  ","  我们自定义为"-"
        format: yaml  #文件格式为yml
        fail-fast: true
        prefix: config  #基础文件夹名称
        default-context: application
        data-key: data

新建Myconfig类

java 复制代码
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.stereotype.Component;

/**
 * 获取consult config 的key/vlue
 */
@RefreshScope
@ConfigurationProperties(prefix = "jdbc")
public class MyConfig {
    private String username;
    private String password;
    private My my;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public My getMy() {
        return my;
    }

    public void setMy(My my) {
        this.my = my;
    }
}
复制代码
My 类
java 复制代码
public class My {
    private String year;

    public String getYear() {
        return year;
    }

    public void setYear(String year) {
        this.year = year;
    }
}

新建ConfigController

java 复制代码
@RestController
public class ConfigController {
    @Autowired
    private MyConfig myConfig;
    @RequestMapping("/getMyConfig")
    public String getMyConfig(){
        return myConfig.toString();
    }
    @RequestMapping("/getUsername")
    public String getUsername(){
        return myConfig.getUsername();
    }
    @RequestMapping("/getYear")
    public String getYear(){
        return myConfig.getMy().getYear();
    }
}

启动类添加注解 使 @ConfigurationProperties 注解的类生效。

复制代码
@EnableConfigurationProperties({MyConfig.class})

到此我们完成配置,可以启动项目访问我们controller中的方法获取到我们在Consul的配置文件里的值

但是这里有一个问题,开始我配置的内容写到了application-uat配置文件中,启动后获取不到方法,然后我把内容写到bootstrap.yml中就可以访问到了

bootstrap.yml

java 复制代码
#bootstrap.yml是系统级的,优先级更加高
spring:
  application:
    name: test-demo
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        service-name: ${spring.application.name}
        prefer-ip-address: true
      config:
        profile-separator: ',' #默认的分隔符为  ","  我们自定义为"-"
        format: yaml  #文件格式为yml
        fail-fast: true
        prefix: config  #基础文件夹名称
        default-context: application
        data-key: data
相关推荐
小熊美家熊猫系统2 小时前
电子合同技术实现与合规实践
java·开发语言·分布式
阿狸猿3 小时前
论微服务架构及其应用
java·微服务·架构
兮山与4 小时前
SpringCloud1.0
微服务
AI 小老六4 小时前
Google AX 控制面拆解:分布式 Agent 如何把断点恢复、审计策略和执行调度收进同一条链路
人工智能·分布式·后端·ai·架构·ai编程
functionflux5 小时前
kafka-python:Python 生态中最成熟的 Kafka 客户端
分布式·python·其他·kafka
kyle~9 小时前
DDS分布式实时系统---自省机制
开发语言·分布式·机器人·c#·接口·ros2
q21030633729 小时前
kafka启动几秒后挂了,重启多次无果
分布式·kafka
凯源智能10 小时前
工商业分布式光伏箱变智能监控落地实战
分布式·箱变测控·光伏箱变测控装置·箱变监控系统·箱式变测控装置
沂水弦音10 小时前
软控 EI 系列模块优势与竞品对比分析:面向 EtherCAT 分布式 I/O 的工程选型视角
分布式·制造·工业自动化·ethercat·io模块
NG47711 小时前
【微服务学习笔记】stream与zipkin的操作和使用
微服务·stream·zipkin