SpringCloud 有很多组件,本篇主要介绍Eureka组件的使用。
Eureka分为两个模块,即Server和Client。
第一,注册中心的搭建
首先创建一个maven项目,本人使用idea工具,其他工具的创建方式大同小异,主要是pom.xml文件的异同。
pom.xml文件如下:
<?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.fangxing.springcloud</groupId> <artifactId>euruka-server</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>euruka-server</name> <description>Demo project for Eureka Server</description> <!--基于Springboot--> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.0.RELEASE</version> <relativePath/> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <java.version>1.8</java.version> </properties> <dependencies> <!--增加eureka-server的依赖--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <!--依赖管理,用于管理spring-cloud的依赖--> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Camden.SR3</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> </project>
然后配置application.yml文件信息。
server.port=8081 #访问端口号 eureka.instance.hostname=localhost #表示设置该服务注册中心的hostname eureka.client.register-with-eureka=false #此项默认为true。这项表示向服务注册中心注册本应用,也就是eureka自己注册自己,需要禁止 eureka.client.fetch-registry=false #不主动去检索其他服务,做好自己维护服务的本职工作即可 eureka.client.service-url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
其次在启动类上加@EnableEurekaServer标签。
import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; @EnableEurekaServer @SpringBootApplication public class EurekaserverApplication { public static void main(String[] args) { SpringApplication.run(EurekaserverApplication.class, args); System.out.println("hello world"); } }
最后浏览器输入http://localhost:8081/就能访问到eureka的主页了。
但是此时这里显示的是No instances available,因为我们还没有注册任何服务。
第二,创建一个服务
首先还是创建一个maven项目,它的pom.xml文件是这样子的。
<?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.example</groupId> <artifactId>webserver</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>webserver</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.0.RELEASE</version> <!--刚开始我的版本是2.0.2,依赖包冲突,项目都启动不了,后来降低了版本就正常了--> <relativePath/> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</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>Camden.SR3</version> <!--<version>Camden.SR1</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.yml文件。
eureka: client: serviceUrl: defaultZone: http://localhost:8081/eureka/ #这是刚才创建的eureka注册地址 server: port: 8082 spring: application: name: peoduceserver #服务名称,这里写什么,注册中心就显示什么,以后调用这个服务就写这个名
其次在项目的启动类上加@EnableEurekaClient标签。
@SpringBootApplication @EnableEurekaClient public class ProduceServerApplication { public static void main(String[] args) { SpringApplication.run(ProduceServerApplication.class, args); System.out.println("hello ProduceServerApplication"); } }
最后启动项目。
这时刷新Erueka的页面,我们发现刚才的服务已经注册成功了。
第三,一些小问题
在整个注册过程中也出现两个问题,但是都解决了。如下:
a.项目启动时报错。虽然是一闪而过,项目也启动成功,但是看到了就要解决。
原因很简单,因为手贱多敲了几个空格。
这些地方明显颜色不一致,就是空格键所致。删掉就好了。
b.如图,项目直接启动失败。报java.lang.NoSuchMethodError: org.springframework.boot.builder.SpringApplicationBuilder.<init>([Ljava/lang/Object;)错。
依赖包冲突,版本太高也怪我咯?解决办法,在pom.xml文件中修改版本号。
第一处,将2.0.2改为1.4.0。
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.0.RELEASE</version> <!--<version>2.0.2.RELEASE</version>--> <relativePath/> </parent>
第二处,将Camden.SR1改为Camden.SR3。
<dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Camden.SR3</version> <!--<version>Camden.SR1</version>--> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>