天天看点

SpringCloud学习笔记(三、创建父子项目、注册中心)创建父子项目

文章目录

在这里,需要创建父子项目,将之前单体式的工程拆分开来。

  • 我们这里在IDEA中创建一个maven项目,当然,也可以直接创建一个SpringBoot项目
SpringCloud学习笔记(三、创建父子项目、注册中心)创建父子项目

  • 依赖
<?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>edu.hpu.springcloud</groupId>
    <artifactId>springcloud</artifactId>
    <version>1.0-SNAPSHOT</version>
    <description>springcloud</description>
    <modules>
        <module>eureka-server</module>
    </modules>
    <packaging>pom</packaging>  <!--打包方式当然要选pom-->

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RELEASE</version>    <!--springboot版本-->
        <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>
        <spring-cloud.version>Finchley.RELEASE</spring-cloud.version> <!--SpringCloud版本-->
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>4.3.1</version>
        </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>

</project>      

  • 创建子项目:New—>Module
    SpringCloud学习笔记(三、创建父子项目、注册中心)创建父子项目
  • 这里项目命名为 eureka-server,表示SpringCloud注册中心
    SpringCloud学习笔记(三、创建父子项目、注册中心)创建父子项目
  • 依赖:
<?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">
    <parent>
        <artifactId>springcloud</artifactId>
        <groupId>edu.hpu.springcloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>eureka-server</artifactId>

    <name>eureka-server</name>
    <!-- FIXME change it to the project's website -->
    <url>http://www.example.com</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

</project>
      

EurekaServer 启动类。

这个类充当注册中心,用于注册各种微服务,以便于其他微服务找到和访问。

EurekaServer 本身就是个 Springboot 微服务, 所以它有 @SpringBootApplication 注解。

@EnableEurekaServer 表示这是个 EurekaServer 。

NetUtil 是 Hutool 的工具,在父项目的 pom.xml 里已经依赖了。

package edu.hpu.springcloud;

import cn.hutool.core.util.NetUtil;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args){
        int port=8761;
        if(!NetUtil.isUsableLocalPort(port)) {
            System.err.printf("端口%d被占用了,无法启动%n", port );
            System.exit(1);
        }
        new SpringApplicationBuilder(EurekaServerApplication.class).properties("server.port=" + port).run(args);
    }
}      

application.yml:

配置文件,提供 eureka 的相关信息。

  • hostname: localhost 表示主机名称。
  • registerWithEureka:false. 表示是否注册到服务器。 因为它本身就是注册中心,所以就无需把自己注册到注册中心
  • fetchRegistry: false. 表示是否获取服务器的注册信息,和上面同理,这里也设置为 false。
  • defaultZone: http:// e u r e k a . i n s t a n c e . h o s t n a m e : {eureka.instance.hostname}: eureka.instance.hostname:{server.port}/eureka/ 自己作为服务器,公布出来的地址。 比如后续某个微服务要把自己注册到 eureka server, 那么就要使用这个地址: http://localhost:8761/eureka/
eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

spring:
  application:
    name: eureka-server      

运行EurekaServeApplication,我们配置的端口是8761,所以访问网址:http://localhost:8761/

可以看到我们的注册中心已经启动。

SpringCloud学习笔记(三、创建父子项目、注册中心)创建父子项目

查看看Instances currently registered with Eureka,

SpringCloud学习笔记(三、创建父子项目、注册中心)创建父子项目

目前没有被注册的服务,接下来就要学习如何注册和消费服务。

参考:

【1】、

分布式和集群 / SpringCloud / SpringCloud系列教材 (五)- 服务注册中心

【2】、

工具和中间件 / Intellij IDEA / Intellij IDEA系列教材 (十六)- maven - 父子-聚合项目