文档章节

微服务、容器与容器云-从入门到放弃

Soi
 Soi
发布于 2017/09/11 09:10
字数 1115
阅读 8
收藏 1
点赞 0
评论 0

前言

驱动技术的,从来都不应该是技术,也不是情怀,应该是不断变化的诉求。

在过去的不知道多少年前,我们的应用和数据库,还部署在一台机器上,大概如下:

+----------+                   +--------------+
|          |                   |              |
|          |                   |              |
|          |                   |  +--------+  |
|          +--------------------> |        |  |
|          |                   |  |  App   |  |
|          | <------------------+ | ^    + |  |
|  Client  |                   |  +--------+  |
|          |                   |    |    |    |
|          |                   |  +--------+  |
|          |                   |  | +    v |  |
|          |                   |  |   DB   |  |
|          |                   |  |        |  |
|          |                   |  +--------+  |
|          |                   |              |
|          |                   |     Server   |
+----------+                   +--------------+

随着业务的增长,这样的架构已经不能满足大量的请求,这时候架构也随之改变,把应用与数据库拆分开来:

+--------+               +---------+             +-------+
|        |               |         |             |       |
|        +-------------> |         +-----------> |       |
| Client |               |   App   |             |   DB  |
|        | <-------------+         | <-----------+       |
|        |               |         |             |       |
+--------+               +---------+             +-------+

当然,业务是不停的增长的,而上述这样的也会发生变化,可以把应用与数据库进行集群部署。

然后...

不搭的后语

而如今,技术与架构,在业务的驱动下,早已发生了巨大的变化。

在最近两年,最火的,莫过于服务化,容器化与云化。

微服务

微服务架构,它把软件围绕业务功能结构进行划分、拆解成服务,以服务构建应用,而服务可以独立部署、独立扩展,服务也可以提供模块化的边界,并且不同的使用也可以使用不同的开发语言。

微服务风格的特性:

  • 组件与服务
  • 围绕业务功能进行组织
  • 产品不是项目
  • 强化终端及弱化通道
  • 分散治理
  • 分散数据管理
  • 基础设施自动化
  • 容错性设计
  • 设计改进

容器

容器,另一个热门的话题,而在这个话题中,我们能够快速想到的,应该是Docker。

Docker 最初是 dotCloud 公司创始人 Solomon Hykes 在法国期间发起的一个公司内部项目,它是基于 dotCloud 公司多年云服务技术的一次革新,并于 2013 年 3月以 Apache 2.0 授权协议开源。

Docker包括三个基本概念镜像、容器、仓库。镜像和容器的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实例;容器可以被创建、启动、停止、删除、暂停等;而仓库,则是用来统一存储镜像,进行版本控制。

使用容器技术,带来了以下好处:

  • 持续部署与测试
  • 跨云平台支持
  • 环境标准化和版本控制
  • 高资源利用率与隔离
  • 简单易用
  • ...

容器云

容器云是以容器为资源分割和调度的基本单位,封装整个软件运行时环境,为开发者和系统管理员提供用于构建、发布和运行分布式运用的平台。

当容器云专注于资源共享与隔离、容器编排与部署时,它更接近传统的IaaS;当容器云渗透到应用支撑与运行时环境时,它更接近传统的PaaS。

使用容器云,带来了以下好处:

  • 更高效的利用系统资源
  • 更快速的启动时间
  • 一致的运行环境
  • 持续交付和部署
  • 更轻松的迁移
  • 更轻松的维护和扩展。

服务化,容器化与云化

当软件服务化后,我们的架构看起来应该是这样的:

+-------+  +--------------------------------------+ +--------------------------+
|       |  |                                      | |                          |
|       |  |                WebUI                 | |         App              |
|       |  |                                      | |                          |
|       |  +--------------------------------------+ +--------------------------+
|       |
|       |  +-------------------------------------------------------------------+
|       |  |                                                                   |
|       |  |                            RESTful API                            |
|       |  +-------------------------------------------------------------------+
|       |
|       |  +-----------+  +-----------------------------------+  +-------------+
|       |  |           |  |  +-----------+    +------------+  |  |             |
|Monitor|  | Registry  |  |  | Ser^ice1  |    |  Ser^ice2  |  |  |  Configure  |
|       |  | &         |  |  +-----------+    +------------+  |  |             |
|       |  | Dsco^ery  |  |                                   |  |             |
|       |  |           |  |  +-----------+                    |  |             |
|       |  |           |  |  |   ...     |     Ser^ices       |  |             |
|       |  |           |  |  +-----------+                    |  |             |
|       |  |           |  |                                   |  |             |
|       |  |           |  |                                   |  |             |
|       |  +-----------+  +-----------------------------------+  +-------------+
|       |
|       |  +-------------------------------------------------------------------+
|       |  |  +-------------+   +------------+    +----------+                 |
|       |  |  |     DB      |   |     MQ     |    |    ...   |                 |
|       |  |  +-------------+   +------------+    +----------+                 |
+-------+  +-------------------------------------------------------------------+

