消息提供者-----等于zk里面的生产者。
1.准备
https://github.com/ITfqyd/springcloud
把这个download加载下来,放入到idea中,更新下maven就可以使用
记住:因为我的项目是聚合项目,所以,父模块的jar,下面的博客都不增加了。
2.eureka client设置
2.1 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">
<modelVersion>4.0.0</modelVersion>
<groupId>com.fqyd</groupId>
<artifactId>springcloud-eureka-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcloud-eureka-client</name>
<packaging>jar</packaging>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>com.fqyd</groupId>
<artifactId>springcloud</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath>../pom.xml</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.RELEASE</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
<!-- Spring Cloud 管理依赖 -->
<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>
注意:
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: 8762
spring:
application:
name: eurka-client
eureka:
instance:
hostname: localhost
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
注意:
1.端口问题,以前的端口是8761,这里改为8762保证端口不冲突,不然运行就报端口占用的问题(网上很多的资料都写的一样)。
2.spring application name的名称改为不一样的
3. eureka之前的设置有,去掉,不然,本身不注册
register-with-eureka 由于该应用是注册中心,false:代表不向注册中心注册自己;true:代表注册自己
fetch-registry 是否启动检测服务
4.http://localhost:8761/eureka/ 这里localhost和8761都不是顺便写的,而是在springcloud(二) 注册中心Eureka server中配置勒localhost和8761。不了解的请查看对应博客
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类的服务。
3.运行效果
通过截图我们可以看到已经有服务注册进来了。
DESKTOP-8S3CENH:eurka-client:8762
拆分说明下
DESKTOP-8S3CENH 是计算机名称(这里也可以设置为ip显示,需要配置,后面会详细说明)
eurka-client: 是spring 的名称
8762:是注册的服务端口
注意:有时候可能会出现服务器注册不进来的情况。
例如:我本地网卡配置
通过图片,我这里有虚拟机、以太网、无线、vpn,而在代码中获取ip,不知道为什么以太网的优先级是最高。具体原因不清楚,清楚的朋友可以在下方留言。
测试场景:在代码中写获取ip的代码,每次获取的都是vpn的地址,我把其他的都禁用后,只留以太网,获取ip才正常。
上文发现 注册的服务有一列为DESKTOP-8S3CENH:eurka-client:8762 这样十分不利于让我们清楚,这个服务是从哪个ip注册过来的,不方便管理,所以这里需要设置一下,把计算机名称换成ip
ok.把主机名换成ip完成,大功告成!
如果你热衷技术,喜欢交流,欢迎加入我们!