zoukankan      html  css  js  c++  java
  • Eureka服务注册于发现之Client搭建

    Eureka在Server端的搭建已经有很多介绍的文章,同时也是学习Eureka的第一步。

    搭建好注册中心后怎么进行服务注册和服务调用,是我们要讲的主要内容。

    开发环境:IDEA2018.3+SpringBoot2.1.7Release+Eureka2.1.3+SpringCloud Greenwich.SR3

    第一步:

    Pom引入Eureka包

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

    同时需要引入 spring-cloud-dependencies,来管理SpringCloud全家桶组件

    <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>

    关键点在于spring-cloud引用的版本,需要查一下自己springboot版本选择对应的spring-cloud.version

    SpringCloud SpringBoot
    Angel版本 兼容Spring Boot 1.2.x
    Brixton版本 兼容Spring Boot 1.3.x,也兼容Spring Boot 1.4.x
    Camden版本 兼容Spring Boot 1.4.x,也兼容Spring Boot 1.5.x
    Dalston版本、Edgware版本 兼容Spring Boot 1.5.x,不兼容Spring Boot 2.0.x
    Finchley版本 兼容Spring Boot 2.0.x,不兼容Spring Boot 1.5.x
    Greenwich版本 兼容Spring Boot 2.1.x

    当然对于不熟悉的同学来说,看完这个依旧不知道自己该如何正确选择小版本。

    这一交给大家一个最容易的方法

    打开 Spring Initializr选择自己的Spring版本

    在Dependencies部分输入Eureka,找到Eureka Discovery Client,这里会根据我们选择的组件生成项目模板。

     然后下载为我们创建的项目模板,找到POM.XML查看这里的引用版本,是不是又快捷,又准确。

    我这里当然用到的版本是:

     <spring-cloud.version>Greenwich.SR3</spring-cloud.version>

    第二步:
    添加yml配置Eureka

    
    
    spring:
    application:
    name: crmapi

    #eureka配置 eureka: client: fetch
    -registry: true register-with-eureka: true serviceUrl: defaultZone: http://127.0.0.11:8020/eureka/,http://127.0.0.1:8021/eureka/,http://127.0.0.1:8022/eureka/ instance: instance-id: ${spring.application.name} prefer-ip-address: true ip-address: 127.0.01
    eureka.client.serviceUrl.defaultZone配置注册中心地址

    ureka.client.fetch-registry,是否启用获取服务注册信息,默认true

    ureka.client.fetch-registry.register-with-eureka,是否注册eureka,默认true
    instance.prefer-ip-address=true 
    默认false服务的Status将会采用“主机名:程序名(application.name属性):端口号”

      修改为true后,可以通过配置instance-id,来限定服务Status为制定instance-id,则实际访问时会访问对应的接口“服务器IP:端口号”
    以上两种方法可以按实际需求去配置。

    第三步
    注册服务

    找到程序入口添加@EnableEurekaClient注解

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

    在程序运行时便会按照之前的配置将当前服务注册到注册中心

    到这里,就可以完成服务中心注册,后面两步是调用时用使用,当然调用前也是同样要引用Eureka包,按第一步操作即可。

    如果当前服务既是服务提供者又是服务调用者,就可以直接配置第四、第五步进行远程调用别的服务。

    第四步
    配置调用

    我们可以建一个Bean配置EurekaConfig.class

    @Configuration
    public class EurekaConfig {
        @LoadBalanced
        @Bean
        RestTemplate restTemplate() {
            return new RestTemplate();
        }
    }

    第五步

    Controller调用

     @Autowired
        private RestTemplate restTemplate;
    
    public  List<MemberLevelVO> GetMemberLevel(String im) {
    
     String im =  restTemplate.getForObject("http://servername/getmemberlevel?im="+im,String.class)
    }

    后传: 

    调用时注意的问题,如果直接 new RestTemplate()去调用,服务端执行是不会调用我们前面调用的额IP形式,依然会调用主机名:端口号,是因为再资源注入是一定要有@LoadBalanced注解出现才行

    如果需要手动删除Eureka服务,可以使用PostMan执行DELETE操作既可删除已有服务

    删除链接:http://127.0.0.1:8020/eureka/apps/crmapi(服务名Application)/bi:crmapi:8028(注册名)

    删除操作

     

  • 相关阅读:
    初步掌握HBase
    基于HBase0.98.13搭建HBase HA分布式集群
    获取当前目录中的文件个数
    MapReduce链接作业
    MapReduce二次排序
    使用map端连接结合分布式缓存机制实现Join算法
    字符串匹配算法-BM
    统计电视机顶盒中无效用户数据,并以压缩格式输出有效用户数据
    字符串匹配算法-KMP
    MapReduce中的Join算法
  • 原文地址:https://www.cnblogs.com/loyung/p/11730914.html
Copyright © 2011-2022 走看看