众多的服务给运维带来极大的挑战,要求能够快速地发布与容错处理,而如果再使用人肉运维的方式再也无法满足。

这时候,一个借助于CI/CD的研发流水线的开发方式,渐渐进入了视野:

    +--------------+           +------------+ Re^iew  +--------------+
    |              |           |            +-------> |              |
    |  Developer   |  Push     |            |         |  Maintainer  |
    |              +-------->  |   Repo     | Merge   |              |
    |              |           |            | <----+  |              |
    +------+-------+           +-----+------+         +--------------+
           ^                         |
           |                         |
           |                         v  Trigger
           |
           |                   +------------+
    Feedback                   |            |
           |         CI        |            |     CD
           |        +----------+   CI/CD    +-------------+
           |        |          |            |             |
           |        v          +------------+             v
           |
+-------------------------------+        +--------------------------------------+
|-------+ +-------+ +--------+  |        |                                      |
||Build +-> Unit  +->Analyze +-+|        | +---------+ +---------+ +---------+  |
|-------+ +-------+ +--------+ ||        | |Test Env | |UAT Env  | |Production  |
|-------+ +-------+ +--------+ ||        | |         | |         | |         |  |
||Deploy<-+Package<-+  Test  <-+|        | +---------+ +---------+ +---------+  |
|-------+ +-------+ +--------+  |        |                                      |
+-------------------------------+        +--------------------------------------+

可以借助容器与容器云,将服务进行持续集成、持续部署与交付,最终达到自动化。

放弃

服务化是未来吗?容器是未来吗?容器云是未来吗?

谁知道呢?未来,还没来!

只是现在,作为一枚面向搜索引擎复制粘贴的开发者,在不停的学习中,开拓自己的视野,积累自己的经验,为后来的业务需求打下坚实的基础也是势在必行。


参考:

微服务(Microservices)

《Docker——容器与容器云》试读:1.3 进化:从容器到容器云

本文转载自:https://ronggle.com/2017/05/22/microservice-container-and-container-cloud/

共有 人打赏支持
Soi

Soi

粉丝 16
博文 11
码字总数 4845
作品 0
合川
微服务、容器和云开启了IT架构的新纪元

  【IT168 资讯】今年非常流行微服务、容器和云。Evans Data Corp在6月份进行的一项调查显示,近半数的云开发人员正在使用不可变的架构和微服务。包括Google、IBM、Lyft和Apache等大型科技...

it168网站 ⋅ 2017/12/28 ⋅ 0

2017 年,开启了 IT 架构的新纪元

今年,微服务,容器和云非常普遍。6月份,Evans Data Corp 进行的一项调查显示,几乎一半的云开发人员正在使用不可变的架构和微服务。有几项新服务是用于管理微服务,包括一些大的科技公司的...

周其 ⋅ 2017/12/28 ⋅ 4

聚焦“微服务与容器云” 2017CIO时代线下CIO沙龙顺利举行

2017年2月23日下午,CIO时代2017年第一场线下CIO沙龙在上海复旦大学老逸夫楼顺利举行。本次活动主题聚焦“微服务与容器云”,来自复旦大学、CIO时代学院、上海电气、上海汽车、港中旅华贸货运...

玄学酱 ⋅ 04/18 ⋅ 0

网易容器云平台的微服务化实践

摘要:网易云容器平台期望能给实施了微服务架构的团队提供完整的解决方案和闭环的用户体验,为此从 2016 年开始,我们容器服务团队内部率先开始进行 dogfooding 实践,看看容器云平台能不能支...

fl63zv9zou86950w ⋅ 2017/12/15 ⋅ 0

云原生概述

1. 什么是云原生 1.1 CNCF组织 在讲云原生之前,我们先了解一下CNCF,即云原生计算基金会,2015年由谷歌牵头成立,基金会成员目前已有一百多企业与机构,包括亚马逊、微软。思科等巨头。 cn...

aoho ⋅ 2017/12/25 ⋅ 0

云原生架构概述

云原生架构概述 Harries Blog™2017-12-251 阅读 SpringcatAPIDockerCassandra 1. 什么是 云 原生 1.1 CNCF 组织 在讲云原生之前,我们先了解一下CNCF,即云原生计算 基金 会, 2015 年由 谷...

Harries Blog™ ⋅ 2017/12/25 ⋅ 0

阿里云Kubernetes Service Mesh实践进行时(6): 故障诊断与检测工具Weave Scope

