Docker搭建便捷的开发者环境
2015-12-02 15:51
676 查看
from:http://www.cnblogs.com/yanghuahui/p/3941685.html
你可能遇到这样的场景:开发软件时,需要像数据库(mysql,mongodb)、消息系统(rabbitmq)、缓存服务(redis)等其它依赖服务。当然我们可以找台机器,一步步安装依赖,然后把所有依赖的服务都安装好,这就是一台测试机。
为了避免重复的劳动,vm层面的解决方案就是把这个测试机做成镜像,以后申请的时候,就可以用之前测试机的镜像作为模板,启动一台虚拟机。这是一种解决方案,不过你可能需要更加灵活的解决方案,更加快速的启动一个开发环境,更加自由的组合和扩展开发时候依赖的服务组件,那好,it comes to Docker。 Dock基于Docker实现了快速搭建开发环境,是一个更加灵活便利的可行性方案,可以短时间内启动所有开发环境所需要的服务。Dock Github:https://github.com/bripkens/dock 安装步骤:1.首先确保我们安装了docker engine,然后接下来就是安装dock,当然如果在mac系统上,也可以通过虚拟化的解决方案boot2docker来安装docker,这样整个开发环境就可以都在mac机器上。2.代码clone下来,然后执行以下命令以及初始化工作,可以把dock放到环境变量中
接下来,开发者就可以根据ip+port等信息,使用刚刚所启动的服务组件了 扩展:也许我们可以提供这样的服务1.开发者需要一个redis实例,mongodb实例等等2.我们可以做一个这样的服务,搭建一个docker集群,然后写一个网页,接收用户的请求,请求到后台docker集群运行起来一个实例,成功后返回ip+port+admin+password3.开发者通过网页就可以管理申请实例的生命周期4.管理员在平台中方便的添加新的服务,只要package所需服务的docker image加上服务发现和管理,这样就是一个简单私有云的服务分发平台了
你可能遇到这样的场景:开发软件时,需要像数据库(mysql,mongodb)、消息系统(rabbitmq)、缓存服务(redis)等其它依赖服务。当然我们可以找台机器,一步步安装依赖,然后把所有依赖的服务都安装好,这就是一台测试机。
为了避免重复的劳动,vm层面的解决方案就是把这个测试机做成镜像,以后申请的时候,就可以用之前测试机的镜像作为模板,启动一台虚拟机。这是一种解决方案,不过你可能需要更加灵活的解决方案,更加快速的启动一个开发环境,更加自由的组合和扩展开发时候依赖的服务组件,那好,it comes to Docker。 Dock基于Docker实现了快速搭建开发环境,是一个更加灵活便利的可行性方案,可以短时间内启动所有开发环境所需要的服务。Dock Github:https://github.com/bripkens/dock 安装步骤:1.首先确保我们安装了docker engine,然后接下来就是安装dock,当然如果在mac系统上,也可以通过虚拟化的解决方案boot2docker来安装docker,这样整个开发环境就可以都在mac机器上。2.代码clone下来,然后执行以下命令以及初始化工作,可以把dock放到环境变量中
chmod +x /path/to/dock # Make dock executable dock -u # Initialise dock之后你就可以运行以下命令快速的启动需要的组件了,dock这个项目比较简单,很快就可以把代码看完,因为就是在docker之上封装了一层sh脚本,在formula里头可以根据项目需求,自行添加服务组件
$ dock redis jenkins mongodb rabbitmq这样在开发机上就已经有如下服务了
root@docker-stable-ubuntu:~# docker ps CONTAINER ID IMAGE COMMAND PORTS NAMES 63142f5e4ad2 tutum/rabbitmq /run.sh 0.0.0.0:5672->5672/tcp, 0.0.0.0:15672->15672/tcp rabbitmq 29c3a381ba55 dockerfile/mongodb:latest mongod 28017/tcp, 0.0.0.0:27017->27017/tcp mongodb 0b356f508ed6 jenkins:latest /usr/local/bin/jenki 50000/tcp, 0.0.0.0:8472->8080/tcp jenkins 2cf88d0aea8f dockerfile/redis:latest redis-server /etc/re 0.0.0.0:6379->6379/tcp redis
接下来,开发者就可以根据ip+port等信息,使用刚刚所启动的服务组件了 扩展:也许我们可以提供这样的服务1.开发者需要一个redis实例,mongodb实例等等2.我们可以做一个这样的服务,搭建一个docker集群,然后写一个网页,接收用户的请求,请求到后台docker集群运行起来一个实例,成功后返回ip+port+admin+password3.开发者通过网页就可以管理申请实例的生命周期4.管理员在平台中方便的添加新的服务,只要package所需服务的docker image加上服务发现和管理,这样就是一个简单私有云的服务分发平台了
相关文章推荐
- docker容器的网络信息查看
- 如何移除或禁用 Ubuntu Dock
- 在windows下的安装Docker的教程
- 8个你可能不知道的Docker知识
- 深入分析C#中WinForm控件之Dock顺序调整的详解
- 在Docker中自动化部署Ruby on Rails的教程
- 搭建基于Docker的PHP开发环境的详细教程
- 利用OpenVSwitch在多台主机上部署Docker的教程
- ubuntu14.04+docker的安装及使用
- Docker 清理命令集锦
- 再Docker中架设完整的WordPress站点全攻略
- 基于 Docker 开发 NodeJS 应用
- 在Docker上部署Python的Flask框架的教程
- 在Docker上开始部署Python应用的教程
- 详解在Python和IPython中使用Docker
- 使用IPython来操作Docker容器的入门指引
- OSX下brew安装docker(boot2docker)
- docker 设置TLS远程访问
- mesos + marathon + docker部署
- docker-registry server部署