Spring Cloud,Docker书籍资源、优秀博文等记录

一、书籍

周立 Docker 开源书

使用Spring Cloud与Docker实战微服务

二、博文地址

系列教程:

  1. Docker系列教程
  2. Spring Cloud系列教程
  3. 博客园:雪雁:Docker最全教程

搭建教程:

  1. Centos7下安装Docker(详细安装教程)
  2. docker安装常用组件(mysql,redis,postgres,rancher,Portainer,蝉道,JIRA,sonarqube,Confluence,pgadmin4)

学习教程:

  1. CSDN:数据架构师:docker教程,dockerfile教程
  2. CSDN:Docker通过容器生成镜像(通过容器提交(docker commit)成镜像)
  3. CSDN:查看Docker容器使用资源情况–docker stats
  4. 博客园:SpringCloud系列教程

三、思维导图Or图片

3.1一张图总结 Docker 的命令

Spring Cloud


部分内容原文地址:

博客园:程序开发者社区:Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览


Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,领导选举,分布式会话,集群状态)。分布式系统的协调导致了样板模式,使用Spring Cloud开发人员可以快速站起来实现这些模式的服务和应用程序。它们适用于任何分布式环境,包括开发人员自己的笔记本电脑,裸机数据中心和Cloud Foundry等托管平台。

1、Spring Cloud组件

Spring Cloud构建微服务是基于SpringBoot开发的,服务之间通过基于HTTP的RESTFUL API进行通信协作的。

Spring Cloud组件由20多个组件组成的,常用的组件有如下:

主要:

  • Eureka:服务注册中心,特性有失效剔除、服务保护
  • Dashboard,Hystrix仪表盘:监控集群模式和单点模式,其中集群模式需要收集器Turbine配合
  • Zuul:API服务网关,功能有路由分发和过滤
  • Config:分布式配置中心,支持本地仓库、SVN、Git、Jar包内配置等模式

融合:

融合在每个微服务中、依赖其它组件并为其提供服务。

  • Ribbon:客户端负载均衡,特性有区域亲和、重试机制
  • Hystrix:客户端容错保护,特性有服务降级、服务熔断、请求缓存、请求合并、依赖隔离
  • Feign:声明式服务调用,本质上就是Ribbon+Hystrix,类似于Dubbo的调用
  • Stream:消息驱动,有Sink、Source、Processor三种通道,特性有订阅发布、消费组、消息分区
  • Bus:消息总线,配合Config仓库修改的一种Stream实现
  • Sleuth:分布式服务追踪,需要搞清楚TraceID和SpanID以及抽样,并且与ZipKin整合
  • SpringBoot的SpringBoot Admin(一个管理和监控 Spring Boot 应用程序的开源项目)

每个组件都不是平白无故的产生的,是为了解决某一特定的问题而存在:

  • Eureka:分为客户端和服务端,客户端是一个java客户端,用来连接Eureka服务端(说白了服务端就是Eureka注册中心),与服务端进行交互,负载均衡,服务的故障切换等。。。作用类似于zookeeper

  • Ribbon:是一个基于HTTP和TCP的客户端负载均衡器,当使用Ribbon对服务进行访问的时候,他会扩展Eureka客户端的服务发现功能,实现从Eureka注册中心获取服务端列表,并通过Eureka客户端来确定服务端是否已经启动。Ribbon在Eureka客户端服务发现的基础上,实现对服务实例的选择策略,从而实现对服务的负载均衡消费。

    Eureka和Ribbon,是最基础的组件,一个注册服务,一个负载均衡消费服务。

  • Hystrix(断路器/熔断器):为了优化Ribbon、防止整个微服务架构因为某个服务节点的问题导致崩溃,是个保险丝的作用,防止服务雪崩。

  • Dashboard:给Hystrix统计和展示用的,而且监控服务节点的整体压力和健康情况。

  • Turbine:是集群收集器,服务于Dashboard的。

  • Feign:是Netflix公司开发的一个声明式的REST调用客户端,Ribbon负载均衡,Hystrix服务熔断是Spring Cloud中进行微服务开发的最基础的组件,在使用过程中我一般发现他们都是一起存在的,而且配置也相似,每次开发都有相同的代码,因此Spring Cloud基于Netflix Feign整合了Ribbon和Hystrix两个组件,让开发更简单

  • Zuul:是加在整个微服务最前沿的防火墙和代理器,隐藏微服务结点IP端口信息,加强安全保护的。

  • Config:是为了解决所有微服务各自维护各自的配置,设置一个统一的配置中心,方便修改配置的。

  • Bus:是因为config修改完配置后各个结点都要refresh才能生效实在太麻烦,所以交给bus来通知服务节点刷新配置的。

  • Stream:是为了简化研发人员对MQ使用的复杂度,弱化MQ的差异性,达到程序和MQ松耦合。目前只支持RabbitMQ和Kafka

  • Sleuth:是因为单次请求在微服务节点中跳转无法追溯,解决任务链日志追踪问题的

2、SpringCloud架构图

