springcloud

Posted linzx2015

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springcloud相关的知识,希望对你有一定的参考价值。

中文文档:https://springcloud.cc/spring-cloud-dalston.html
访问eureka不用加项目名:http://localhost:8761/ 
1.与dubbo对比
技术图片
2.服务架构
技术图片
Eureka:服务注册中心,完成服务注册、发现、调用  
   访问https://start.spring.io 出现一直失败时,可改成http形式
   Eureka Server:作为注册中心,提供给服务注册,mvn clean package后可到对应eureka项目目录下打成jar包,通过java -jar eureka.jar启动作为服务
    技术图片
    技术图片
    技术图片
   Eureka Client:服务提供者和消费者
   @EnableEurekaClient
Ribbon:完成负载均衡;RestTemplate、Feign、Zuul都使用到了Ribbon,@LoadBalanced
    a.服务发现  b.服务选择  c.服务监听
    ServerList获取服务列表,再通过ServerListFilter过滤部分服务,最后通过IRule选择一个实例作为最终目标
Zuul:实现网关作用,反爬虫等作用
Hystrix:实现服务熔断、降级(资源紧张时,下调非必要服务)、限流
Hystrix Dashboard:服务流量管控台
Config Server:管理配置
Sleuth:请求日志、服务请求时长等
3.请求耗时比较
技术图片
4.Eureka架构:
Application Service:向Eureka Server完成服务提供
Application Client:从Eureka Server调用服务
Eureka Server:服务注册中心
技术图片
分布式系统中为什么需要服务发现?
技术图片
技术图片
 微服务的特点:异构
  1.不同语言
  2.不同类型的数据库
服务拆分理论:如何拆"数据"
1.每个服务都有单独的数据存储
2.依据服务特点选择不同的结构选择的数据库类型
3.难点在于边界
   服务注册到eureka后,不重启无法清理服务列表?
技术图片
两个提供者,分别8100和8200
6.服务如何拆分:
   起点:既有架构的形态
   终点:好的架构不是设计出来的,而是进化(演化)而来的
   适不适合微服务?
        业务形态不适合的:
           1.系统中包含很多强事务场景  2.业务想对稳定、迭代周期长  3.访问压力不大,可用性要求不高
    康威定律:任何组织在设计一套系统(广义概念上的系统)时,所交付的设计方案在结构上都与该组织的沟通结构保持一致。
     微服务的特点:
            1.一系列的微小的服务共同组成   2.单独部署,跑在自己的进程里  3.每个服务为独立的业务开发  4.分布式的管理
     服务拆分的方法论:
         如何拆分功能:
                1.单一职责、松耦合、高内聚
                2.关注点分离(职责(订单)、通用性(消息)、粒度)
         服务和数据的关系:
                1.先考虑业务功能,再考虑数据
                2.无状态服务(有->无)
        技术图片
 启动两个client,需要配置不同的端口,否则都会去使用8080,后启动的会报错
server配置了server.port,client如果也要配置server.port,两者端口不能一样。
7.服务间调用:
      RestTemplate:
        第一种:
         技术图片
        第二种:
         技术图片
        第三种:
        技术图片
        技术图片
        技术图片
      Feign:注意pom依赖版本,伪RPC,声明式加注解式RPC
        技术图片
        技术图片
        技术图片
        技术图片
        技术图片
        技术图片
        当无参、@RequestParam、 @PathVariable可使用GetMapping
         服务调用方:
         技术图片
         服务提供方:
         技术图片
 应用间通信:通过客户端负载均衡器 Ribbon
     1.ServerList->IRule->ServerListFilter
     2.RestTemplate,   Feign    Zuul都用到了Ribbon(@LoadBalance)
8.配置中心:远端git->config server->本地git
   a.为什么要用配置中心:不方便维护,配置内容安全与权限,更新配置项目需要重启
   b.当做eureka客户端,注册到eureka,增加@EnableDiscoveryClient和@EnableConfigServer
      技术图片
   c.git仓库创建config.yml,启动配置中心后浏览器访问:http://localhost:8080/config-a.yml(-a的a可随意,但一定要写一个)
      技术图片
     技术图片
   d.客户端读取配置中心数据:配置中心config.yml可作为config-dev.yml的通用配置,不然每次都会被加载过来,但不能自动刷新
      技术图片
   e.spring cloud bus能支持自动刷新,增加完spring-cloud-bus组件后,在rabbitmq上会相应多一个队列
     技术图片
    config项目上增加就能暴露 /bus-refresh;客户端增加@RefreshScope
    技术图片技术图片
    技术图片
