- 浏览: 210956 次
- 性别:
- 来自: 河北
文章分类
最新评论
-
6420285:
你的文章很棒,很多地方讲的通俗易懂,非常感谢。 ...
深入掌握JMS(一):JSM基础 -
xs.cctv:
不错
zeroDateTimeBehavior=convertToNull -
hanyannan0123:
搞不清楚,此话属于经典呢,还是废话。
超类 好 -
czy584521:
```我肯定他用了谷歌金山词霸
IBM的面试官被我忽悠蒙了 -
yuantong:
老板跳槽?什么概念
我们老板跳槽了 !!!
转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/128.html?1455808640
当听到很多人在说Docker是多么多么的棒,很多新潮的孩子都在使用它时,我决定在我的开发环境上也来尝试下。在下面的这篇文章中,我将讲解在Mac OS X怎样建立Postgres,Elasticsearch和Redis。
什么是Docker
Docker用轻量容器把一个APP从它运行的OS中隔离开。它把APP放入到一个孤立的盒子中,对外只呈现需要使用的文件夹和端口。
这样,基于建立和使用APP的容器是可重用,共享的。目前,在Docker集中已经存在了15,000种以上的容器。Docker就像一个商店的存储库,当你需要建立一个你想要的APP时,你首先去挑出它,然后把它下载下来打开即可。
在OS X上安装Docker
Docker不是天生就能运行在OS X上的,它需要一个包含LINUX容器的Linux内核。因此,当你想像我一样要安装OS X时,你将需要一套虚拟器。
不要使用boot2docker
当试图让docker工作时,我发现“非常容易”安装。这将使用一个称之为boot2docker的工具,该工具是一个像virtualBox的虚拟机上的瘦包装。
我马上发现,这个工具有一些严重的问题,例如:在一个稳定状态下将会终止任何获取Docker的进程。我不想在这方面浪费太多的体力和脑细胞,所以我继续寻找了一个可替代的解决方案。
使用Vargrant
自从Vagrant的1.6版本之后,已经集成了支持Docker的配套组件。Vargrant是一种类似于VirtualBox的虚拟软件,它采用一种声明Ruby DSL的方法来描述你的环境。
我非常喜欢这种定义虚拟环境的方式,因为当你的环境发生故障时,你可以记录下来当时的信息,再次开始使用,而不用遗漏下大量的类似环境变量的信息。
安装Stuff
首先,让我们浏览下我们需要安装的各种事宜。
Homebrew安装:
ruby -e "$(curl -fsSL https://raw.github.com/mxcl/homebrew/go)"#p#分页标题#e#
Cask安装:
brew tap caskroom/homebrew-cask brew install brew-cask
Vagrant 和 VirtualBox安装:
brew cask install virtualbox brew cask install vagrant
Vagrant文件
一个vagrant文件来描述一个使用Ruby DSL虚拟机环境的需求。当描述Docker容器时,Vagrant使每一个容器都好像在使用自己独有的虚拟机一样。事实上这是一个假象,因为每一个Docker容器实际上是允许在各种的代理虚拟机上的。
因此,两个vagrant文件是非常必须的,一个文件是用来定义代理虚拟机(Provisioner),另外一个文件是用来定义Docker容器的(Providers)。
代理虚拟Vagrant文件
代理虚拟Vagrant文件被叫做:Vagrantfile.proxy
VAGRANTFILE_API_VERSION = "2"Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| config.vm.box = "hashicorp/precise64" config.vm.provision "docker" config.vm.provision "shell", inline: "ps aux | grep 'sshd:' | awk '{print $2}' | xargs kill" config.vm.network :forwarded_port, guest: 6379, host: 6379 config.vm.network :forwarded_port, guest: 5432, host: 5432 config.vm.network :forwarded_port, guest: 9200, host: 9200end
这使用hashicorp/precise64 Ubuntu 12.04的64位来处理代理虚拟机。它也提供Docker和一些神奇的shell命令来让Docker工作。
最后的事情就是设置转发端口了。它使用config.vm.network来为Redis, Elasticsearch 和Postgres来进行配置,用代理虚拟机映射到OS X。#p#分页标题#e#
Docker 容器的 Vagrant 文件
这是Vagrantfile的主要内容:
VAGRANTFILE_API_VERSION = "2" Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| config.vm.define "redis" do |v| v.vm.provider "docker" do |d| d.image = "dockerfile/redis" d.volumes = ["/var/docker/redis:/data"] d.ports = ["6379:6379"] d.vagrant_vagrantfile = "./Vagrantfile.proxy" end end config.vm.define "elasticsearch" do |v| v.vm.provider "docker" do |d| d.image = "dockerfile/elasticsearch" d.ports = ["9200:9200"] d.vagrant_vagrantfile = "./Vagrantfile.proxy" end end config.vm.define "postgres" do |v| v.vm.provider "docker" do |d| d.image = "paintedfox/postgresql" d.volumes = ["/var/docker/postgresql:/data"] d.ports = ["5432:5432"] d.env = { USER: "root", PASS: "abcdEF123456", DB: "root" } d.vagrant_vagrantfile = "./Vagrantfile.proxy" end endend
这个文件定义了三个容器: Redis , Elasticsearch, 和 Postgres 带有图片 dockerfile/redis , dockerfile/elasticsearch 和 paintedfox/postgresql 。
每个文件定义 vagrant_vagrantfile 作为 proxy VM 文件,这使得它们在同一个 proxy 虚拟机上运行。
Redis 和 Postgres 的 volumes 定义是为了它们的信息可以存储在 proxy VM 上,而不是在容器中。这也是容器可以更删除或升级而数据不会丢失的原因。下一步是映射这些文件从proxy VM 到 OS X ,但是没必要让其运转着。
每个容器上的 ports 定义哪个端口转到 proxy VM 。这些需要匹配 proxy VM 到 OS X 的端口。
Postgres 容器也定义了需要设置它的服务器的环境变量。这些可以用来在OS X 里设置缺省的Postgres 服务器,通过设置环境变量 PGHOST=localhost PGUSER=root PGPASSWORD=abcdEF123456 来实现。
使用Vagrant工作
在你的Vagrant文件相同的目录内,你可以运行:
vagrant up --provider=docker#p#分页标题#e#
第一次运行这个时,Vagrant将下载然后启动proxy VM,然后下载并启动Docker容器。在这些初始化下载之后每次运行Vagrant都将重复使用现有的图片。
可以查看Docker容器的状态:
vagrant status
应该输出一些东西类似:
代码如下:
Current machine states:
redis running (docker)
elasticsearch running (docker)
db running (docker)
要测试Docker容器是否正确运行,可以使用 Redis 和 Postgres 客户端, 和 curl for Elasticsearch。只需要检查redis-cli和psql到服务器的连接,和curl http://localhost:9200响应。
如果需要连接到proxy VM(非常有助于调试),运行vagrant global-status,这将列出所有VM,包括proxy。然后调用vagrant ssh <ID>,ID为proxy的ID。建议不要手动改变这个proxy VM,使用一个Chef(或类似的)脚本,这样改变可以更容易的测试和分布。
性能
使用虚拟化时,第一个问题总是会问“性能的影响有多少?”。要找出性能影响是多么的糟糕,我的同事和我都做了一个Postgres,在相同的硬件上做了Elasticsearch 和 Redis 加强测试。唯一的区别是一个测试有本机安装的软件而另一个有Docker自定义容器。带有本机软件的运行了2分钟,而带有容器的运行了3分钟。
这个性能影响并不像我想象的那样小,甚至可能会更糟。即使这样,我将继续使用Docker做开发,但并不推荐大家将它作为所有开发环境问题的灵丹妙药。
#p#分页标题#e#
注意:一些其他使用Vagrant 和 Docker的限制在 这里 列出
总结
我还看不到"Vagrant with Docker"的路在哪里。不过,在看过可能的情况后,我不禁思考它可以用于什么其他地方。另外,它是我遇到过的最好玩的虚拟化,乐趣就在于编程。
当听到很多人在说Docker是多么多么的棒,很多新潮的孩子都在使用它时,我决定在我的开发环境上也来尝试下。在下面的这篇文章中,我将讲解在Mac OS X怎样建立Postgres,Elasticsearch和Redis。
什么是Docker
Docker用轻量容器把一个APP从它运行的OS中隔离开。它把APP放入到一个孤立的盒子中,对外只呈现需要使用的文件夹和端口。
这样,基于建立和使用APP的容器是可重用,共享的。目前,在Docker集中已经存在了15,000种以上的容器。Docker就像一个商店的存储库,当你需要建立一个你想要的APP时,你首先去挑出它,然后把它下载下来打开即可。
在OS X上安装Docker
Docker不是天生就能运行在OS X上的,它需要一个包含LINUX容器的Linux内核。因此,当你想像我一样要安装OS X时,你将需要一套虚拟器。
不要使用boot2docker
当试图让docker工作时,我发现“非常容易”安装。这将使用一个称之为boot2docker的工具,该工具是一个像virtualBox的虚拟机上的瘦包装。
我马上发现,这个工具有一些严重的问题,例如:在一个稳定状态下将会终止任何获取Docker的进程。我不想在这方面浪费太多的体力和脑细胞,所以我继续寻找了一个可替代的解决方案。
使用Vargrant
自从Vagrant的1.6版本之后,已经集成了支持Docker的配套组件。Vargrant是一种类似于VirtualBox的虚拟软件,它采用一种声明Ruby DSL的方法来描述你的环境。
我非常喜欢这种定义虚拟环境的方式,因为当你的环境发生故障时,你可以记录下来当时的信息,再次开始使用,而不用遗漏下大量的类似环境变量的信息。
安装Stuff
首先,让我们浏览下我们需要安装的各种事宜。
Homebrew安装:
ruby -e "$(curl -fsSL https://raw.github.com/mxcl/homebrew/go)"#p#分页标题#e#
Cask安装:
brew tap caskroom/homebrew-cask brew install brew-cask
Vagrant 和 VirtualBox安装:
brew cask install virtualbox brew cask install vagrant
Vagrant文件
一个vagrant文件来描述一个使用Ruby DSL虚拟机环境的需求。当描述Docker容器时,Vagrant使每一个容器都好像在使用自己独有的虚拟机一样。事实上这是一个假象,因为每一个Docker容器实际上是允许在各种的代理虚拟机上的。
因此,两个vagrant文件是非常必须的,一个文件是用来定义代理虚拟机(Provisioner),另外一个文件是用来定义Docker容器的(Providers)。
代理虚拟Vagrant文件
代理虚拟Vagrant文件被叫做:Vagrantfile.proxy
VAGRANTFILE_API_VERSION = "2"Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| config.vm.box = "hashicorp/precise64" config.vm.provision "docker" config.vm.provision "shell", inline: "ps aux | grep 'sshd:' | awk '{print $2}' | xargs kill" config.vm.network :forwarded_port, guest: 6379, host: 6379 config.vm.network :forwarded_port, guest: 5432, host: 5432 config.vm.network :forwarded_port, guest: 9200, host: 9200end
这使用hashicorp/precise64 Ubuntu 12.04的64位来处理代理虚拟机。它也提供Docker和一些神奇的shell命令来让Docker工作。
最后的事情就是设置转发端口了。它使用config.vm.network来为Redis, Elasticsearch 和Postgres来进行配置,用代理虚拟机映射到OS X。#p#分页标题#e#
Docker 容器的 Vagrant 文件
这是Vagrantfile的主要内容:
VAGRANTFILE_API_VERSION = "2" Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| config.vm.define "redis" do |v| v.vm.provider "docker" do |d| d.image = "dockerfile/redis" d.volumes = ["/var/docker/redis:/data"] d.ports = ["6379:6379"] d.vagrant_vagrantfile = "./Vagrantfile.proxy" end end config.vm.define "elasticsearch" do |v| v.vm.provider "docker" do |d| d.image = "dockerfile/elasticsearch" d.ports = ["9200:9200"] d.vagrant_vagrantfile = "./Vagrantfile.proxy" end end config.vm.define "postgres" do |v| v.vm.provider "docker" do |d| d.image = "paintedfox/postgresql" d.volumes = ["/var/docker/postgresql:/data"] d.ports = ["5432:5432"] d.env = { USER: "root", PASS: "abcdEF123456", DB: "root" } d.vagrant_vagrantfile = "./Vagrantfile.proxy" end endend
这个文件定义了三个容器: Redis , Elasticsearch, 和 Postgres 带有图片 dockerfile/redis , dockerfile/elasticsearch 和 paintedfox/postgresql 。
每个文件定义 vagrant_vagrantfile 作为 proxy VM 文件,这使得它们在同一个 proxy 虚拟机上运行。
Redis 和 Postgres 的 volumes 定义是为了它们的信息可以存储在 proxy VM 上,而不是在容器中。这也是容器可以更删除或升级而数据不会丢失的原因。下一步是映射这些文件从proxy VM 到 OS X ,但是没必要让其运转着。
每个容器上的 ports 定义哪个端口转到 proxy VM 。这些需要匹配 proxy VM 到 OS X 的端口。
Postgres 容器也定义了需要设置它的服务器的环境变量。这些可以用来在OS X 里设置缺省的Postgres 服务器,通过设置环境变量 PGHOST=localhost PGUSER=root PGPASSWORD=abcdEF123456 来实现。
使用Vagrant工作
在你的Vagrant文件相同的目录内,你可以运行:
vagrant up --provider=docker#p#分页标题#e#
第一次运行这个时,Vagrant将下载然后启动proxy VM,然后下载并启动Docker容器。在这些初始化下载之后每次运行Vagrant都将重复使用现有的图片。
可以查看Docker容器的状态:
vagrant status
应该输出一些东西类似:
代码如下:
Current machine states:
redis running (docker)
elasticsearch running (docker)
db running (docker)
要测试Docker容器是否正确运行,可以使用 Redis 和 Postgres 客户端, 和 curl for Elasticsearch。只需要检查redis-cli和psql到服务器的连接,和curl http://localhost:9200响应。
如果需要连接到proxy VM(非常有助于调试),运行vagrant global-status,这将列出所有VM,包括proxy。然后调用vagrant ssh <ID>,ID为proxy的ID。建议不要手动改变这个proxy VM,使用一个Chef(或类似的)脚本,这样改变可以更容易的测试和分布。
性能
使用虚拟化时,第一个问题总是会问“性能的影响有多少?”。要找出性能影响是多么的糟糕,我的同事和我都做了一个Postgres,在相同的硬件上做了Elasticsearch 和 Redis 加强测试。唯一的区别是一个测试有本机安装的软件而另一个有Docker自定义容器。带有本机软件的运行了2分钟,而带有容器的运行了3分钟。
这个性能影响并不像我想象的那样小,甚至可能会更糟。即使这样,我将继续使用Docker做开发,但并不推荐大家将它作为所有开发环境问题的灵丹妙药。
#p#分页标题#e#
注意:一些其他使用Vagrant 和 Docker的限制在 这里 列出
总结
我还看不到"Vagrant with Docker"的路在哪里。不过,在看过可能的情况后,我不禁思考它可以用于什么其他地方。另外,它是我遇到过的最好玩的虚拟化,乐趣就在于编程。
发表评论
-
UDF 底层实现
2017-01-04 00:03 757用户自定义函数 继承UDF,重写evaluate方法即可 ... -
MetadataCleaner
2016-12-09 23:09 764MetadataCleaner运行定时任务周期性的清理元数据( ... -
黑马程序员_java08_多线程
2016-03-13 13:01 445转载于:http://www.itxuexiwang.com/ ... -
Redis数据库的安装配置方
2016-02-23 11:27 794转载于:http://www.itxuexiwang.com/ ... -
通过 Redis 实现 RPC 远程方法调用(支持多种编程语
2016-02-23 11:27 846转载于:http://www.itxuexiwang.com/ ... -
CentOS Linux系统下安装Redis过程和配置参数说明
2016-02-28 18:39 604转载于:http://www.itxuexiwang.com/ ... -
NoSQL和Redis简介及Redis在Windows下的安装和使用教程
2016-02-23 11:28 668转载于:http://www.itxuexiwang.com/ ... -
64位Windows下安装Redis教程
2016-03-10 14:06 717转载于:http://www.itxuexiwang.com/ ... -
让Redis在你的系统中发挥更大作用的几点建议
2016-03-10 14:06 1006转载于:http://www.itxuexiw ... -
Redis主从复制问题和扩容问题的解决思路
2016-02-25 13:26 1001转载于:http://www.itxuexiw ... -
Redis中5种数据结构的使用场景介绍
2016-02-25 13:27 718转载于:http://www.itxuexiw ... -
redis中使用redis-dump导出、导入、还原数据实例
2016-02-25 13:26 1312转载于:http://www.itxuexiwang.com/ ... -
Redis批量删除KEY的方法
2016-02-26 17:24 761Redis 中有删除单个 Key 的指令 DEL,但好像没有批 ... -
超强、超详细Redis数据库入门教程
2016-02-28 18:39 575转载于:http://www.itxuexiw ... -
Redis总结笔记(一):安装和常用命令
2016-02-26 17:23 536转载于:http://www.itxuexiw ... -
Redis总结笔记(二):C#连接Redis简单例子
2016-02-26 17:24 728转载于:http://www.itxuexiwang.com/ ... -
redis启动流程介绍
2016-03-10 14:07 635转载于:http://www.itxuexiwang.com/ ... -
redis中使用java脚本实现分布式锁
2016-03-13 13:03 589转载于:http://www.itxuexiwang.com/ ... -
redis常用命令、常见错误、配置技巧等分享
2016-02-26 17:23 537转载于:http://www.itxuexiwang.com/ ... -
Redis数据库的使用场景介绍(避免误用Redis)
2016-03-11 12:12 549转载于:http://www.itxuexiw ...
相关推荐
vagrant 在mac上通过命令行工具可以管理统一的镜像(BOX)所以vagrant还需要依赖VirtualBox等提供系统(支持linux,windows,OS X等)环境。这篇文章主要介绍下个人在mac上的配置过程。后面一篇会介绍vagrant上搭建...
这是 Docker 容器在 Mac OS X 上的 Vagrant VM 内运行 Node.js Web 服务器的互联网上最简单的示例。 )。 我从 nodejs.com 的首页窃取了 Node.js 服务器,并将 Vagrantfiles 和 Dockerfile 从我发现不太适合我需要...
先决条件Mac OS X示例用法使用 $HOME/projects/vagrant-dockerhost 作为安装位置 $ cd $HOME/projects/vagrant-dockerhost$ ./dockerenv$ vagrant upBringing machine 'dockerhost' up with 'virtualbox' provider.....
一个 Vagrant 虚拟机,用于在 Mac OS X 上运行 Docker 开发环境。 虚拟机基于 Vagrant box。 介绍 在 OS X 上运行 Docker 通常意味着运行 ,或者最近的 。 尽管这些工具非常适合快速启动和运行,但如果您想运行 ...
6. **文件同步**:Vagrant支持共享文件夹功能,使得开发者在主机上的代码更改能够实时反映到虚拟机内的osTicket源码中,反之亦然,确保了开发和测试的一致性。 7. **跨平台兼容性**:无论开发者是在Windows、Mac...
Mac OS X和Linux / CentOS的安装脚本 Ansible剧本,具有可重用的角色,可用于centos,nodejs,httpd,mongodb,mysql,redis,memcached,git等。 包含用于测试的测试Vagrant设置。 只需在目录中运行vagrant up 。...
Ruby-Xhyve是Vagrant的一个插件,它为Mac OS X用户提供了在本地使用Vagrant管理虚拟机的能力。这个插件利用了Apple在其操作系统中内置的Hypervisor.framework,使得开发者能够在不依赖其他第三方虚拟化软件(如...
请帮我在Linux和Windows上检查它如何安装要安装dev.env ,您可以将此存储库克隆到本地计算机: git clone https://github.com/huytd/dev.env然后运行install.sh : ./install.sh如何使用? 首先,在新项目文件夹中...
这些开发环境可以存在于您的计算机或云中,并且可以在Windows,Mac OS X和Linux之间移植。 快速开始 程序包依赖关系:Vagrant需要bsdtar和curl在系统PATH上可用,才能成功运行。 为了快速入门,我们将在上启动开发...
使用 Ansible(以及适用于 Windows/Mac OS X 开发者的 Vagrant)在 Docker 容器中部署任何 symfony2 应用程序 是的,您没有看错,如果您的应用程序,那么您无需执行任何操作就可以使用这组脚本进行部署 如果您的应用...
VirtualBox_PKC 对于可以在其计算机上运行Oracle 任何人,都可以使用此项目安装 ()。 然后,可以仅复制通过此过程创建的...在撰写本文时,我们已经在Mac,Windows 10和Linux计算机上进行了测试。 以下版本的操作系
运行 Cassandra 集群示例 推介会 可以从找到 OpenSlava 2014 随附的演示文稿...该环境已在 Windows 7 和 Mac OS X 中测试过。它也应该在 Linux 中运行。 主机上必须安装以下软件(括号中为测试版本号): VirtualBox
适用于任何平台的开发和测试Fusion使在Mac上几乎可以测试几乎所有的OS和应用程序变得简单。在安全共享本地源文件和文件夹的同时,在沙箱中构建和测试应用。 Fusion Pro现在包括一个RESTful API,可与Docker,Vagrant...
UserKBDeployment 为了启用个性化数据所有权,该项目提供了部署指南,以允许个人在笔记本电脑或个人台式机上安装和维护MediaWiki知识存储。 目的是帮助个人用户将功能齐全的MediaWiki服务作为文档服务器使用,其中...
- 介绍了不同的部署方案,如PaaS服务、虚拟/专用服务器、共享服务器,以及使用Vagrant和Docker进行应用虚拟化。 13. **文档撰写**: - 书中的资源部分可能提到了文档编写的重要性,鼓励开发者创建清晰、易于理解...
Mac OS X Yosemite version 10.10.2 Virtual Box 4.3.26 vagrant 1.7.2 git 2.2.1 我尝试使用 Windows 8.1 和 vagrant 1.7.2。 有用! 只需克隆它然后流浪并重新加载。 大约需要40分钟。 $ git clone ...
开发人员应用程序:iTerm2,Sublime Text,Atom,VirtualBox,Vagrant,Docker,Chrome等 Python数据分析:IPython Notebook,NumPy,Pandas,Scikit-Learn,Matplotlib等 大数据平台:Spark(与IPython Notebook...
自动预配Mac OS X开发环境 从GitHub下载(并提取)。 cd ~ /Downloads/mac-dev-setup-master ./setup.sh 该脚本将询问一些变量,并将其内容存储在./.personalised_settings.sh以备将来使用。 安装过程将下载许多...