zoukankan      html  css  js  c++  java
  • springcloud 学习1:创建eureka server和eureka client

    springcloud学习1:eureka server 和client 的构建

    使用的springboot版本是2.0.0

    一、eureka简单介绍

    eureka是一个服务发现组件,是为了解决微服务相互之间调用时通过硬编码服务地址进行调用的弊端。

    硬编码服务地址进行调用主要有以下两个弊端:

    (1) 如果服务提供者的网络地址(IP和端口)发生了变化,将会影响服务消费者。

    (2) 一般服务提供者会部署多个实例进行高可用和负载均衡,硬编码服务地址无法实现这种功能。

    所以需要服务发现组件来动态的获取服务地址。服务提供者,服务消费者,发现组件这三个之间应该有这样的关系:

    • 各个微服务在启动时,将自己的网络地址等信息注册到服务发现组件中,服务发现组件会存储这些信息
    • 服务消费者可从服务发现组件查询服务提供者的网络地址,并使用该地址调用服务提供者的接口
    • 各个微服务与服务发现组件使用一定机制(如心跳)通信。服务发现组件如长时间无法与某微服务实例通信,就会注销该实例。
    • 微服务网络地址发生变更(例如实例增减或IP端口发生变化时),会重新注册到服务发现组件中。

    eureka包含server和client两部分,eureka server提供服务发现的能力,各个微服务启动时会向eureka server注册自己的地址。eureka client是一个java客户端,用来简化和eureka server的交互。

    二、创建单节点的eureka server服务

    (1) 创建springboot工程,maven依赖如下

    <?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.lyy</groupId>
        <artifactId>eureka_server</artifactId>
        <version>1.0-SNAPSHOT</version>
    
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.0.0.RELEASE</version>
            <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.M8</spring-cloud.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
            </dependency>
    
            <!--热部署配置-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-devtools</artifactId>
            </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>
    

    (2) 在启动类上加上@EnableEurekaServer注解

    @SpringBootApplication
    @EnableEurekaServer
    public class EurekaServerApplication {
        public static void main(String[] args) {
            SpringApplication.run(EurekaServerApplication.class,args);
        }
    }
    

    (3) 在配置文件中进行eureka的端口和连接地址等的配置

    server:
      port: 8761
    eureka:
      instance:
        hostname: localhost
      client:
        register-with-eureka: false # 是否将自己注册到Eureka Server,默认为true。由于当前应用就是Eureka Server,故而设为false
        fetch-registry: false # 表示是否从Eureka Sever获取注册信息,默认为true。因为这个一个单节点的Eureka Server,不需要同步其他的Eureka Server节点的数据,故而设为false
        service-url:
          defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka # 设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。
    
    

    启动工程,访问http://localhost:8761/,可以看到eureka的管理界面,表示服务搭建成功。

    三、创建eureka client,服务提供者

    要注意的是服务提供者和服务发现者都是eureka client。

    创建springboot工程demo-provider-user,引入eureka-client的依赖

    <?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.lyy</groupId>
        <artifactId>demo_provider_user</artifactId>
        <version>1.0-SNAPSHOT</version>
    
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.0.0.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>Finchley.M8</spring-cloud.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            </dependency>
    
            <!--热部署配置-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-devtools</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
                <version>1.16.16</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>
    

    在工程的启动类上加上@EnableEurekaClient注解

    @SpringBootApplication
    @EnableEurekaClient
    public class UserProviderApplication {
        public static void main(String[] args) {
            SpringApplication.run(UserProviderApplication.class);
        }
    }
    

    在配置文件中配置连接到eureka server

    server:
      port: 8082
      servlet:
        # 这是配置应用的根目录
        context-path: /provider
    spring:
      application:
        name: demo-provider-user
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:8761/eureka/
      instance:
        prefer-ip-address: true # 将自己的IP注册到Eureka Server。若不配置或设置为false,表示注册微服务所在操作系统的hostname到Eureka Server
    

    对外提供一个查询所有用户的接口

    @RestController
    @RequestMapping("/user")
    public class UserController {
        @GetMapping("/findAll")
        public List<User> findAll(){
            User user=new User();
            user.setName("zs");
            List<User> list=new ArrayList<>();
            list.add(user);
            return list;
        }
    }
    

    这个接口在提供者工程中的访问地址是http://localhost:8082/provider/user/findAll

    四、创建eureka client 服务消费者

    创建springboot工程demo_consumer_user,引入eureka-client的依赖,pom文件的内容和服务提供者类似

    在工程的启动类上加@EnableEurekaClient注解

    在配置文件中配置连接到eureka server

    五、测试

    先启动eureka server,再启动eureka client,访问eureka的管理界面,看两个client服务是否注册到了server上。

  • 相关阅读:
    LeetCode 82,考察你的基本功,在有序链表中删除重复元素II
    golang | Go语言入门教程——结构体初始化与继承
    pandas | 使用pandas进行数据处理——DataFrame篇
    博弈论 | 详解搞定组合博弈问题的SG函数
    PCA算法 | 数据集特征数量太多怎么办?用这个算法对它降维打击!
    Python | 面试必问,线程与进程的区别,Python中如何创建多线程?
    Pytorch | 详解Pytorch科学计算包——Tensor
    通过Windows Visual Studio远程调试WSL2中的.NET Core Linux应用程序
    MSIL入门(二)通过对象看IL
    MSIL入门(一)C#代码与IL代码对比
  • 原文地址:https://www.cnblogs.com/chengxuxiaoyuan/p/12872553.html
Copyright © 2011-2022 走看看