SpringCloud教程之Eureka注册中心(二)

阅读: 评论:0

SpringCloud教程之Eureka注册中心(二)

SpringCloud教程之Eureka注册中心(二)

学习SpringCloud技术前提就是学习Eureka注册服务中心,而Eureka注册服务中心,它是什么呢?今天小编就带你一起了解一下吧!!!

Eureka

    • 1.认识Eureka
    • 2.原理图
    • 3.入门案例

1.认识Eureka

首先我们来解决第一问题,服务的管理。

  • 网约车
    这就好比是 网约车出现以前,人们出门叫车只能叫出租车。一些私家车想做出租却没有资格,被称为黑车。而很多人想要约车,但是无奈出租车太少,不方便。私家车很多却不敢拦,而且满大街的车,谁知1道哪个才是愿意载人的。一个想要,一个愿意给,就是缺少引子,缺乏管理啊。
    此时滴滴这样的网约车平台出现了,所有想载客的私家车全部到滴滴注册,记录你的车型(服务类型),身份信息(联系方式)。这样提供服务的私家车,在滴滴那里都能找到,一目了然。
    此时要叫车的人,只需要打开APP,输入你的目的地,选择车型(服务类型),滴滴自动安排一个符合需求的车到你面前,为你服务,完美!
  • Eureka做什么?
    Eureka就好比是滴滴,负责管理、记录服务提供者的信息。服务调用者无需自己寻找服务,而是把自己的需求告诉Eureka,然后Eureka会把符合你需求的服务告诉你。
    同时,服务提供方与Eureka之间通过“心跳”机制进行监控,当某个服务提供方出现问题,Eureka自然会把它从服务列表中剔除。
    这就实现了服务的自动注册、发现、状态监控。

2.原理图

基本架构:

  • Eureka:就是服务注册中心(可以是一个集群),对外暴露自己的地址
  • 提供者:启动后向Eureka注册自己信息(地址,提供什么服务)
  • 消费者:向Eureka订阅服务,Eureka会将对应服务的所有提供者地址列表发送给消费者,并且定期更新
  • 心跳(续约):提供者定期通过http方式向Eureka刷新自己的状态

了解了这么多,终于到了写代码的时候啦,现在就让我们来写一个入门案例吧!

3.入门案例

3.1.编写EurekaServer

接下来我们创建一个项目,启动一个EurekaServer:
依然使用spring提供的快速搭建工具:

选择依赖:

完整的Pom文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns=".0.0" xmlns:xsi=""xsi:schemaLocation=".0.0 .0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId&demo</groupId><artifactId>eureka-demo</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>eureka-demo</name><description>Demo project for Spring Boot</description><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.1.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>&porting.outputEncoding>UTF-8</porting.outputEncoding><java.version>1.8</java.version><!-- SpringCloud版本,是最新的F系列 --><spring-cloud.version>Finchley.RC1</spring-cloud.version></properties><dependencies><!-- Eureka服务端 --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency></dependencies><dependencyManagement><dependencies><!-- SpringCloud依赖,一定要放到dependencyManagement中,起到管理版本的作用即可 --><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><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build><repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>;/url><snapshots><enabled>false</enabled></snapshots></repository></repositories>
</project>

编写启动类:

@SpringBootApplication
@EnableEurekaServer // 声明这个应用是一个EurekaServer
public class EurekaDemoApplication {public static void main(String[] args) {SpringApplication.run(EurekaDemoApplication.class, args);}
}

编写配置l:

server:port: 10086 # 端口
spring:application:name: eureka-server # 应用名称,会在Eureka中显示
eureka:client:register-with-eureka: false # 是否注册自己的信息到EurekaServer,默认是truefetch-registry: false # 是否拉取其它服务的信息,默认是trueservice-url: # EurekaServer的地址,现在是自己的地址,如果是集群,需要加上其它Server的地址。defaultZone: 127.0.0.1:${server.port}/eureka

启动服务,并访问:127.0.0.1:10086/eureka

