写点什么

用 Docker 和 Kubernetes 重做云服务

  • 2020-03-12
  • 本文字数:2505 字

    阅读完需:约 8 分钟

用Docker和Kubernetes重做云服务

重做云服务

在之前的博客中,我写过开源软件如何作为服务被交付,而不是从二进制文件角度来看它们。这些开源服务交付一个免费、开放、灵活的服务,工程师用来帮助创建他们的应用程序,这个过程不需要解决保持软件持续运行的问题。


今天我们来谈进一步的话题,新一代的云服务:Anywhere Cloud Services,即随处安放的云,这一切多亏有了 Docker 和 Kubernetes。

现目前云服务在哪里

现在的应用程序水平云服务,比如说 AWS 的 Kinesis 或者是谷歌的 BigTable,会提供全面管理服务给工程师,在这里你可以在不需要努力维护的基础上创建一个应用程序。这些服务不仅安全、自动调度的、被监控的,登陆中的,还是整合好的,已更新的。个人来说,我爱死这些服务了。但是……


  • 你可以通过代码锁定这些服务(比如,修改数据库备份的时候需要修改软件)

  • 选择一家公有云服务,同时也会要求强制使用他们的硬件。所以,要是你的应用是在微软 Azure 上运行,但是私心却比较偏爱 Big Table,那怎么办?

  • 如果你想要使用开源软件,但是又不想自己操作,调度,也不想自己给开源软件提供安全措施怎么办?

  • 让我们进入 Anywhere Cloud Service。

模型 No.2——Anywhere Cloud Services

anywhere cloud service 服务是全面管理服务,这个管理服务可以在任意地方交付,它有三个特点:


全面托管——用户不需要担心保持服务在线这个事情。服务提供商会承担这个责任。


可以运行在任何地方——用户选择服务所在的地方。可能是主要的云提供商的其中一个,或者是带有标准 API 的私有云。在运行的基础设施中有一个清晰的分界:


被当作 service,而不是软件——以明显可消耗的方法来为使用者提供一个功能。比如,一个 No SQL 服务提供注入数据的方法,并且解析数据。这个服务会自我治愈。当被需要的时候它会自己调度。它为使用者提供指标,日志和警报。这也是高度可用的。安装这个服务跟运行一个命令行或者点击一个按钮一样简单可操作。

举一些例子

为了帮助阐述这个 idea,这里是一些我们可能不久之后就会看到的例子:


  • AWS 上的任意的非基础设施,比如说,No SQL DynamoDB 服务,可以提供在其他所有云提供商上。比如,Azure,谷歌云等等。

  • 谷歌的非基础设施服务,比如他们的 PaaS App Engine,可以被部署在任意公有云上,甚至可以通过 openstack 部署到本地数据中心。

  • 初创公司在 Docker 容器空间后,创建了可以在任意公有云或者私有云上运行你的应用程序/代码的服务。

  • 出于想要受益于开源软件的原因,开发团队决定使用在 Kafka,Spark 和 Cassandra 的数据栈。然而,他们并不想自己雇咨询公司或者自己操作。所以,有些初创公司专门研究在任意期望的位置提供这些软件,他们使用的就是这些初创公司做的新服务。

  • 这些开源软件的创造者会打包他们的软件,这样的话,除了处理源代码和二进制文件,软件可以像配置服务一样轻松。这些公司同时也将花费成本提供这些 service 的“支持”版本。

  • 以上这些皆有可能,多亏 Anywhere Cloud Service。

那么,我们如何做到 Anywhere Cloud Service (ACS)

在到达 ACS 的过程中,有两大障碍:


1、如何用标准和有效的方式跨越多个云服务商,在硬件的前提下,来打包和配置软服务。


2、怎样使用有效的方式来打包、运行、配置、调度和确保你的服务的安全性。

进入 Docker 和 Kubernetes 环节

Docker 令我们可以快速的创建,打包和通过特殊方式打包在多个系统上运行软件。通过使用容器,云服务提供商可以在任意环境运行他们的软件。但是,这还远远不够。我们需要一种可以让软件安装、运行和实现高可用的方法。我们需要 Kubernetes。


一旦软件在 Docker 容器中打包,我们就可以通过使用 Kubernetes 的功能将他们的软件变成 service。Kubernetes 的功能目标就是处理一系列基础设施(不管是哪里的),同时提供 API 在基础设施的基础上创建服务。Kubernetes 包括了负载均衡、弹性扩容、滚动更新、服务发现、命名空间、APIs,弹性调度和可配置的基础设施和阈值限制等等功能。使用这些功能,我们就可以创建声明式服务,并且将这些服务的控制权交给用户。Kubernetes 提高 No 和 NoOps,同时也提供给开发者单个 API,使用户可以进入公有云和私有云。

我们如何使用 ACS?

首先,用户需要有一个或者多个 Kubernetes 集群。安装 Kubernetes,使其运行能够在 5 分钟内,或者几天内运行起来(这个时间的话依据你的不同情况而定)。Kubernetes 支持大部分的公有云,openstack 云和本地数据中心。


用户也可以选择要运行在虚拟机上还是运行在物理机上。我们可以自己运行 kubernetes,如果我们在寻找增加支持,我们也可以使用管理工具来运行。


