服务注册与发现 -- Eureka

一、简单介绍

​ Eureka是spring cloud中的一个负责服务注册与发现的组件,是Netflix开发的服务发现框架,本身是一个基于REST的服务。它和 zookeeper、Consul,nacos一样,都是用于服务注册管理的 。这里我们先说下Eureka。一个Eureka中分为eureka server和eureka client。其中eureka server是作为服务的注册与发现中心。eureka client既可以作为服务的生产者,又可以作为服务的消费者。

二、上手

spring cloud是基于spring boot进行的开发,因此我们需要创建一个spring boot项目,同时在里面添加eureka server包。

1. 先搭建父级项目

搭建父级项目的是多次下篇文章继续使用。

父级项目使用maven创建,new --> Project -- >maven ,直接点击NEXT,出现GAV坐标要填写,本次demo使用 com.dzbiao.springcloud ,artifactId 为springcloud-collection。当然自定义也可。

我们在pom.xml 统一下jar包管理。

<?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.dzbiao.springcloud</groupId>
    <artifactId>springcloud-collection</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modules>
        <module>eureka-server-8761</module>
    </modules>

    <!--统一管理jar包版本-->
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
        <mybatis.spring.boot.version>2.1.4</mybatis.spring.boot.version>
    </properties>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-plugins</artifactId>
            </dependency>
            <!--spring boot 2.3.9-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>2.3.9.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!--spring cloud Hoxton.SR1-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Hoxton.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>
                <configuration>
                    <fork>true</fork>
                    <addResources>true</addResources>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

同时删除父级项目的src文件夹,只留下pom.xml即可。

2.eureka-server-8761

新建 eureka-server-8761的maven项目,父级项目为我们刚刚建立的springcloud-collection,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">
    <parent>
        <artifactId>springcloud-collection</artifactId>
        <groupId>com.dzbiao.springcloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.dzbiao.springcloud</groupId>
    <artifactId>eureka-server-8761</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <!--springboot-starter-web-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <!--springboot2.x使用 Netflix-eureka-server -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>
    
</project>

然后编辑 application.yml

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
    
  client:
    fetch-registry: false
    register-with-eureka: false
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka

src/main/java 创建com.dzbiao.EureKaServerApplication 启动类,添加 @EnableEurekaServer 注解。

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;


@SpringBootApplication
@EnableEurekaServer     // 注册中心添加该注解
public class EureKaServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(EureKaServerApplication.class,args) ;
    }
}

启动该main方法,开启服务注册中心。访问 : http://localhost:8761/ , 可以看到如下页面 :

eureka

上图最下面的英文 No instances available 是说没有可用的实例,也就是说我们仅仅开启了一个注册中心,还没有客户端或者服务进行注册。

3. eureka-client 客户端服务

我们就在下面创建两个客户端服务,eureka-client-8762eureka-client-8763 ,两个服务一样,只是端口不同。

eureka-client-8762 和eureka-client-8763的pom.xml 都为:

<dependencies>
    <!--springboot-starter-web-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>

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

eureka-client-8762 和eureka-client-8763的application.yml 都为:(注意更改端口)

# 注意更改端口号
server:
  port: 8763

spring:
  application:
    name: service

  client:
    service-url:
      defaultZone: http://localhost:8761/eureka

eureka-client-8762 的启动类 EurekaClientApplication8762

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;

@SpringBootApplication
@EnableEurekaClient     // 客户端注册
public class EurekaClientApplication8762 {

    public static void main(String[] args) {
        SpringApplication.run(EurekaClientApplication8762.class,args);
    }
}

eureka-client-8763 的启动类 EurekaClientApplication8763

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class EurekaClient8763 {

    public static void main(String[] args) {
        SpringApplication.run(EurekaClient8763.class,args) ;
    }
}

两个服务各新建 controller/UserController.java

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class UserController {

    @Value("${server.port}")
    private String server_port ;

    @GetMapping("user")
    public String getUser() {
        String str = "端口号:" + server_port ;
        return str;
    }
}

8762和8763分别启动,访问 localhost:8762/user 和localhost:8763/user ,会返回各自的带端口的字符串。同时我们看看注册中心的注册情况。

eureka-register

我们看到我们的服务已经注册成功,由于服务名称相同,所以上面显示service 有两个服务实例,一个8762,一个8763。

至此我们的eureka注册中心和服务注册全部成功。

posted @ 2021-03-16 12:46  duanxiaobiao  阅读(145)  评论(0编辑  收藏  举报