《springcloud学习》 四 eureka-消费提供者

消息提供者-----等于zk里面的生产者。

1.准备

记住:因为我的项目是聚合项目

pom.xml



    4.0.0

    
    org.springframework.boot
    spring-boot-starter-parent
    2.0.4.RELEASE
     


    com.fqyd
    springcloud
    1.0-SNAPSHOT

    
        UTF-8
        UTF-8
        1.8
        Finchley.RELEASE
    
    
        springcloud_eureka
        springcloud_product
    

    
        
            org.springframework.boot
            spring-boot-starter-web
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    
    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                ${spring-cloud.version}
                pom
                import
            
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    

 

2.eureka 会员服务1

    2.1 pom.xml



    4.0.0
    
        com.fqyd
        springcloud
        1.0-SNAPSHOT
        ../pom.xml
    

    com.fqyd
    springcloud_product
    0.0.1-SNAPSHOT
    springcloud_product
    Demo project for Spring Boot

    
        UTF-8
        UTF-8
        1.8
    

    
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
    

注意:
1. client使用的是spring-cloud-starter-netflix-eureka-client
2.版本问题,spring boot2.0以上的版本使用的是Finchley开头的。
3.2.0以下和2.0的依赖多来netflix,2.0以下引入的是spring-cloud-starter-eureka-client

2.2 application.yml

####服务器端口号
server:
  port: 8000
###服务别名---服务器注册到注册中心的名称
spring:
  application:
    name: fqyd-member
eureka:
  client:
    ###需要将我的服务注册到eureka上
    registerWithEureka: true
    ###检索服务
    fetchRegistry: true
    ###当前服务注册到eureka服务地址
    serviceUrl:
      defaultZone: http://localhost:8100/eureka/

注意:

1.端口问题,以前的端口是8100,这里改为8000保证端口不冲突,不然运行就报端口占用的问题(网上很多的资料都写的一样)。

2.spring application name的名称改为不一样的

3. eureka之前的设置有,去掉,不然,本身不注册
《springcloud学习》 四 eureka-消费提供者_第1张图片

 

register-with-eureka  由于该应用是注册中心,false:代表不向注册中心注册自己;true:代表注册自己
fetch-registry 是否启动检测服务

4.http://localhost:8100/eureka/  这里localhost和8761都不是顺便写的,而是在springcloud(二) 注册中心Eureka server中配置勒localhost和8100。不了解的请查看对应博客

https://blog.csdn.net/qq_16855077/article/details/90752257

2.3启动类

package com.fqyd.springcloudeurekaclient;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;


@EnableDiscoveryClient   //更通用,支持服务发现组件
//@EnableEurekaClient    专属的组件
@SpringBootApplication
public class SpringcloudEurekaClientApplication {

    public static void main(String[] args) {
        System.out.println("启动————提供服务者");
        SpringApplication.run(SpringcloudEurekaClientApplication.class, args);
    }

}

注意:这两个注解都可以使用,只是更广泛使用,因为他可以不仅仅支持eureka的服务,也可以发现如zk类的服务。

2.4   会员api接口

package com.fqyd.api.controller;

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

/**
 * Description:
 * Author: wude
 * Date:  2019/7/10 16:44
 * Modified By:
 */
@RestController
public class MeberApiController {
    @Value("${server.port}")
    private String port;
    @RequestMapping("getMember")
    public  String getMember(){
        return "this is member!端口号为:"+port;
    }
}

 

2.5.运行效果

《springcloud学习》 四 eureka-消费提供者_第2张图片

《springcloud学习》 四 eureka-消费提供者_第3张图片

 

 通过截图我们可以看到已经有服务注册进来了。

DESKTOP-8S3CENH:fqyd-member:8000 

拆分说明下

DESKTOP-8S3CENH 是计算机名称(这里也可以设置为ip显示,需要配置,后面会详细说明)

eurka-client: 是spring 的名称

8000:是注册的服务端口

注意:有时候可能会出现服务器注册不进来的情况。

例如:我本地网卡配置

《springcloud学习》 四 eureka-消费提供者_第4张图片

通过图片,我这里有虚拟机、以太网、无线、,而在代码中获取ip,不知道为什么以太网的优先级是最高。具体原因不清楚,清楚的朋友可以在下方留言。

测试场景:在代码中写获取ip的代码,每次获取的都是的地址,我把其他的都禁用后,只留以太网,获取ip才正常。

上文发现 注册的服务有一列为DESKTOP-8S3CENH:eurka-client:8000 这样十分不利于让我们清楚,这个服务是从哪个ip注册过来的,不方便管理,所以这里需要设置一下,把计算机名称换成ip

《springcloud学习》 四 eureka-消费提供者_第5张图片

《springcloud学习》 四 eureka-消费提供者_第6张图片

ok.把主机名换成ip完成,大功告成!

3.会员服务2

3.1 pom.xml



    4.0.0
    
        com.fqyd
        springcloud
        1.0-SNAPSHOT
        ../pom.xml
    
    com.fqyd
    springcloud_product_member
    0.0.1-SNAPSHOT
    springcloud_product_member
    Demo project for Spring Boot

    
        UTF-8
        UTF-8
        1.8
    

    
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
    


3.2 application.yml 

####服务器端口号
server:
  port: 8010
###服务别名---服务器注册到注册中心的名称
spring:
  application:
    name: fqyd-member
eureka:
  client:
    ###需要将我的服务注册到eureka上
    registerWithEureka: true
    ###检索服务
    fetchRegistry: true
    ###当前服务注册到eureka服务地址
    serviceUrl:
      defaultZone: http://localhost:8100/eureka/

3.3 api接口 

package com.fqyd.api.controller;

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

/**
 * Description:
 * Author: wude
 * Date:  2019/7/10 16:44
 * Modified By:
 */
@RestController
public class MeberApiController {
    @Value("${server.port}")
    private String port;
    @RequestMapping("getMember")
    public  String getMember(){
        return "this is member!端口号为:"+port;
    }
}

3.3 启动类 

package com.fqyd;

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

@SpringBootApplication
public class SpringCloudProductMemberApplication {

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

}

3.4测试效果 

《springcloud学习》 四 eureka-消费提供者_第7张图片

注意:这里启动了两个会员提供者,主要是为了方便后面做消费者负责均衡测试使用

如果你热衷技术,喜欢交流,欢迎加入我们! 

你可能感兴趣的:(#)