1. 什么是consul
HashiCorp Consul是一款服务网络解决方案,可让团队管理服务之间以及内部部署和多云环境及运行时的安全网络连接。consul提供服务发现、服务治理、流量管理和对网络基础设施设备的自动更新。(添加链接描述)Consul使用Go语言开发
2. 功能
- 多数据中心
- 服务网格
- API网关
- 健康监测
- 服务发现
- 动态应用配置
添加链接描述
3. 下载
官网下载添加链接描述
4. 安装
解压后
编辑~/.bash_profile
#consul
export PATH=$PATH:/Users/hong/consul/
source ~/.bash_profile
consul --version
5. 运行
以开发模式运行
consul agent -dev
端口号8500
浏览器输入添加链接描述即可访问
6.整合
6.1. payment8001项目整合consul
6.1.1. 添加依赖
<!--SpringCloud consul discovery -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
6.1.2. 修改yml
####Spring Cloud Consul for Service Discovery
cloud:
consul:
host: localhost
port: 8500
discovery:
service-name: ${spring.application.name}
6.1.3. 主启动添加注解EnableDiscoveryClient
package com.hong;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import tk.mybatis.spring.annotation.MapperScan;
/**
* @author hong
* @date 2020/1/14
* @description 支付模块v1启动类
*/
@SpringBootApplication
@MapperScan("com.hong.mapper")
@EnableDiscoveryClient
public class Main8001 {
public static void main(String[] args) {
SpringApplication.run(Main8001.class,args);
}
}
启动payment8001,控制台日志有警告,若想屏蔽在consul依赖中移除commons-logging即可
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
<exclusions>
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
6.2. order80项目整合consul
6.2.1. 添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
<exclusions>
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
6.2.2. 修改yml
server:
port: 80
spring:
application:
name: cloud-consumer-order
####Spring Cloud Consul for Service Discovery
cloud:
consul:
host: localhost
port: 8500
discovery:
service-name: ${spring.application.name}
6.2.3. 主启动添加注解EnableDiscoveryClient
package com.hong;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class Main80{
public static void main(String[] args)
{
SpringApplication.run(Main80.class,args);
}
}
修改原先硬编码
//先写死,硬编码
// public static final String PaymentSrv_URL = "http://localhost:8001";
//服务注册中心上的微服务名称
public static final String PaymentSrv_URL = "http://cloud-payment-service";
7. 测试
测试地址添加链接描述
consul默认使用负载均衡,修改RestTemplateConfig配置类
package com.hong.config;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;
/**
* @Description: RestTemplate配置类
* @Author: hong
* @Date: 2024-04-14 06:57
* @Version: 1.0
**/
@Configuration
public class RestTemplateConfig {
/**
* 使用@LoadBalanced注解赋予RestTemplate负载均衡的能力
* @return
*/
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
重启order80再次测试