一、服务注册中心
本系列文章主要展示的是整合后的微服务框架,所以客户端部分不拆分来一一实现,具体请查看 客户端
一、构建项目
我是使用eclispe+sts构建的 SpringBoot/SpringStarterProject
Springboot版本:1.5.8.RELEASE
SpringCloud版本:Edgware.SR3
因为使用的时Sts,所以构建时候可以勾选方式,选择EurekaServer
展示一下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>cnex.cloud</groupId> <artifactId>registry</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>cloud-registry</name> <description>registry-center</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.8.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>Edgware.SR3</spring-cloud.version> </properties> <dependencies> <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> <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> </project>
二、配置文件
使用yml各式,配置文件名:application.yml,#风格注释,具体看注释,有一点说明一下。
因为我是运行在docker环境内的,但是懒,没有去编排容器,遇到过问题:
客户端注册到服务中心,如果没有 prefer-ip-address: true 一种是通过别名,即容器名/PC名等等。
如果有,是使用ip注册上去的,但是Docker内部网络和宿主机不在一个网段,所以通过IP是不能访问的。
所以 ip-address: 10.180.206.254 instance-id: ${eureka.instance.ip-address}:${server.port} 强制指定了他的注册地址。
后期最好还是使用容器的编排,这个只是demo
#端口 server: port: 9000 eureka: client: #不注册自身 register-With-Eureka: false fetch-Registry: false #服务中心地址,即自身 serviceUrl: defaultZone: http://10.180.206.254:9000/eureka/ instance: ip-address: 10.180.206.254 #使用iP地址注册 prefer-ip-address: true #注册到服务中心的ip:端口 instance-id: ${eureka.instance.ip-address}:${server.port}
三、开启注册中心
使用@EnableEurekaServer
package cnex.cloud.registry; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; @SpringBootApplication @EnableEurekaServer //开启注册中心 public class CloudRegistryApplication { public static void main(String[] args) { SpringApplication.run(CloudRegistryApplication.class, args); } }
四、访问管理界面
ip:port
五、客户端
具体请查看 客户端