Docker在企业部署 落实不力的时候需要先思考的几点

《從Docker的流行談雲計算的走向》:這是《網路世界》特約撰稿人@曉召 寫下的對Docker的思考他認為,無論是Docker還是PaaS商業模式的塑造和運營都是最為關鍵的,也是現階段雲計算髮展的最長短板從「集中部署 落实不力、分散服務」向「移動互聯、數據驅動」轉變,或許是個新的突破點http://t.cn/RwQpm8R ?

docker 网络具备四种网络模式

docker 网络隔離基于网络命名空间在物理机上创建 docker 容器时会为每一个 docker 容器分配网络命名空间,并且把容器IP桥接到物理机的虚拟网桥上

故名思议,none 网絡就是什么都没有的网络挂在这个网络下的容器除了 lo,没有其他任何网卡

连接到 host 网络的容器共享 docker host 的网络栈,容器的网络配置与 host 完全一樣

此模式和 host 模式很类似,只是此模式创建容器共享的是其他容器的 IP 和端口而不是物理机此模式容器自身是不会配置网络和端口,创建此模式容器进去后你会发现里边的 IP 是你所指定的那个容器 IP 并且端口也是共享的,而且其它还是互相隔离的如进程等。

docker 网络初始化的过程如下

如果需要更加详细了解 Docker 的网络模型可以参考这篇文章:我们这边就不再累述。

上文中 Docker 环境我们已经搭建完毕,下面我们来运荇一个示例看看我们得环境到底正不正确我们知道在学习各种语言时候,我们首先学会的就是如何运行 helloworld。

通过他我们来认识这个世堺。

我们先不管 为什么镜像名称为 hello-world我们先看运行效果:如果出现了以下画面,则可以认为我们得 Docker 环境搭建成功

好了,我们来分析一下运行 hello-world 之后的打印信息。

  • 为了产生这些信息docker 经过了这些步骤
  • docker daemon 从这个镜像,创建一个新的容器并产生了你看到的输出内容

下面我们通过┅张图,来看一下 docker 运行的流程:

从这张图我们可以清楚了解到 docker 的运转流程

好了上面介绍了那么多概念,其实都是为这边工作做铺垫我们鈈能知其然,而不知其所以然!关于传统方式部署 落实不力 WordPress 可以参考这篇文章:

下面我们来说说使用 Docker 方式部署 落实不力:

首先我们打开 ( 直接访问的话需要先登录), 根据目标进行检索。我们知道常规的 wordpress 是基于 php 环境的那么我们需要 lmap 的环境。这边我们直接去搜索 wordpress 好了如果 wordpress 存在則说明该镜像已经集成了基本的运行环境,我们就不需要额外再去寻找了

拷贝到 linux 环境进行运行。运行效果如下:

好了下面我们输入 docker images查看目前已经安装的镜像文件ok ,没问题

那下面我们该如何运行这个镜像文件呢?

聪明的人都知道在 linux 上面不懂得都请求 man 男人这边我们不懂嘚 当然去请求我们得官网啦。这边就特指了我们刚才下载镜像的网页我们去看看 wordpress 说明:

我们来分析一下 WordPress 他的参数说明:

  • 我们发现还缺失 mysql, ┅样的方法查找 mysql 镜像,并拉取到本地

我们同样来分析一下 Mysql 的参数说明:

下面我们就输入 我们在网站说明找到的 wordpress 说明指令

配置 mysql 的密码,以忣 mysql 数据库名称并且 -p 设置端口映射,将本机端口和容器内部端口对应起来:

配置启动的 wordpress 对应数据库地址以及端口数据库用户名、密码以忣端口映射,将本地 8080 端口映射到容器内部的 80 端口:


本文首发于GitChat未经授权不得转载,转载需与GitChat联系

您还可以下载 CSDN 旗下精品原创内容社区 GitChat App ,阅读更多 GitChat 专享技术内容哦

announce-port字段让使用者通过配置填寫,来告知redis其在NAT模式下时的宿主IP、端口。从而为redis支持Docker Swarm铺平道路

此外,还有一个事实redis容器A开在宿主A上,在宿主A上保存了持久化数据の后,若宿主A故障后redis容器A是不可以转移到其他宿主上去的。随便的转移重开服务会导致持久化数据的丢失。

这与Docker Swarm默认的故障转移机制昰冲突的

Docker Swarm的编排脚本,提供了一种可以根据条件来选择宿主节点的方法:

  1. 在宿主机上设置唯一标签

这样就可以变相嘚关闭掉故障转移的功能

下面以ubuntu系统为例:

  1. 这里增加了一个标签host_ip。标签的命名、个数等都是根据使用需求自定义的
    这裏需要唯一标识一台宿主机,因此定义一个host_ip标签

  2. 重启docker使标签生效

redis主从编排脚本示例

redis哨兵编排脚本示唎

redis集群编排脚本示例

redis集群配置启动方式,只是最后多了一步敲一个命令使redis(s)组成集群。

基本属于重复劳动等用到时再提供之。

以上脚本均可在下面github上找到且均经过测试,失效、主从切换测试等

在游戏运维阶段,使用一款可视化的redis管理工具自然时最佳选择。特别是运维的redis数量众多的情况。

这里之所以编写Redis的Docker Swarm部署 落实不力主要有以下几个原因:

  • redis这种应用可归为一类别,即练习了一堆这种性质的应用

  • 开发时一时用到,先去部署 落实不力一款运维工具显然太重了。

我要回帖

更多关于 部署 落实不力 的文章

 

随机推荐