9.异步:客户端请求不会阻塞进程,服务端的响应可以是非即时的
   常见形式:1.通知    2.请求/异步响应   3.消息(MQ)
   MQ应用场景:1.异步处理:用户注册后发短信、加积分等    2.流量削峰:秒杀    3.日志处理(最常见kafka)    4.应用解耦:订单系统完成下单,发消息到商品服务扣库存等
   rabbitMq:需管控台新建队列myQueue,增加queuesToDeclare可自动创建队列
    技术图片
    技术图片技术图片
    技术图片
10.maven依赖自动补全:File->setting->maven->repositories,选择本地仓库,点击右上角更新,更新maven仓库索引
springCloud对消息中间件进行封装,代码层面做到对中间件无感知,目前Binder支持rabbitmq(项目启动时会管控台会多一个myMessage队列)和kafka;
    技术图片技术图片
发送方:
@RestController
public class MessageProductController {
@Autowired
private StreamClient streamClient;
@GetMapping("/sendMessage")
public void process(){
streamClient.output().send(MessageBuilder.withPayload("aa").build());
}
}
    接收方:以上对多台服务器接收消息会每台都收到消息,yml对一台机器增加spring.stream.bindings.myMessage.group:order防止重复消费消息 
    技术图片
    rabbitmq中的消息是base64转码过的数据,不直观,yml增加spring.stream.bindings.myMessage.content-type:application/json实现mq中json数据展示    技术图片
异步扣库存:
    技术图片
11.网关方案:
    a.nginx(负载均衡)+lua-->Kong(扩展,商业)
    b.Tyk:开源,支持认证,多用户多组织分析,go语言
    c.zuul(路由+过滤器):java+微服务,认证,协作单点压测等,快速上手,性能比nginx稍差;cookie无法传到后端;也可使用Hystrix超时配置
       技术图片技术图片
       1.增加@EnableZuulProxy作为网关代理,访问http://ip:zuul端口/目标eureka实例/url可完成跳转;RefreshSocpe是动态加载配置中心数据
        技术图片
        技术图片zuul.sensitive-headers: 设置为null,所有服务都可传cookie等信息
        技术图片
        技术图片可实现访问全部路由:http://localhost:9000/application/routes
      前置过滤器:限流、鉴权
      后置过滤器:统计
      高可用:多台注册
      技术图片
    自定义token的pre过滤器:
    技术图片
    自定义post的过滤器:
    技术图片
    限流时机:在请求被转发之前调用;开源限流项目:https://github.com/marcosbarbero/spring-cloud-zuul-ratelimit 
    令牌桶限流:
    技术图片
     技术图片
    跨域问题:通用方案:https://www.imooc.com/learn/947 
        1.在被调用的类或方法上增加@CrossOrigin注解(@CrossOrigin(allowCredentials = "true")cookie跨域传),缺点:只针对加了注解的类或方法有效
        2.在Zuul中增加ZuulFilter过滤器或者nginx中解决跨域问题
        技术图片
12.服务容错与Hystrix:
    a.雪崩效应:a->b->c,c崩溃后,最终导致ab都不可用
    b.Hystrix:
       1.服务降级:网络开小差等提示,优先核心服务,非核心服务不可用或弱可用,通过HystrixCommand注解指定,fallbackMethod中实现降级逻辑
       技术图片技术图片
       默认处理:
       技术图片
    2.依赖隔离:
        a.线程池隔离:Hstrix自动实现了依赖隔离
        技术图片
        技术图片
        hystrix管控台:
        技术图片
        有引入cloud-stream的话,就不需要再引入
        技术图片
        技术图片
        技术图片
        yml增加management.context-path:/  
技术图片
         最终视图:
        技术图片
13.服务追踪:
     1.SpringCloud Sleuth:
       技术图片
        调整Feign的日志级别:
        技术图片

















































以上是关于springcloud的主要内容,如果未能解决你的问题,请参考以下文章

SpringCloud系列四:Eureka 服务发现框架(定义 Eureka 服务端Eureka 服务信息Eureka 发现管理Eureka 安全配置Eureka-HA(高可用) 机制Eur(代码片段

SpringCloud+Feign环境下文件上传与form-data同时存在的解决办法

SpringCloud环境搭建服务提供者 我们需要拿到实体类,所以要配置api module, 在这时报错

springcloud项目多个微服务中,jwt鉴权的代码应该放在哪个服务中?

微信小程序代码片段

VSCode自定义代码片段——CSS选择器