近几年,微服务架构在大量技术社区迅速蹿红,被认为是 IT 软件架构的未来方向。一线互联网公司由于具有大量的业务体量和业务场景,比如阿里、百度、网易,很早就开始入坑微服务架构。
随着云端办公以来,发现微服务越来越重要了。Docker 容器技术和自动化运维等相关技术发展,使微服务变得更容易维护。大家可能都注意到,像阿里、腾讯、字节跳动等大厂的后端岗位明确写出:微服务设计经验优先。如果没有这方面的准备的话,想拿到高薪可不容易。
再者,微服务在技术面试的时候多有提及,尤其对于头部互联网企业,微服务架构更是必备的考核点,如果平时不注意这方面的知识的积累和运用,在跳槽或升职的时候,薪酬会非常吃亏。
目录
微服务概述
从微服务的起源和现实业务的角度探讨微服务,使大家能够对微服务有一个感观的认识
微服务设计原则
针对微服务的设计理念进行整理,包括服务如何折分、前后端分离、 CAP 理论和CQRS 等,是 个高层次的指导原则。
开发篇
微服务之Spring Boot
详细的介绍 Spring Boot 开发,包括使用它的优缺点,以及在企业级开发中常用的工具包的整合,包括面向切面编程、 We 开发、文档管理和调度管理,最后结合 Dubbo 完成一个示例性的分布式工程。
微服务之Docker
主要讲解 Docker 的基础操作,介绍微服务中所用到的容器相关的技术,最后给出通用的基于容器的私有云架构
微服务之Spring Cloud
Spring Cloud 实现微服务的几个重要框架进行展开描述,让读者了解注册中心、负载均衡、容错、分布式配置、网关和消息总线,能够完成开发层面的微服务架构。
微服务之Spring Cloud其他框架
Spring Cloud 的非核心框架进行介绍,包括 Consul ZooKeeper 安全框架和数据流框架。
运维篇
微服务之自动化测试与质量管理
主要对测试和质量管理进行介绍,测试部分包括单元测试、 AIB 测试、冒烟和回归测试,质量管理部分主要使用静态代码分析,并且 SonarQube 对代码进行静态检查, 以及分析代码的总体质量
微服务之JHipster
对微服务的最佳实践 JHipster 进行系统的介绍,并且对 JHip ter 部分内容做了处理,将在国内不是很流行的部分进行了处理,尽可能详细地介绍 JHipster 应用和配置。
微服务之自动化部署
主要对自动化部署进行介绍,因为微服务的目的不仅仅是简化开发,而且能够提高整个团队的运行效率。所 以私服的使用和自动化运维就显得非常重要。
微服务之日志收集与监控
主要讲解日志收集 APM 监控,对于线上系统来说,出现问题的概率还是非常大的,如何快速定位并第 时间找到问题所在的点就显得非常重要。 APM 部分对常用的监控工进行列举,重点介绍 Pinpoint 对使用和邮件告警也进行了重点介绍。
实战篇
完整示例
过对 PiggyMetrics 的全面讲解,让读者能够了解 个简单的微服务架构所包含的技术点和构建原则,并且实际部署微服务,完成业务的基础操作
微服务核心功能推荐
对在微服务构建过程中可能涉及的技术点进行讲解,包括工作流引擎、规则引擎、调度系统、分布式配置及单点登录。
微服务是当下最火热的后端架构之一。不管你是一个什么级别的程序员,也不论你在一个什么体量的公司,服务化都是你迟早会遇到的难题。实践微服务的过程本身也是一个升级打怪的过程,这中间你会遇到基本上所有后端架构的问题。解决了这些问题,你自然也就理解了那些高深的概念,也就成为了一名架构师,成长和能力提升都是这个过程的附属品。
从分布式服务到 SOA ,再到微服务,服务化的脚步 直在不断地前进 正所谓“分久必合,合久必分”,在企业高速发展的今天,单体架构已经很难适应业务的快速变化,微服务的出现,为应对快速变化的业务需求、冗长的开发周期提供了一种新的解决方案。它以模块化的思维应对快速变化的业务需求,使用比如自动化部署、自动化业务监控预警、调用链监控、容器化,以及快速开发等思想加快软件的开发周期,实现更快速、更高质 的交付,整体提高客户的满意度
总目录:
不难预料,今年,微服务只会越来越完善,成为将来大中型企业业务架构的发展方向。但对于一些 coding 的朋友,由于接触不到一线实战架构设计,眼看别人都在向微服务架构转型,自己却只能日复一日地重复造轮子。