springCloud-Consul史上最详细搭建步骤

本文介绍springCloud-consul搭建步骤

下载consul文件
consul下载地址,下载出来是一个二进制文件,我们只需要启动这个文件就好。
启动consul有三种方式:
1.以客户端启动
2.以服务端启动
3.以开发模式启动
    这三种启动方式区别在于,如果以开发模式启动,我们在consul上配置的一切配置在consul重启之后将丢失,以客户端启动的话,需要指定服务端,我们访问客户端,客户端会将我们的请求转载到服务端,服务端我们配置成集群,这样就可以满足高可用与分布式。以服务端启动是为了配置集群
启动命令
1.开发模式

consul agent -dev
pause

2.服务端模式

consul agent -server -ui -data-dir=/data/consul -node=agent-1 -client=0.0.0.0 -bind=192.168.0.70 -join 192.168.1.136   
pause

3.客户端模式

consul agent  -ui -data-dir=/data/consul -node=agent-5 -client=0.0.0.0 -bind=192.168.0.70 -join 192.168.1.136   
pause

参数说明:

  • server: 以server身份启动。默认是client
  • bootstrap-expect:集群要求的最少server数量,当低于这个数量,集群即失效。
  • data-dir:数据存放的目录
  • node:节点id,集群中的每个node必须有一个唯一的名称。默认情况下,Consul使用机器的hostname
  • bind:监听的ip地址。默认绑定0.0.0.0,可以不指定。表示Consul监听的地址,而且它必须能够被集群中的其他节点访问。Consul默认会监听第一个private
  • IP,但最好还是提供一个。生产设备上的服务器通常有好几个网卡,所以指定一个不会出错 client:
  • 客户端的ip地址,0.0.0.0是指谁都可以访问(不加这个,下面的ui :8500无法访问)
  • -ui: 可以访问UI界面
  • -config-dir指定配置文件夹,Consul会加载其中的所有文件
  • -datacenter 指定数据中心名称,默认是dc1

本次演示我们以开发模式启动:
在consul.exe二进制文件目录输入启动命令。springCloud-Consul史上最详细搭建步骤_第1张图片出现以上界面代表启动成功
注册服务
首先配置pom.xml文件,如下
Springcloud与springboot版本对应: https://start.spring.io/actuator/info

<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>springCloud-consul</groupId>
  <artifactId>springCloud-consul</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.3.0.RELEASE</version>
		<relativePath /> 
	</parent>
	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<spring-cloud.version>Hoxton.SR6</spring-cloud.version>
	</properties>
	
	<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <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>
       
    
    </dependencies>
	
	<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>
	
  <repositories>
		<repository>
			<id>spring-milestones</id>
			<name>Spring Milestones</name>
			<url>https://repo.spring.io/milestone</url>
		</repository>
	</repositories>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
				<configuration>
					<fork>true</fork>
				</configuration>
			</plugin>
		</plugins>
	</build>
</project>

application.yml

server:
  port: 8501
spring:
  application:
    name: spring-cloud-consul-producer
  cloud: 
    consul: 
      host: localhost
      port: 8500
      discovery: 
      #服务名称
        serviceName: service-producer
        #健康检查时间间隔
        health-check-interval: 5s
        #启用健康检查
        enabled: true

启动类

@SpringBootApplication
@EnableDiscoveryClient //开启客户端注解
public class AssetApplication {

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

springCloud-Consul史上最详细搭建步骤_第2张图片启动项目,出现以上界面证明注册成功!

你可能感兴趣的:(springCloud,java,分布式,consul)