Docker 与分布式数据库结合

来自重庆慧谷科技的蒋勇先生,做为SequoiaDB社区的“骨灰级成员”,于最近分享了主题为“Dockerizing SequoiaDB”的技术专题,分享主要介绍了他们公司如何使用Docker制做国内领先的NoSQL数据库SequoiaDB的镜像的过程,以及有关Docker和Core OS一些介绍和使用心得,那么笔者就将对他的演讲进行概括总结,顺便谈一谈Docker与分布式数据库结合的必要性。docker

技术新潮流 - Docker

随着现在开源软件以及开源项目的热潮,Docker做为现在在技术圈很是火爆的一款开源软件产品,除了开源项目的贡献很是活跃,目前应用也十分的普遍,包括Redhat在内的多个操做系统都已经能支持Docker,而更是无数的软件已经在使用Docker镜像进行安装部署。数据库

那么Docker是什么呢?安全

Docker 是一个开源的应用容器引擎,让开发者能够打包他们的应用以及依赖包到一个可移植的容器中,而后发布到任何流行的 Linux 机器上,也能够实现虚拟化。容器是彻底使用沙箱机制,相互之间不会有任何接口。几乎没有性能开销,能够很容易地在机器和数据中心中运行。最重要的是,他们不依赖于任何语言、框架包括系统。服务器

这是对Docker的一个官方解释,简单说,有两个部分:架构

1) 对于应用程序,曾经咱们须要为了避免同的系统专门的调整应用程序的代码或者是构造相应的依赖包驱动等等,大大增长了开发量以及开发的难度。如今,Docker向不一样的应用程序,提供了一个统一的环境。
2) 对于服务器,为了支持不一样版本的应用,曾经可能须要在物理机上安装多个版本或者不一样的GuestOS或者说虚拟机。这就大大占用了物理机的性能,影响了最终程序的表现,提升了资源的成本。框架

图片描述

使用Docker容器的方式,对于应用程序,不须要开发多种多样的版本或者是针对OS每一个版本的升级再进行代码方面的调整,实现了普遍的兼容性和开发的最简性。同时对于物理机,部署的环境“瘦身”也节约了更多的资源,将更多的资源用于提升应用程序自己的性能。分布式

CoreOS是Docker的不二之选?

以前大概介绍了Docker,那么服务器上面仍是须要最基本的应操做系统才能支撑Docker容器,那么这么多中的Linux内核OS究竟哪个好呢?笔者和不少Docker技术专家的的观点就是Core OS。工具

CoreOS是一个基于Linux 内核的轻量级操做系统,为了计算机集群的基础设施建设而生,专一于自动化,轻松部署,安全,可靠,规模化。做为一个操做系统,CoreOS 提供了在应用容器内部署应用所须要的基础功能环境以及一系列用于服务发现和配置共享的内建工具。oop

简单说,CoreOS去掉了大量的非必要的功能,只保留了Server端须要的最基本功能,真正意义作到了“轻量化”。性能

此外,CoreOS还作到了:总体系统升级/回滚方案;容器化全部非系统应用、无包管理器;集群化调度器Fleet;分布式高可靠的KV存储系统ETCD

这些特性都让它成为Docker生态的首选操做系统。不过最新的消息是,CoreOS不知足于作Docker生态下的一环,它正在推出本身的容器AppC计划,想对Docker来一招“釜底抽薪”。固然,现阶段并无出现彻底的二者 “分手”,因此对于普通使用者,并无太大影响。

Docker+分布式数据库

数据库是每个软件项目必须的一个部分,做为这样的一类底层基础软件,兼容性、通用性、易用度都是须要考虑的重点。很是遗憾的是,如今的操做系统以及数据库都没有彻底的实现彻底的通用。特别对于NoSQL数据库这样的分布式系统,须要部署在多台物理机时,对于通用性要求就更高了。

目前,像SequoiaDB已经实现了自动化的安装,大大提高了部署的效率,可是考虑到部署以后的配置以及不一样环境下的调试问题,仍然可能会耗费不小的人力物力。因此基于刚刚提到的Docker的优势,做为一个通用的基础软件,NoSQL数据库的Docker化就成了必须。

图片描述
图片描述
图片描述

一个简单的例子,你能够用docker把数据库的数据与数据库程序自己分离开:用一个container A做为数据存储,而后另外一个container B运行数据库。当你想升级数据库时,用新的container C替换掉container B便可。

Docker+分布式数据库的结合,带来诸多的好处:

1) 部署简单,使用镜像部署很是简单,特别是对集群环境,使用Docker镜像的部署还能够再数据库上提早集成Hadoop、Spark等架构,真正实现“一步到位”。
2) 方便应用的更新,应用的更新只须要考虑制做一个新的镜像就能够与容器适配,无需从新再调整与底层的配置。数据和程序的分离,这样升级替换等等都不会影响到数据。
3) 操做简单方便,除了底层免除了复杂的与环境进行配置的工做,操做也更加方便,配置好的Docker镜像在部署时候只须要一条指令就能够了。
4) 开发、应用环境一致,Docker让数据库能作到 开发---测试---实施应用 三个阶段的环境是彻底一致的。下降开发到应用过程当中的工做量,开发出来就能保证明际应用环境上能一样的运行。
5) 系统稳定,由于Docker的隔离做用,将应用与OS独立开,这样能更好保证整个系统的稳定性。
6) 节省系统资源,系统只须要运行一个统一的环境就能够,不须要占用太多性能去支持运行环境自己,能将更多的系统资源投入到应用当中。

有了这些特性, Docker+数据库,将成为一个数据库发展的新方向,Docker这样的通用性和简单操做解决方案,大大提升了数据库使用的效率,帮助使用者节约了大量成本。

Docker是现在技术圈的新潮流,开发人员是最乐见于Docker的这种应用部署模式,由于应用的生命周期起始于开发人员的开发系统,通过开发,测试,压力测试,等过程,最终应用发布到生产系统,并可能在不一样的生产系统中迁移。应用开发人员对此都会有切身的体会,任何微小的运行环境的错误都会致使应用出现问题,尤为在讲究快速敏捷的今天,应用模块,新的代码,新的配置,被快速的加入应用的环境中,可能还没等写入到文档,新特性就已经被推送到生产上了。做为一个新的技术,笔者也但愿更多的产品能增强与Docker的结合,帮助产品更好的使用。

相关文章
相关标签/搜索