注意,在这里,用户完全处于控制地位,摆脱任意的锁定,自己控制自己的应用程序在哪里运行。多亏普通 API,这些 API 存在于任意的基础设施环境,用户可以使用他们的集群在多个云提供商上进行交付,或者他们可以创建一个真实的混合策略。


其次,通过将这些服务将他们的代码配置到用户的 Kubernetes 集群上,这样用户可以简单的使用这些服务。通过 app store,或者通过开发人员,用户可以搜索满足他们需求的服务,然后点击安装。服务提供商会在云端或者是在本地接触 Kubernetes 集群问题,并且安装服务。开发人员会马上开始使用服务。服务提供商的工作就是确保服务运行,健康的,并且按照需要调度。


在这个新世界,用户对自己的应用程序和他们所依赖的服务有越来越大的控制权。他们可以在云间,在私有云、公有云上移动我们的应用程序。使用者可以在多个集群间积极运行应用程序或准备好 active-standby。

总结,Anywhere Cloud Service

有了 anywhere cloud service,开发人员就能够按照他们想要的方式创建他们的应用程序,同时不需要担心运行和操作后端服务的问题。科技高管有云端锁定的自由,同时也有真正的混合解决方案。公有云提供商可以在其它不想移动的云上面访问用户。开源项目又有了收费的新途径。企业家正迎来新一波的淘金热,也面临众多的机遇与挑战。

总结——Anywhere 和开源服务

在 5 年内,新一代云服务将会像软件一样,你可以随意买一些,然后随意安装在你想要的地方,我预言一切就是会变的这么容易。


本文转载自才云 Caicloud 公众号。


原文链接:https://mp.weixin.qq.com/s/fhwcpAu-qmyPG146jVpHcQ


2020-03-12 22:54986

评论

发布
暂无评论
发现更多内容

云上人和物联科技加入龙蜥社区,携手打造软硬件服务生态

OpenAnolis小助手

开源 生态 龙蜥社区 CLA 云上人和物联科技

加密市场进入寒冬,是“天灾”还是“人祸”?

股市老人

攻防演练 | 基于ATT&CK的威胁狩猎实践案例

青藤云安全

网络安全 攻防演练 威胁狩猎

TiFlash 函数下推必知必会丨十分钟成为 TiFlash Contributor

PingCAP

#TiDB

MAUI使用Masa blazor组件库

沙漠尽头的狼

轻松上手Fluentd,结合 Rainbond 插件市场,日志收集更快捷

北京好雨科技有限公司

Kubernetes EFK Fluentd rainbond

美团基于 Flink 的实时数仓平台建设新进展

Apache Flink

大数据 flink 流计算 实时计算 实时数仓

Java——I/O II

武师叔

6月月更

DevSecOps: CI/CD 流水线安全的最佳实践

SEAL安全

CI/CD DevSecOps

天翼云探索云原生、边缘计算融合新思路

天翼云开发者社区

力扣每日一练之双指针2Day9

京与旧铺

6月月更

初识ElasticSearch

阿Q说代码

搜索引擎 lucene ES 选举 脑裂

假如,程序员面试的时候说真话

AlwaysBeta

程序员 面试

2022年盲盒软件开发商业模式深度解析

开源直播系统源码

软件开发 盲盒开发 盲盒软件

SAP Marketing Cloud 功能概述(二)

汪子熙

云计算 SaaS SAP 6月月更 Marketing Cloud

java培训机构 | Java设计模式之适配器模式

@零度

设计模式 JAVA开发

NFT交易平台数字藏品系统开发技术

薇電13242772558

NFT 数字藏品

【OpenI开源项目推荐-GammaGL】支持国内外主流深度学习框架的图神经网络算法库

OpenI启智社区

人工智能 算法 图神经网络

Java——流输入输出

武师叔

6月月更

天翼云数字政府智慧数据中台通过认证

天翼云开发者社区

企业官网如何提高客户转化率

源字节1号

重磅直播|BizDevOps:数字化转型浪潮下的技术破局之路

阿里云云效

阿里云 DevOps 研发效能 BizDevOps 场数字化转型

6月《中国数据库行业分析报告》发布!智能风起,列存更生

墨天轮

数据库 TiDB 国产数据库 列式存储

大数据培训 | 电商用户行为分析之商业指标统计分析

@零度

大数据开发

定金预售的规则思路详解

CRMEB

web前端开发培训 | React面向组件编程

@零度

前端开发 React

本周四晚19:00战码先锋第7期直播丨三方应用开发者如何为开源做贡献

OpenHarmony开发者

OpenHarmony

社恐?自我介绍时大脑一片空白?

阿Q说代码

个人成长 社恐 职场破冰 入职公司

北京大数据培训 | 电商用户行为分析之实时流量统计

@零度

大数据开发

CAT敏捷团队教练工作坊 (Coaching Agile Teams) | 8月20日开课

ShineScrum

教练 敏捷教练 高管教练 专业教练 ACC

得物技术复杂 C 端项目的重构实践

得物技术

前端 大前端 重构 框架 社区

用Docker和Kubernetes重做云服务_服务革新_才云科技_InfoQ精选文章