3.2user-service注册到Eureka

注册服务,就是在服务上添加Eureka的客户端依赖,客户端代码会自动把服务注册到EurekaServer中。

  • 我们在user-service-demo中添加Eureka客户端依赖:

先添加SpringCloud依赖:

<!-- SpringCloud的依赖 -->
<dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Finchley.RC1</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>
<!-- Spring的仓库地址 -->
<repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>;/url><snapshots><enabled>false</enabled></snapshots></repository>
</repositories>

然后是Eureka客户端:

<!-- Eureka客户端 -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
  • 在启动类上开启Eureka客户端功能

通过添加@EnableDiscoveryClient来开启Eureka客户端功能

@SpringBootApplication
@EnableEurekaClient // 开启EurekaClient功能
public class UserServiceDemoApplication {public static void main(String[] args) {SpringApplication.run(UserServiceDemoApplication.class, args);}
}

编写配置

server:port: 8081
spring:datasource:url: jdbc:mysql://localhost:3306/mydb1?useUnicode=true&characterEncoding=utf8username: rootpassword: 123456driver-class-name: sql.jdbc.Driverapplication:name: user-service # 应用名称
eureka:client:service-url: # EurekaServer地址defaultZone: 127.0.0.1:10086/eurekainstance:prefer-ip-address: true # 当调用getHostname获取实例的hostname时,返回ip而不是host名称ip-address: 127.0.0.1 # 指定自己的ip信息,不指定的话会自己寻找

注意:

  1. 这里我们添加了spring.application.name属性来指定应用名称,将来会作为应用的id使用。
  2. 不用指定register-with-eureka和fetch-registry,因为默认是true

3.3消费者从Eureka获取服务

接下来我们修改consumer-demo,尝试从EurekaServer获取服务。

方法与消费者类似,只需要在项目中添加EurekaClient依赖,就可以通过服务名称来获取信息了!

1)添加依赖:

先添加SpringCloud依赖:

<!-- SpringCloud的依赖 -->
<dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Finchley.RC1</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>
<!-- Spring的仓库地址 -->
<repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>;/url><snapshots><enabled>false</enabled></snapshots></repository>
</repositories>

然后是Eureka客户端:

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

2)在启动类开启Eureka客户端

@SpringBootApplication
@EnableDiscoveryClient // 开启Eureka客户端
public class UserConsumerDemoApplication {@Beanpublic RestTemplate restTemplate() {return new RestTemplate();}public static void main(String[] args) {SpringApplication.run(UserConsumerDemoApplication.class, args);}
}

3)修改配置:

server:port: 8080
spring:application:name: user-consumer # 应用名称
eureka:client:service-url: # EurekaServer地址defaultZone: 127.0.0.1:10086/eurekainstance:prefer-ip-address: true # 当其它服务获取地址时提供ip而不是hostnameip-address: 127.0.0.1 # 指定自己的ip信息,不指定的话会自己寻找

4)修改user-consumer-demo项目中的UserDao代码,用DiscoveryClient类的方法,根据服务名称,获取服务实例:


 // 必须导入org.springframework.cloud.client.discovery.DiscoveryClient@Autowiredprivate DiscoveryClient discoveryClient;public User queryUserById(Long id){//1、 根据user-service获取user-serivce 的集群的信息List<ServiceInstance> instances = Instances("user-service");//2、由于我们没有集群,只有一个,所以直接取出第一个ServiceInstance instance = (0);//3、拼接URLString url = ""&#Host()+":"&#Port()+"/user/"+id;// 使用restTemplate发起请求ResponseEntity<User> entity = ForEntity(url, User.class);// 获取返回对象User user = Body();return user;}

5)Debug跟踪运行:

生成的URL:

访问结果:

好啦!以上就是小编的内容啦,如果不懂,请在下方留言! 如有错误,欢迎大家请在下方评论!!!!

本文发布于:2024-02-02 21:24:52,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170688029246532.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:教程   中心   SpringCloud   Eureka
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23