sringcloud2.0学习-8-SpringCloud整合Consul作注册中心

SpringCloud整合Consul作注册中心

1.Consul简介

Consul 是一套开源的分布式服务发现和配置管理系统,由 HashiCorp 公司用 Go 语言开发。
它具有很多优点。包括: 基于 raft 协议,比较简洁; 支持健康检查, 同时支持 HTTP 和 DNS 协议 支持跨数据中心的 WAN 集群 提供图形界面 跨平台,支持 Linux、Mac、Windows,这里以windows版本的consul来演示

2.启动consul

如图,使用cmd进入该目录:
sringcloud2.0学习-8-SpringCloud整合Consul作注册中心_第1张图片
输入启动命令:consul agent -dev -ui -node=cy
-dev 开发服务器模式启动
-ui 可以用界面访问,默认能访问
-node 节点名
sringcloud2.0学习-8-SpringCloud整合Consul作注册中心_第2张图片
启动之后访问http://localhost:8500可以看到consul界面
sringcloud2.0学习-8-SpringCloud整合Consul作注册中心_第3张图片

创建服务

  • SpringBoot整合consul客户端
<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.0modelVersion>
  <groupId>com.lchtestgroupId>
  <artifactId>springcloud2.0-consul-memberartifactId>
  <version>0.0.1-SNAPSHOTversion>
  
   
  <parent>
		<groupId>org.springframework.bootgroupId>
		<artifactId>spring-boot-starter-parentartifactId>
		<version>2.0.3.RELEASEversion>  
	parent>
	
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloudgroupId>
				<artifactId>spring-cloud-dependenciesartifactId>
				<version>Finchley.RELEASEversion>
				<type>pomtype>
				<scope>importscope>
			dependency>
		dependencies>
	dependencyManagement>
	<dependencies>
		
		<dependency>
			<groupId>org.springframework.bootgroupId>
			<artifactId>spring-boot-starter-webartifactId>
		dependency>
		
		<dependency>
			<groupId>org.springframework.cloudgroupId>
			<artifactId>spring-cloud-starter-consul-discoveryartifactId>
		dependency>

	dependencies>
project>
  • 注册中心配置如下
    spring.cloud.consul.host 注册中心地址
    spring.cloud.consul.port 注册中心端口
    spring.cloud.consul.discovery.hostname 默认情况下服务注册到注册中心上的的address是随机生成的,修改hostname为本机ip
# 服务端口号
server:
  port: 8501
#服务别名
spring:
  application:
    name: consul-member
  # consul注册中心地址
  cloud:
    consul:
      host: localhost
      #consul端口号
      port: 8500
      discovery:
      #默认情况下服务注册到注册中心上的的address是随机生成的,修改hostname为本机ip
        hostname: 192.168.5.102
  • 启动类
    consul使用@EnableDiscoveryClient将服务注册到注册中心
package com.lchtest.springcloud;

import org.springframework.beans.factory.annotation.Value;
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;
/**
 * springcloud consul注册中心
 * @author pc
 *
 */
@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class ConsulMemberController {
	
	@Value("${server.port}")
	private String port;

	@RequestMapping("/getmember")
	public String getmember() {
		return "this is member service.port=" + port;
	}
	
	public static void main(String[] args) {
		SpringApplication.run(ConsulMemberController.class, args);
	}
}

启动服务,请求接口:
在这里插入图片描述
查看注册中心:
sringcloud2.0学习-8-SpringCloud整合Consul作注册中心_第4张图片

总结

不论注册中心是Eureka,还是consul,或者是Zookeeper, 客户端对接口的调用方式都不变,不同的只是配置文件和注册中心客户端的maven依赖信息

代码地址
springcloud2.0-consul-member

你可能感兴趣的:(SpringCloud2.0)