springCloud全家桶
简单介绍、使用
1、服务注册与发现eureka
介绍:
各服务系统(订单、商品、用户......)将需要对外提供的服务发布至eureka服务器上进行注册;
各eureka客户端系统,可以从eureka服务中心,发现其他服务连接信息,便于服务间调用(实现解耦);
eureka服务器
一般是集群方式部署eureka服务器,保证eureka的高可用;
配置开启@EnableEurekaServer
data:image/s3,"s3://crabby-images/6c149/6c149618a81f744a0c78bd3222d0dfcb1e7aae82" alt=""
服务端配置文件
data:image/s3,"s3://crabby-images/a4d88/a4d8889fbb2b5202245e839ac998090edc910c96" alt=""
eureka服务使用者——各客户端
配置开启@EnableDiscoveryClient
data:image/s3,"s3://crabby-images/d4e8b/d4e8ba0e2e28ebe7e15f641855bf5301b1012535" alt=""
客户端配置
data:image/s3,"s3://crabby-images/ea572/ea572a9b5febd5e2007ee2438dab6a0bcb10654f" alt=""
RestTemplate使用
比如user服务配置跟提供的服务如下
data:image/s3,"s3://crabby-images/2d6dc/2d6dc805285fb24096139ada6cbde92fa285f9a4" alt=""
data:image/s3,"s3://crabby-images/a4605/a4605f6d9e6c32f1118d96f9a0776e2bd8dab402" alt=""
那么在其他服务中调用user服务时
data:image/s3,"s3://crabby-images/f26d6/f26d6024df204041880189c728ccd5993a13c237" alt=""
data:image/s3,"s3://crabby-images/c3ec1/c3ec1a21e25b271b86141db3d9eeb7ff3c16b336" alt=""
2、各服务间调用负载均衡ribbon
data:image/s3,"s3://crabby-images/ef1d0/ef1d0f3fc6003807c913e7526ae5ffd7a99f2be0" alt=""
data:image/s3,"s3://crabby-images/71054/710549f8bd3b2224a624836172227cbeb14c1936" alt=""
比如goods服务调用用户服务ribbon配置
data:image/s3,"s3://crabby-images/d480c/d480cc6229dee5a71fb1d2278ccd8406e798f44d" alt=""
3、服务间调用,申明式Api,Feign
data:image/s3,"s3://crabby-images/d7b3e/d7b3e8e8b2cb87984fe826fbb74cccb5d4f67b4f" alt=""
开启Feign配置
@EnableFeignClients
data:image/s3,"s3://crabby-images/e162a/e162a1de08f3f00fc0a4e27887de3bb3fb24c9bd" alt=""
远程调用
data:image/s3,"s3://crabby-images/4d57a/4d57aa68f4bb565231173809b90adb8217c54aa3" alt=""
也可以如此使用,这样将remote跟dto抽取出去,可以实现代码复用,服务提供者维护接口依赖。也可做为对外开放接口的文档(如果调用方不想直接使用的话);
data:image/s3,"s3://crabby-images/188b5/188b5caa07ec2f866222c6c4cff199cd6066c9e2" alt=""
4、服务间调用,服务熔断hystrix断路器
data:image/s3,"s3://crabby-images/a98d3/a98d3c0ad86b539560b813f77b6809bf85b24949" alt=""
服务开启配置
@EnableHystrix
data:image/s3,"s3://crabby-images/ac65d/ac65dd89cb83b089862ade0579e10a4870f2a7b7" alt=""
data:image/s3,"s3://crabby-images/60715/6071537bd6e8d4ade789b44ccb5303c363ef3900" alt=""
5、微服务网关zuul
对外(web层)提供一个统一的出入口,方便做一些权限校验、安全检查;
data:image/s3,"s3://crabby-images/e7940/e7940d9a3b4eb81c4d5146da681536b0fa51251e" alt=""
配置
@EnableZuulProxy // 开启网关相关功能
@EnableHystrix 开启断路器检验
@EnableDiscoveryClient // 开启服务发现
data:image/s3,"s3://crabby-images/48605/48605a5256696328c8daaed1b47a2ea2431cb1d4" alt=""
ZuulFilter使用
data:image/s3,"s3://crabby-images/e6c58/e6c5853e14f2de2b6c49caa11b1dc35af4fa2608" alt=""
data:image/s3,"s3://crabby-images/cd9ce/cd9ce3e574724192d111275ed771983727180696" alt=""
data:image/s3,"s3://crabby-images/ed9ab/ed9ab1183de008961c415491b39a05002994a127" alt=""
zuul调用服务退回
data:image/s3,"s3://crabby-images/9064b/9064b421bdfda98729b09d5ff6811dfdce58c227" alt=""
为了高可用性,zuul一般也是采用集群部署的;
然后 在 zuul外部 采用nginx做网关的负载均衡器,就基本实现一个分布式微服务系统的构建了;
网友评论