写在开头
SpringCloud进来成为业界排名靠前的微服务框架,最核心功能就是搭建微服务,并在此基础上衍生出一系列功能,如断路器(Hystrix)、断路监控、管理配置、Zuul、OAuth2等功能。其中Eureka是SpringCloud的核心模块,是一个服务注册与发现的模块。
通常情况下搭建Eureka的流程
第一步:建立一个服务注册中心;
第二步:建立微服务并注入到注册中心;
第三步:建立client端来访问微服务。
本教学中,服务中心采用Eureka Server来建立,微服务及访问微服务的client均采用Eureka Client来建立。
--------------------------------------正文开始------------------------------------------------
第一步 建立Eureka Server服务注册中心
Path:File->New->Project->Spring Initializr->Next 按照下图配置
配置后生成POM如下
<?xml version="1.0" encoding="UTF-8"?> <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>com.cloud</groupId> <artifactId>eureka</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>eureka</name> <description>Demo project for Spring Cloud Eureka</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.3.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.RC2</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </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> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> <repositories> <repository> <id>spring-milestones</id> <name>Spring Milestones</name> <url>https://repo.spring.io/milestone</url> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories> </project>
下面对程序做修改:
首先在Application中加入注解@EnableEurekaServer
然后修改application配置文件后缀为yml
PS:.yml文件是项目的配置文件,各节点间具有层级关系,便于配置和维护。
yml文件增加下面内容,由于每个eureka serve项目均为client,而当下要建立的是一个纯eureka serve服务,
所以增加fetch-registry: false register-with-eureka: false两项配置来告诉系统该服务并非是client无需将其注册到服务中心。
8761为注册中心的默认端口,在配置文件中显示声明。
eureka:
client:
fetch-registry: false
register-with-eureka: false
server:
port: 8761
做完上面配置,可以登录localhost:8761查看【服务注册中心】的管理界面
写在最后
本章对SpringCloud做了简要介绍,另外阐述了Eureka和SpringCloud的关系。搭建SpringCloud微服务环境的核心就是搭建Eureka,本文将其分为三步,本章详细介绍了【服务注册中心的建立】。下一章节介绍【微服务的创建】以及将其【添加到服务注册中心的方式】。
以上,亲测。
欢迎在评论区指正,
如果感觉本教程对您有所帮助,希望可以为笔者打Call