zoukankan      html  css  js  c++  java
  • 服务注册与发现 -- 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注册中心和服务注册全部成功。

  • 相关阅读:
    7.3---直线是否相交(CC150)
    7.2---蚂蚁相遇问题(CC150)
    5.6---交换整数的奇数位和偶数位(CC150)
    5.5---整数A转成整数B(CC150)
    5.2---小数的二进制表示(CC150)
    5.1---二进制数插入(CC150)
    4.6---找二叉树中序后继(CC150)
    4.5---判断是否是二叉排序树BST(CC150)
    4.4---建立二叉树的链表
    linux中查看java进程
  • 原文地址:https://www.cnblogs.com/duanxiaobiao/p/14542838.html
Copyright © 2011-2022 走看看