前言
docker是一个开源的容器引擎,它的观点就是服务器上安装有不同的容器 容器内配备单独的cpu和配置环境,当你需要这个环境的时候只需要单独下载容器并且使用就可以了 而且你也可以配置自己的容器,这样的办法 方便了开发人员在更换办公机器的时候为再次搭建复杂的开发环境省去了时间和麻烦,并且重启容器的时间较快只需要一秒,详细构造如下图:
我们最初的模式是a1 服务器内存放着所有的应用 但是如果其中一个应用因为内存过满导致应用崩溃那么服务器都跟着遭殃,所以需要做到应用资源独立,这时用到了a2,一台服务器上装了不同的虚拟机 每个虚拟机分配了不同的内存和cpu ,这样解决了应用资源独立问题如果应用已崩溃了 并不会影响应用2的内容,但是虚拟机启动过慢,并且如果迁移应用的时候需要从新配置虚拟机,这时候我们可以运用docker来实现第三种a3的方式,docker容器重启时间很快当应用迁移的时候,只需要把装了docker服务器镜像下载加载进去 运行就可以了。
使用教程
这里我们以服务器是Ubuntu系统为前提使用docker。
//首先安装docker sudo apt-get install docker.io //安装完成后我们输入docker可查看详细命令参数
docker info 命令可以帮我们查看docker的信息
接下来我们需要的是容器现在的docker只是一个空的docker。
//首先我们需要一个系统镜像 用 docker pull 命令获取系统镜像 docker pull ubuntu:14.04 // images命令可以查看本机docker中存在哪些镜像 docker images // 接下来我们运行镜像 运行的镜像就叫做容器 容器可读可写 用run命令 运行镜像 docker run -it ubuntu:14.04 //接下来我们就进入到了容器中 所有操作并不会影响原来的系统 exit退出容器
接下来我们将自己创建好的容器转化为镜像方便日后开发
//ps命令可以查看我们当前都运行了哪些容器 -a参数表示运行过哪些容器 docker ps -a //commit命令用来将容器转化为镜像 -m 参数用来提交说明信息 -a指定用户信息 长长的字母加数字表示容器的id 最后指定目标镜像的用户名 仓库名和tag信息 sudo docker commit -m "xxxx" -a "xxx" id 用户名/仓库名 tag信息 //这时我们运行 docker images 就会发现我们刚刚转化后的镜像 用docker run -it 用户名/仓库名 tag信息 我们就能运行刚刚转化后的容器
接下来我们需要把这个刚刚创建好的容器上传到docker hub容器仓库中方便以后重复使用或者被别人使用
//首先登陆docker hub docker login //然后我们以此输入 用户名 密码和 邮箱 最后返回login success提示 //运行push 命令即可上传到docker hub中 docker push 用户名/仓库名 tag信息 //然后你就可以在docker hub中看到你上传的镜像
dockerfile使用
案例:利用nginx创建一个网页
首先我们新建一个 www 目录 然后存放一个index.html文件 随便写一写些内容
然后在www同级目录下存放一个名为dockerfle的文件并书写内容为
FROM ubuntu:14.04 //声明构建镜像 MAINTAINER saymagic saymagic@163.com //告诉别人你的名字和联系方式 RUN apt-get update RUN apt-get install -y nginx COPY ./www/user/share/nginx/html //将当前系统文件拷贝到容器内目录下 EXPOSE 80 //声明开放80端口 CMD ["nginx","-g","daemon off;"] //表示运行容器的时候开启nginx //最后我们通过build来构建镜像 运行 docker build -t="用户名/仓库名 tag信息"
此时我们运行 docker images 就会看到刚刚生成的镜像,现在我们就可以运行刚刚的镜像了,和前面运行稍有不同,此时我们需要对外指定80端口,该行为通过-p参数指定,运行
docker run -p 80:80 用户名/仓库名 tag信息
此时终端会卡 因为docker思想是每个容器最好只开一个线程做一件事 现在我们可以通过localhost 查看效果
总结
docker会让我们的开发变得便捷,让合作变得简单,当然还有更多docker的命令文中没有介绍,希望大家一起参考官方文档去慢慢实践练习,刚刚的例子如果不满足只在本地访问在我们没有自己服务器的前提下 利用daocloud 就可只负责写dockerfile 剩下的命令由daocloud完成。
官方传送门:https://www.daocloud.io/
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍GridView使用学习总结,包括了GridView使用学习总结的使用技巧和注意事项,需要的朋友参考一下 由于Asp.Net视频比较旧,涉及到的数据绑定控件DataGrid在VS2012中已经没有了,取而代之的是GridView。开始觉得视频中的例子没法实现了,其实不然,DataGrid里面的功能GridView里一样都不少,只是形式变化了一下,仔细研究一下发现它们是换汤不换药啊。
本文向大家介绍Docker学习之常用的基础命令总结,包括了Docker学习之常用的基础命令总结的使用技巧和注意事项,需要的朋友参考一下 前言 Docker是一个用了一种新颖方式实现的超轻量虚拟机,在实现的原理和应用上还是和VM有巨大差别,专业的叫法是应用容器(Application Container)。下面这篇文章将简单介绍一下Docker常用的一些基础命令。 当利用 docker run 来创
Python 是一种跨平台的计算机程序设计语言。 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。
本文向大家介绍JQuery学习总结【二】,包括了JQuery学习总结【二】的使用技巧和注意事项,需要的朋友参考一下 一:JQuery知识点 *:JQuery的dom操作 *:动态创建dom节点 比如动态创建表格等,在js里面进行完成。 *删除节点 这里面的删除就是将其放在了一个地方,并不是真的删除,之后可以使用。 *:document方法 1:.val()可以获取到文本框里面的值,若括号里面有值则
有四种类型的znode: PERSISTENT-持久化目录节点 客户端与zookeeper断开连接后,该节点依旧存在 PERSISTENT_SEQUENTIAL-持久化顺序编号目录节点 客户端与zookeeper断开连接后,该节点依旧存在,只是Zookeeper给该节点名称进行顺序编号 EPHEMERAL-临时目录节点 客户端与zookeeper断开连接后,该节点被删除 EPHEMERAL_SEQ
从sklearn加载流行数字数据集。数据集模块,并将其分配给可变数字。 分割数字。将数据分为两组,分别命名为X_train和X_test。还有,分割数字。目标分为两组Y_训练和Y_测试。 提示:使用sklearn中的训练测试分割方法。模型选择;将随机_状态设置为30;并进行分层抽样。使用默认参数,从X_序列集和Y_序列标签构建SVM分类器。将模型命名为svm_clf。 在测试数据集上评估模型的准确