Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devzwy/springclouddemo
🔥🔥🔥🔥🔥🔥SpringCloud常用组件的使用Demo
https://github.com/devzwy/springclouddemo
eureka eureka-client eureka-server hystrix ribbon springcloud springcloud-demo springcloud-hystrix springcloud-ribbon springcloudeureka
Last synced: about 1 month ago
JSON representation
🔥🔥🔥🔥🔥🔥SpringCloud常用组件的使用Demo
- Host: GitHub
- URL: https://github.com/devzwy/springclouddemo
- Owner: devzwy
- Created: 2020-04-27T05:42:26.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-04-27T06:37:13.000Z (over 4 years ago)
- Last Synced: 2024-10-30T02:37:50.773Z (3 months ago)
- Topics: eureka, eureka-client, eureka-server, hystrix, ribbon, springcloud, springcloud-demo, springcloud-hystrix, springcloud-ribbon, springcloudeureka
- Language: Kotlin
- Homepage:
- Size: 2.11 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# SpringCloud使用到的相关组件以及端口等说明
___EurekaServer:服务注册中心 端口使用8000
EurekaClient:微服务客户端(内容提供者) 端口分别使用9000、9001、9002、9003,在Idea Configuration中自行配置
PublicApi:消费端+Hystrix(熔断器)+Zuul(路由网关以及全局拦截) 外网调用路径 端口80
#### 1. Eureka
服务治理,服务注册中心
#### 2.Hystrix
熔断器
#### 3.Zuul
路由网关以及全局拦截### 项目启动流程:
首先启动注册中心:`EurekaServer`启动后访问`localhost:8000`看到如下页面![image1](https://github.com/devzwy/SpringCloudDemo/blob/master/images/1.png)
随后启动微服务`EurekaClient()`,至少启动一个端口,启动后可在以上页面发现注册成功的微服务
![image2](https://github.com/devzwy/SpringCloudDemo/blob/master/images/2.png)
最后启动外部调用端微服务`PublicApi`,访问:`localhost/getUser`,数据会通过不同的端口返回,
如果其中有服务掉线后会通过熔断器返回预先定义好的数据,并根据熔断器配置的策略选择重连/remove机制,remove后该端口将不会被使用
#### 以下图片来自测试熔断器过程图片,假设开启两个服务端口9000,9001
![image3](https://github.com/devzwy/SpringCloudDemo/blob/master/images/3.png)postMan正常访问,从9000和9001不同端口返回,负载均衡没问题。
![image4](https://github.com/devzwy/SpringCloudDemo/blob/master/images/4.png)
![image5](https://github.com/devzwy/SpringCloudDemo/blob/master/images/5.png)
关闭其中的9000端口![image6](https://github.com/devzwy/SpringCloudDemo/blob/master/images/6.png)
再使用Postman访问,当负载均衡分配到9000端口时,熔断器会工作,如:
![image7](https://github.com/devzwy/SpringCloudDemo/blob/master/images/7.png)
间隔10s后再次访问(一段时间内访问如果再次被分配到9000,还是会返回失败信息,详见熔断器介绍),负载均衡将不会再分发到9000端口![image8](https://github.com/devzwy/SpringCloudDemo/blob/master/images/8.png)
再次启动9000端口![imag9](https://github.com/devzwy/SpringCloudDemo/blob/master/images/9.png)
间隔一段时间后,负载均衡又可以分配到9000端口了。自动重连成功。![image10](https://github.com/devzwy/SpringCloudDemo/blob/master/images/10.png)