本文主要讲解了dockerfile的使用,在文章的最后加了一个dockerfile实现自制镜像的实战,如果你希望使用docker commit来制作镜像可以参考:
手动构建自己的docker容器镜像实战
🏠个人主页:我是沐风晓月
🧑个人简介:大家好,我是沐风晓月,阿里云社区博客专家😉😉
💕 座右铭: 先努力成长自己,再帮助更多的人 ,一起加油进步🍺🍺🍺
💕欢迎大家:这里是CSDN,我总结知识的地方,喜欢的话请三连,有问题请私信😘
文章目录
官网中的介绍: Docker can build images automatically by reading the instructions from a Dockerfile. A Dockerfile is a text document that contains all the commands a user could call on the command line to assemble an image。
Dockerfile 是一个文本文件,里面包含组装新镜像时用到的基础镜像和各种指令。
使用dockerfile 文件来定义镜像,然后运行镜像,启动容器。
一个dockerfile文件包含以下部分:
常见的镜像操作指令:
| 指令 | 描述 |
|---|---|
| FROM | # 基础镜像,一切从这里开始构建 |
| MAINTAINER | 镜像是谁写的,姓名+邮箱 |
| RUN | 镜像构建的时候需要运行的命令 |
| ADD | 添加内容: 比如加一个tomcat压缩包 |
| WORKDIR | 镜像的工作目录 |
| VOLUME | 镜像挂载的目录 |
| EXPOSE | 保留暴露的端口 |
| CMD | 指定这个容器启动的时候要运行的命令,只有最后一个会生效,可以被代替 |
| ENTRYPOINT | 指定这个容器启动的时候需要运行的命令,可以追加命令 |
| ONBUILD | 当构建一个被继承DockerFile 的时候就会运行 ONBUILD 的指令。触发指令 |
| COPY | 类似ADD ,将我们的文件拷贝到镜像中 |
| ENV | 构建的时候设置环境变量 |
在完成dockerfile文件的编写后,执行docker build命令,则会根据dockerfile文件中上下文的内容构建新的docker镜像。
整个构建过程会被递归处理,如果在dockerfile中包含了路径或者URL,都会被递归构建。
docker build 命令用于使用 Dockerfile 创建镜像
语法:
docker build [OPTIONS] PATH | URL | -
常用参数:
| 参数 | 解释 |
|---|---|
| –build-arg=[] | 设置镜像创建时的变量; |
| –cpu-shares | 设置 cpu 使用权重; |
| –cpu-period | 限制 CPU CFS周期; |
| –cpu-quota | 限制 CPU CFS配额; |
| –cpuset-cpus | 指定使用的CPU id; |
| –cpuset-mems | 指定使用的内存 id; |
| –disable-content-trust | 忽略校验,默认开启; |
| -f | 指定要使用的Dockerfile路径; |
| –force-rm | 设置镜像过程中删除中间容器; |
| –isolation | 使用容器隔离技术; |
| –label=[] | 设置镜像使用的元数据; |
| -m | 设置内存最大值; |
| –memory-swap | 设置Swap的最大值为内存+swap,"-1"表示不限swap; |
| –no-cache | 创建镜像的过程不使用缓存; |
| –pull | 尝试去更新镜像的新版本; |
| –quiet, -q | 安静模式,成功后只输出镜像 ID; |
| –rm | 设置镜像成功后删除中间容器; |
| –shm-size | 设置/dev/shm的大小,默认值是64M; |
| –ulimit | Ulimit配置。 |
| –squash | 将 Dockerfile 中所有的操作压缩为一层。 |
| –tag, -t: | 镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像设置多个标签。 |
| –network: | 默认 default。在构建期间设置RUN指令的网络模式 |
编写一个简单的centos镜像
在本地创建一个文件名为Dockerfile的文件
FROM centos:7.9.2009
# 指定基础镜像为 centos
MAINTAINER mufenggrow mufenggrow@163.com
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo "-----end-----"
CMD /bin/bash
.docker build -f dockerfile 文件名 -t 镜像名:[tag] .
测试:
因为最开始我们创建的文件名叫Dockerfile所以,不需要使用-f 参数
[root@mufenggrow ~]# ls
anaconda-ks.cfg Dockerfile
[root@mufenggrow ~]# docker build -t mufeng_centos .
[root@mufenggrow ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mufeng_centos latest 5233b48a8b4e 9 seconds ago 667MB
centos 7.9.2009 eeb6ee3f44bd 19 months ago 204MB
[root@mufenggrow ~]# ls
anaconda-ks.cfg Dockerfile initial-setup-ks.cfg 公共 模板 视频 图片 文档 下载 音乐 桌面
[root@mufenggrow ~]# docker run -itd mufeng_centos /bin/bash
0801e25a61e5999b1616d1f0073f39a7e5431e34d983445b3f349b7da6bf3fe6
[root@mufenggrow ~]# docker exec -it 0801e25a /bin/bash
[root@0801e25a61e5 local]# pwd
/usr/local
[root@0801e25a61e5 local]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.17.0.2 netmask 255.255.0.0 broadcast 172.17.255.255
ether 02:42:ac:11:00:02 txqueuelen 0 (Ethernet)
RX packets 8 bytes 656 (656.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
loop txqueuelen 1000 (Local Loopback)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
💕 好啦,这就是今天要分享给大家的全部内容了,我们下期再见!
💕 本文由沐风晓月原创,首发于CSDN博客, 博客主页:mufeng.blog.csdn.net
💕 日拱一卒无尽有,功不唐捐终入海
💕 喜欢的话记得点赞收藏哦
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A
我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只