一、服务注册中心

本系列文章主要展示的是整合后的微服务框架,所以客户端部分不拆分来一一实现,具体请查看 客户端

一、构建项目

我是使用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

五、客户端

具体请查看 客户端

posted @ 2018-07-18 10:18  BBJB  阅读(358)  评论(0编辑  收藏  举报