第一部分--------微服务的简单搭建
------ 代码连接https://gitee.com/liuxw9715/SpringCloud_Eureka
1. eureka基础
1.1 Eureka的基本架构,有三个部分组成:
Eureka Service --------提供服务注册与发现
Service Provider-------服务提供方、将自身服务注册到Eureka从而使得消费者找到
Service Consumer-----服务消费方,从Eureka获取服务,从而消费
1.2 Eureka 的原理
2. 搭建Eureka Service
2.1创建工程
2.2导入坐标
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
2.3配置application.yml文件
server:
port: 8000 #端口号
#配置eureka service
eureka:
instance:
hostname: localhost
client:
register-with-eureka: false #是否将自己注册到注册中心
fetch-registry: false #是否从eureka中获取注册信息
#配置暴露给eureka client的请求地址
service-url:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
2.4配置启动类
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class,args);
}
}
2.5启动页面
3. 将服务提供者注册到eureka Service中
3.1 引入eurekaClient的坐标
<!--引入EurekaClient-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
3.2修改application.yml文件添加EurekaService的信息
#配置Eureka
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:8000/eureka/
instance:
profer-ip-address: true #使用IP地址注册
3.3修改启动类,添加服务发现的支持(可选)
主要添加@EnableDiscoveryClient注解
@SpringBootApplication
@EntityScan("org.liu.product.entity.po")
//激活EurekaClient
@EnableDiscoveryClient
public class ProductApplication {
public static void main(String[] args) {
SpringApplication.run(ProductApplication.class,args);
}
}
4. 服务消费者通过注册中心获取服务列表并调用
Eureka中的元数据:服务的主机名,IP地址等信息,可以通过eurekaservice进行获取,用于服务之间调用。
微服务A从EurekaService中获取微服务B的数据信息如下;
使用RestTemplate进行各个服务之间的跳转
object= restTemplate.getForObject("http://" +instance.getHost() +":"+ instance.getPort() +"product/" + id, object.class);
可能图片看起来好理解一点
总结:到此简单的微服务搭建已经结束
第二部分-------Eureka Service的高可用
5.Eureka Service的高可用
解决方案直接看图,也就是说部署2个Eureka Service服务,且相互注册
注:只有一个eureka服务如何启动两个----没错就是直接复制,注意修改端口和注册端口的信息
①如何开启两个EurekaService服务
②两个application.yml文件的配置
8000端口
spring:
application:
name: eureka-service
server:
port: 8000 #端口号
#配置eureka service
eureka:
client:
#配置暴露给eureka client的请求地址
service-url:
defaultZone: http://127.0.0.1:8001/eureka/
8001端口
spring:
application:
name: eureka-service
server:
port: 8001 #端口号
#配置eureka service
eureka:
client:
#配置暴露给eureka client的请求地址
service-url:
defaultZone: http://127.0.0.1:8000/eureka/
③启动之后如下所示,代表成功
8000端口的一个
8001端口的一个
总结:服务到这里就可以使用了,即使eureka断开一个节点,另一个服务也可以正常的运行。
第三部分-------细节优化
6. 注册中心显示服务器的IP地址:
配置application.yml文件
#配置Eureka
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:8000/eureka/
#defaultZone: http://127.0.0.1:8000/eureka/,http://127.0.0.1:8001/eureka/ #向多个eureka注册使用逗号隔开
instance:
prefer-ip-address: true #使用IP地址注册
instance-ip: ${spring.cloud.client.ip-address}:${server.port} #向注册中心注册IP地址
7. eureka的服务剔除问题
配置yml文件
#配置Eureka
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:8000/eureka/
#defaultZone: http://127.0.0.1:8000/eureka/,http://127.0.0.1:8001/eureka/ #向多个eureka注册使用逗号隔开
instance:
prefer-ip-address: true #使用IP地址注册
instance-ip: ${spring.cloud.client.ip-address}:${server.port} #向注册中心注册IP地址
lease-renewal-interval-in-seconds: 5 #向注册中心注册服务IP---发送心跳时间5s
lease-expiration-duration-in-seconds: 10 #续约到期时间,立即到期
8.自我保护机制
当eureka界面出现红色的字体时,表示eureka出现自我保护机制
- 自我保护机制的关闭
yam文件中添加
server:
enable-self-preservation: false #关闭自我保护
eviction-interval-timer-in-ms: 4000 #剔除服务间隔