概述 本系列文章已经通过一个官方示例演示了如何部署应用到上述Istio环境中,并演示了如何设置智能路由、分布式追踪以及Istio 的遥测数据收集、查询及可视化等功能。 阿里云Kubernetes Serv...

osswangxining ⋅ 06/06 ⋅ 0

直播 | 为什么Kubernetes天然适合微服务

分享时间:3月13日 20:30 分享主题:为什么Kubernetes天然适合微服务 分享人介绍:刘超,网易云解决方案总架构师。毕业于上海交通大学,15年云计算领域研发及架构经验,先后在EMC、CCTV证券资...

Docker ⋅ 03/12 ⋅ 0

Cloud Native 世界顶级开源项目

CNCF 是什么? CNCF 是一个开源软件基金会,致力于使云原生计算具有普遍性和可持续性。 云原生计算使用开源软件技术栈将应用程序部署为微服务,将每个部分打包到自己的容器中,并动态编排这些...

Docker ⋅ 04/22 ⋅ 0

活动干货|基于Docker的DevOps实现

作者:精灵云 众所周知,传统开发模式已经面临了诸多难题。首先,在代码集成方面,因为没有合适粒度的代码合并,大规模的合并会有很大的风险,且传统开发模式中没有自动化测试,以至于测试周...

精灵云 ⋅ 2017/03/16 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

用ZBLOG2.3博客写读书笔记网站能创造今日头条的辉煌吗?

最近两年,著名的自媒体网站今日头条可以说是火得一塌糊涂,虽然从目前来看也遇到了一点瓶颈,毕竟发展到了一定的规模,继续增长就更加难了,但如今的今日头条规模和流量已经非常大了。 我们...

原创小博客 ⋅ 今天 ⋅ 0

MyBatis四大核心概念

本文讲解 MyBatis 四大核心概念(SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession、Mapper)。 MyBatis 作为互联网数据库映射工具界的“上古神器”,训有四大“神兽”,谓之:Sql...

waylau ⋅ 今天 ⋅ 0

以太坊java开发包web3j简介

web3j(org.web3j)是Java版本的以太坊JSON RPC接口协议封装实现,如果需要将你的Java应用或安卓应用接入以太坊,或者希望用java开发一个钱包应用,那么用web3j就对了。 web3j的功能相当完整...

汇智网教程 ⋅ 今天 ⋅ 0

2个线程交替打印100以内的数字

重点提示: 线程的本质上只是一个壳子,真正的逻辑其实在“竞态条件”中。 举个例子,比如本题中的打印,那么在竞态条件中,我只需要一个方法即可; 假如我的需求是2个线程,一个+1,一个-1,...

Germmy ⋅ 今天 ⋅ 0

Springboot2 之 Spring Data Redis 实现消息队列——发布/订阅模式

一般来说,消息队列有两种场景,一种是发布者订阅者模式,一种是生产者消费者模式,这里利用redis消息“发布/订阅”来简单实现订阅者模式。 实现之前先过过 redis 发布订阅的一些基础概念和操...

Simonton ⋅ 今天 ⋅ 0

error:Could not find gradle

一.更新Android Studio后打开Project,报如下错误: Error: Could not find com.android.tools.build:gradle:2.2.1. Searched in the following locations: file:/D:/software/android/andro......

Yao--靠自己 ⋅ 昨天 ⋅ 0

Spring boot 项目打包及引入本地jar包

Spring Boot 项目打包以及引入本地Jar包 [TOC] 上篇文章提到 Maven 项目添加本地jar包的三种方式 ,本篇文章记录下在实际项目中的应用。 spring boot 打包方式 我们知道,传统应用可以将程序...

Os_yxguang ⋅ 昨天 ⋅ 0

常见数据结构(二)-树(二叉树,红黑树,B树)

本文介绍数据结构中几种常见的树:二分查找树,2-3树,红黑树,B树 写在前面 本文所有图片均截图自coursera上普林斯顿的课程《Algorithms, Part I》中的Slides 相关命题的证明可参考《算法(第...

浮躁的码农 ⋅ 昨天 ⋅ 0

android -------- 混淆打包报错 (warning - InnerClass ...)

最近做Android混淆打包遇到一些问题,Android Sdutio 3.1 版本打包的 错误如下: Android studio warning - InnerClass annotations are missing corresponding EnclosingMember annotation......

切切歆语 ⋅ 昨天 ⋅ 0

eclipse酷炫大法之设置主题、皮肤

eclipse酷炫大法 目前两款不错的eclipse 1.系统设置 Window->Preferences->General->Appearance 2.Eclipse Marketplace下载【推荐】 Help->Eclipse Marketplace->搜索‘theme’进行安装 比如......

anlve ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部