Spring Cloud,Docker书籍资源、优秀博文等记录的更多相关文章

  1. spring cloud+docker 简单说一说

    spring boot 微服务开发工具 spring cloud 微服务框架治理工具集 这么做: 1.搭建spring cloud 基础组件(服务发现,服务注册,服务配置,监控,追踪,API网关) 以 ...

  2. 分享spring、spring boot、spring cloud一些学习资源,从基础知识到项目实战

    1.spring注解驱动开发,学习spring boot和spring cloud必备知识 链接: https://pan.baidu.com/s/1xhULzLlpkERhoMi1G5Lgfg 密码 ...

  3. Spring Cloud,Docker

    Spring Cloud 先决条件 Spring cloud 基于spring boot,spring,java Spring Cloud解决的问题 分布式微服务架构和微服务监控.注册于发现.跟踪等一 ...

  4. docker kubernetes swarm spring cloud结合学习资源

    http://www.docin.com/p-2062732301.html https://blog.csdn.net/michael_hm/article/details/79213839 htt ...

  5. [转]Spring Cloud在国内中小型公司能用起来吗?

    原文地址:http://www.cnblogs.com/ityouknow/p/7508306.html 原文地址:https://www.zhihu.com/question/61403505 今天 ...

  6. Spring Cloud在国内中小型公司能用起来吗?

    今天吃完饭休息的时候瞎逛知乎,突然看到这个一个问题Spring Cloud在国内中小型公司能用起来吗?,吸引了我的注意.仔细的看了题主的问题,发现这是一个好问题,题主经过了一番思考,并且用图形全面的将 ...

  7. 写给大忙人的spring cloud 1.x学习指南

    这几天抽空搞了下spring cloud 1.x(2.0目前应该来说还不成熟),因为之前项目中使用dubbo以及自研的rpc框架,所以总体下来还是比较顺利,加上spring boot,不算笔记整理,三 ...

  8. Spring Cloud在国内中小型公司用的起来吗?

    转自:http://www.cnblogs.com/ityouknow/p/7508306.html 今天吃完饭休息的时候瞎逛知乎,突然看到这个一个问题Spring Cloud在国内中小型公司能用起来 ...

  9. Spring Cloud 与 Spring boot - 转载

    微服务是这样一个结构吗? 前端或二方 - > ng集群 -> zuul集群 -> eureka-server集群 -> service provider集群 (二方指其他业务部 ...

随机推荐

  1. 【NC基础操作】开发环境配置初体验

    当我们拿到开发工具UAP-STUDIO-6.5.0.2和Home文件的时候,意味着我们可以用这两样东西开始进行项目开发了(默认其他准备已就绪). 运行UAP-STUDIO-6.5.0.2 双击进入&q ...

  2. 01 . Go之从零实现Web框架(框架雏形, 上下文Context,路由)

    设计一个框架 大部分时候,我们需要实现一个 Web 应用,第一反应是应该使用哪个框架.不同的框架设计理念和提供的功能有很大的差别.比如 Python 语言的 django和flask,前者大而全,后者 ...

  3. MAC与ARP缓存中毒介绍

    ARP 协议 用于地址解析,请求MAC地址. arp -a 或者 -n 查看ARP缓存表 ls(ARP) 查看scapy里的协议字段 ARP缓存中毒原理 ARP收到ARP请求报文,会将发送方的mac地 ...

  4. 使用python做一个IRC在线下载器

    使用python做一个IRC在线下载器 1.开发流程 2.软件流程 3.开始 3.0 准备工作 3.1寻找API接口 3.2 文件模块 3.2.1 选择文件弹窗 3.2.2 提取文件名 3.2.2.1 ...

  5. 服务器报错"您的主机中的软件中止了一个已建立的连接"

    网上很多的说法都模棱两可,只是说和远程连接有关,这个说的太泛泛了. 我现在遇到的问题是java web出现的, 执行表单提交的时候出现该错误,原因是ajax和表单同时提交导致的, 相信很多朋友用了aj ...

  6. Server 2012 R2 Standard 安装运行PCS7时出现“无法启动此程序,因为计算机中丢失api-ms-win-crt-runtime-l1-1-0.dll”解决方法

    网上看到了这篇文章https://www.jianshu.com/p/21f4bb8b5502,根据思路自己尝试,解决了丢失的问题.提示[计算机中丢失api-ms-win-crt-runtime-l1 ...

  7. 【MyBatis】MyBatis 连接池和事务控制

    MyBatis 连接池和事务控制 文章源码 MyBaits 连接池 实际开发中都会使用连接池,因为它可以减少获取连接所消耗的时间.具体可查看 MyBatis 数据源配置在 SqlMapConfig.x ...

  8. Docker学习笔记之向服务器部署应用程序

    部署的应用仅仅是简单应用程序,使用的是node管理的web应用,具体我也不是很会,当然也可以配置tomcat服务器.这里主要是学习docker.需要客户机和服务机,其中服务机必须要为Linux操作系统 ...

  9. python学习笔记 | 国内常用源镜像地址

    各镜像列表 清华:https://pypi.tuna.tsinghua.edu.cn/simple 阿里云:http://mirrors.aliyun.com/pypi/simple/ 中国科技大学 ...

  10. 跟我一起学Redis之加个哨兵让主从复制更加高可用

    前言 主从复制的实现在上一篇已经分享过,虽然主从复制本身的确让读写分离更加高效,但是对于整体高可用存在很大的劣势:当主节点宕机了之后还需要人为重新进行主从关系配置:这不是开玩笑嘛,这样人为干预,故障恢 ...