学成在线day09, Eureka注册中心,把微服务添加进注册中心,Ribbon客户端负载均衡器和远程调用案例,Feign,课程预览

1 Eureka 注册中心

1.1 需求分析
在前后端分离架构中,服务层被拆分成了很多的微服务,微服务的信息如何管理?Spring Cloud中提供服务注册中
心来管理微服务信息。
为什么 要用注册中心?
1、微服务数量众多,要进行远程调用就需要知道服务端的ip地址和端口,注册中心帮助我们管理这些服务的ip和
端口。
2、微服务会实时上报自己的状态,注册中心统一管理这些微服务的状态,将存在问题的服务踢出服务列表,客户
端获取到可用的服务进行调用。
1.3 Eureka 注册中心
1.3.1 Eureka介绍
Spring Cloud Eureka 是对Netflix公司的Eureka的二次封装,它实现了服务治理的功能,Spring Cloud Eureka提
供服务端与客户端,服务端即是Eureka服务注册中心,客户端完成微服务向Eureka服务的注册与发现。服务端和
客户端均采用Java语言编写。下图显示了Eureka Server与Eureka Client的关系:
在这里插入图片描述
1、Eureka Server是服务端,负责管理各各微服务结点的信息和状态。
2 、在微服务上部署Eureka Client程序,远程访问Eureka Server将自己注册在Eureka Server。
3、微服务需要调用另一个微服务时从Eureka Server中获取服务调用地址,进行远程调用。

1.3.2 Eureka Server搭建

1.3.2.1 单机环境搭建

1、创建xc-govern-center工程:
包结构:com.xuecheng.govern.center
在父工程添加:(有了则不用重复添加)

<dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.SR1</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

注册中心微服务jar:

<dependencies>
        <!-- 导入Eureka服务的依赖,版本已经由父工程锁定了,不用管 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

3、启动类

@EnableEurekaServer //标识这个服务,为注册中心的服务器
@SpringBootApplication
public class GovernCenterApplication {
   
    public static void main(String[] args) {
   
        SpringApplication.run(GovernCenterApplication.class,args);
    }
}

5、从其它服务拷贝application.yml和logback-spring.xml。
后面还会改一些配置
在这里插入图片描述

server:
  port: 50101 #服务端口
spring:
  application:
    name: xc-govern-center #指定服务名
eureka:
  client:
    registerWithEureka: false #服务注册,是否将自己注册到Eureka服务中
    fetchRegistry: false #服务发现,是否从Eureka中获取注册信息
    serviceUrl: #Eureka客户端与Eureka服务端的交互地址,高可用状态配置对方的地址,单机状态配置自己(如果不配置则默认本机8761端口)
      defaultZone: http://localhost:50101/eureka/
  server:
    #是否开启自我保护模式,开发中,不开启,项目上线的时候,开启。目的是,考虑网络的问题。开发中不存在网络问题
    enable-self-preservation: false
    #服务注册表清理间隔(单位毫秒,默认是60*1000),每隔一分钟判断已注册服务器的状态
    eviction-interval-timer-in-ms: 60000

运行启动类,浏览器输入端口测试:
在这里插入图片描述

1.3.2.2 高可用环境搭建

Eureka Server 高可用环境需要部署两个Eureka server,它们互相向对方注册。如果在本机启动两个Eureka需要
注意两个Eureka Server的端口要设置不一样,这里我们部署一个Eureka Server工程,将端口可配置,制作两个
Eureka Server启动脚本,启动不同的端口,如下图:
在这里插入图片描述
1、在实际使用时Eureka Server至少部署两台服务器,实现高可用。
2、两台Eureka Server互相注册。
3、微服务需要连接两台Eureka Server注册,当其中一台Eureka死掉也不会影响服务的注册与发现。
4、微服务会定时向Eureka server发送心跳,报告自己的状态。
5、微服务从注册中心获取服务地址以RESTful方式发起远程调用。
开始构建:

先了解这个配置语法:${
   EUREKA_DOMAIN:eureka01}
可以理解为三元运算符,第一个变量获取到值,就用这个变量的值,获取不到用:后面的值。

这个变量的配置,再服务器的启动中配置。位置如图:
在这里插入图片描述
完整的eureka,yml配置如下:
在这里插入图片描述

server:
#  2个注册中心的高可用配置,能从配置的PROT环境变量中,获取值,就使用。获取不到值,就使用50101
  port: ${
   PORT:50101} #服务端口
spring:
  application:
    name: xc-govern-center #指定服务名
eureka:
  client:
    registerWithEureka: true #服务注册,是否将自己注册到Eureka服务中
    fetchRegistry: true #服务发现,是否从Eureka中获取注册信息
    serviceUrl: #Eureka客户端与Eureka服务端的交互地址,高可用状态配置对方的地址,单机状态配置自己(如果不配置则默认本机8761端口)
#      eureka02,在hosts文件中,已经映射了127.0.0.1 域名,正常情况是填写域名
      defaultZone: ${
   EUREKA_SERVER:http://eureka02:50102/eureka/}
  server:
    #是否开启自我保护模式,开发中,不开启,项目上线的时候,开启。目的是,考虑网络的问题。开发中不存在网络问题
    enable-self-preservation: false
    #服务注册表清理间隔(单位毫秒,默认是60*1000),每隔一分钟判断已注册服务器的状态
    eviction-interval-timer-in-ms: 60000
    #当前服务的别名
  hostname: ${
   EUREKA_DOMAIN:eureka01}

4、在IDEA中制作启动脚本,也就是配${EUREKA_DOMAIN:eureka01}变量名的值
启动1:
在这里插入图片描述
释义:
PORT:这个服务的端口是50101。
EUREKA_SERVER:要往eureke02所指向的域名中的50102端口的eureka注册服务中注册信息。
EUREKA_DOMAIN:本服务的别名是eureka01。

-DPORT=50101 -DEUREKA_SERVER=http://eureka02:50102/eureka/ -DEUREKA_DOMAIN=eureka01

启动2:
在这里插入图片描述
释义:
PORT:这个服务的端口是50102。
EUREKA_SERVER:要往eureke01所指向的域名中的50101端口的eureka注册服务中注册信息。
EUREKA_DOMAIN:本服务的别名是eureka02。

-DPORT=50102 -DEUREKA_SERVER=http://eureka01:50101/eureka/ -DEUREKA_DOMAIN=eureka02

总结:关系就像情侣,你知我长短,我知你深浅。
启动2个注册服务,不用管第一个启动的服务的报错:
进入浏览器,测试:

http://localhost:50101/
http://localhost:50102/

在这里插入图片描述

把微服务项目,注册进EureKa注册中心的方法:

理解:就是中国交一系列的文件,加入WTO世贸组织,各国就通过世贸组织进行交易,交互。

将cms注册到Eureka Server

1、在cms服务中添加依赖

<dependency>
            <!--导入Eureka客户端的依赖-->
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-c
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值