Docker 建立镜像、修改、上传镜像java
–建立镜像有不少方法,用户能够从 Docker Hub 获取已有镜像并更新,也能够利用本地文件系统建立一个。python
1、建立镜像linux
建立镜像有不少方法,用户能够从 Docker Hub 获取已有镜像并更新,也能够利用本地文件系统建立一个。git
2、修改已有镜像github
一、先使用下载的镜像启动容器。web
$ docker run -t -i training/sinatra /bin/bash root@0b2616b0e5a8:/#
注意:记住容器的 ID,稍后还会用到。docker
二、在容器中添加 json 和 gem 两个应用。apache
root@0b2616b0e5a8:/# gem install json
当结束后,咱们使用 exit 来退出,如今咱们的容器已经被咱们改变了,使用 docker commit 命令来提交更新后的副本。django
$ sudo docker commit -m "Added json gem" -a "Docker Newbee" 0b2616b0e5a8 ouruser/sinatra:v2 4f177bd27a9ff0f6dc2a830403925b5360bfe0b93d476f7fc3231110e7f71b1c
其中,-m 来指定提交的说明信息,跟咱们使用的版本控制工具同样;-a 能够指定更新的用户信息;以后是用来建立镜像的容器的 ID;最后指定目标镜像的仓库名和 tag 信息。建立成功后会返回这个镜像的 ID 信息。json
使用 docker images 来查看新建立的镜像。
$ sudo docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE training/sinatra latest 5bc342fa0b91 10 hours ago 446.7 MB ouruser/sinatra v2 3c59e02ddd1a 10 hours ago 446.7 MB ouruser/sinatra latest 5db5f8471261 10 hours ago 446.7 MB
以后,可使用新的镜像来启动容器
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash root@78e82f680994:/#
3、利用 Dockerfile 来建立镜像
使用 docker commit 来扩展一个镜像比较简单,可是不方便在一个团队中分享。咱们可使用 docker build 来建立一个新的镜像。为此,首先须要建立一个 Dockerfile,包含一些如何建立镜像的指令。
新建一个目录和一个 Dockerfile
$ mkdir sinatra $ cd sinatra $ touch Dockerfile
Dockerfile 中每一条指令都建立镜像的一层,例如:
# This is a comment FROM ubuntu:14.04 MAINTAINER Docker Newbee <newbee@docker.com> RUN apt-get -qq update RUN apt-get -qqy install ruby ruby-dev RUN gem install sinatra
Dockerfile 基本的语法是
使用 # 来注释
FROM 指令告诉 Docker 使用哪一个镜像做为基础
接着是维护者的信息
RUN 开头的指令会在建立中运行,好比安装一个软件包,在这里使用 apt-get 来安装了一些软件
编写完成 Dockerfile 后可使用 docker build 来生成镜像。
$ sudo docker build -t="ouruser/sinatra:v2" . Uploading context 2.56 kB Uploading context Step 0 : FROM ubuntu:14.04 ---> 99ec81b80c55 Step 1 : MAINTAINER Newbee <newbee@docker.com> ---> Running in 7c5664a8a0c1 ---> 2fa8ca4e2a13 Removing intermediate container 7c5664a8a0c1 Step 2 : RUN apt-get -qq update ---> Running in b07cc3fb4256 ---> 50d21070ec0c Removing intermediate container b07cc3fb4256 Step 3 : RUN apt-get -qqy install ruby ruby-dev ---> Running in a5b038dd127e Selecting previously unselected package libasan0:amd64. (Reading database ... 11518 files and directories currently installed.) Preparing to unpack .../libasan0_4.8.2-19ubuntu1_amd64.deb ... Setting up ruby (1:1.9.3.4) ... Setting up ruby1.9.1 (1.9.3.484-2ubuntu1) ... Processing triggers for libc-bin (2.19-0ubuntu6) ... ---> 2acb20f17878 Removing intermediate container a5b038dd127e Step 4 : RUN gem install sinatra ---> Running in 5e9d0065c1f7 . . . Successfully installed rack-protection-1.5.3 Successfully installed sinatra-1.4.5 4 gems installed ---> 324104cde6ad Removing intermediate container 5e9d0065c1f7 Successfully built 324104cde6ad
其中 -t 标记来添加 tag,指定新的镜像的用户信息。“.” 是 Dockerfile 所在的路径(当前目录),也能够替换为一个具体的 Dockerfile 的路径。
能够看到 build 进程在执行操做。它要作的第一件事情就是上传这个 Dockerfile 内容,由于全部的操做都要依据 Dockerfile 来进行。而后,Dockfile 中的指令被一条一条的执行。每一步都建立了一个新的容器,在容器中执行指令并提交修改(就跟以前介绍过的 docker commit 同样)。当全部的指令都执行完毕以后,返回了最终的镜像 id。全部的中间步骤所产生的容器都被删除和清理了。
注意一个镜像不能超过 127 层
此外,还能够利用 ADD 命令复制本地文件到镜像;用 EXPOSE 命令来向外部开放端口;用 CMD 命令来描述容器启动后运行的程序等。例如
# put my local web site in myApp folder to /var/www ADD myApp /var/www # expose httpd port EXPOSE 80 # the command to run CMD ["/usr/sbin/apachectl", "-D", "FOREGROUND"]
如今能够利用新建立的镜像来启动一个容器。
$ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash root@8196968dac35:/#
还能够用 docker tag 命令来修改镜像的标签。
$ sudo docker tag 5db5f8471261 ouruser/sinatra:devel $ sudo docker images ouruser/sinatra REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE ouruser/sinatra latest 5db5f8471261 11 hours ago 446.7 MB ouruser/sinatra devel 5db5f8471261 11 hours ago 446.7 MB ouruser/sinatra v2 5db5f8471261 11 hours ago 446.7 MB
4、从本地文件系统导入
要从本地文件系统导入一个镜像,可使用 openvz(容器虚拟化的先锋技术)的模板来建立:openvz 的模板下载地址为templates 。
好比,先下载了一个 ubuntu-14.04 的镜像,以后使用如下命令导入:
sudo cat ubuntu-14.04-x86_64-minimal.tar.gz |docker import - ubuntu:14.04
而后查看新导入的镜像。
docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE ubuntu 14.04 05ac7c0b9383 17 seconds ago 215.5 MB
5、上传镜像
用户能够经过 docker push 命令,把本身建立的镜像上传到仓库中来共享。例如,用户在 Docker Hub 上完成注册后,能够推送本身的镜像到仓库中。
$ sudo docker push ouruser/sinatra The push refers to a repository [ouruser/sinatra] (len: 1) Sending image list Pushing repository ouruser/sinatra (3 tags)
一、概述
咱们制做好镜像后,有时须要将镜像复制到另外一台服务器使用。
能达到以上目的有两种方式,一种是上传镜像到仓库中(本地或公共仓库),可是另外一台服务器很肯能只是与当前服务器局域网想通而没有公网的,因此若是使用仓库的方式,只能本身搭建私有仓库,这会在另外一篇文章中介绍。
若是咱们仅仅是要复制到另外少数的服务器,搭建私有仓库显然没有这个必要,而将镜像保存为文件上传到其余服务器再从文件中载入镜像也是一个不错的选择。
可使用Docker save和Docker load命令来存储和载入镜像。
二、保存镜像为文件
若是要讲镜像保存为本地文件,可使用Docker save命令。
命令格式:
1
|
docker save -o 要保存的文件名 要保存的镜像
|
首先查看当前的镜像列表:
1
|
docker images
|
好比这里,咱们将java8的镜像保存为文件:
1
|
docker save -o java8.
tar
lwieske
/java-8
|
完成后经过 ls 命令便可看到文件。
三、从文件载入镜像
从文件载入镜像可使用Docker load命令。
命令格式:
1
|
docker load --input 文件
|
或者
1
|
docker load < 文件名
|
此时会导入镜像以及相关的元数据信息等。
首先使用SSH工具将文件上传到另外一台服务器。
而后经过命令载入镜像:
1
|
docker load < java8.
tar
|
导入后可使用docker images命令查看:
最近因为工做缘由,须要对Docker镜像进行制做,这里记录下,也许对你们也有必定帮助!
写在前面:本文docker镜像制做方法更适用于基于已有docker镜像一次性修改。
推荐用Docker File制做docker镜像。
原理是同样的,可是用docker file制做docker镜像可以记录下操做步骤,方便之后更改或者镜像丢失后从新建立。
本文以Ubuntu为基础镜像,预启动一个django项目和ssh服务,制做一个新的镜像。
一、基础镜像
我选用的是从Docker官网下载的ubuntu镜像。
docker run ubuntu
或者
docker pull ubuntu
二、安装ssh服务
docker run -i -t ubuntu /bin/bash #建立一个容器,-t是临时终端。
进入ubuntu后,安装openssh
apt-get install openssh-server #安装ssh
#须要修改/etc/sshd/sshd_config文件中内容
PermitRootLogin yes
UsePAM no
修改ubuntu的root用户密码,以便之后ssh登录:
sudo passwd root
三、制做新的镜像
到此,咱们须要把这个带有ssh服务的容器提交成一个镜像,方便之后在这个基础上各类改造:
docker commit <container id> <image name>
四、基于现有ssh服务的Ubuntu镜像,加入django项目,并设置随容器自启动
ok,通过以上步骤,doker images能够查看,新提交的doker镜像已经在里面了,例如image name为ssh-ubuntu的新镜像。
最基础的Ubuntu容器已经没有做用了
利用
doker stop <container id>
doker rm <Container id>
清楚刚刚启动的最基础的Ubuntu容器
下面,要基于咱们新的ssh-ubuntu进行个性化定制,首先,要将这个镜像运行起来
docker run -d -p 5001:22 ssh-ubuntu /usr/sbin/sshd -D
(-p为端口映射 容器中22端口应射程主机5001端口 || /usr/sbin/sshd -D是指定容器启动后要运行的command,本处是启动ssh服务)
容器启动后,咱们能够经过ssh的方式,登录到容器中
ssh root@doker0_ip -p 5001(22映射端口)
进入到容器后,就能够进行下一步个性化定制了。例如我要把个人django项目放到镜像中,并随着容器启动而启动。
(1)把django项目拷贝到容器中,用scp命令便可。
(2)比较通用的开机启动进程方法:
安装supervisor!
apt-get update && apt-get install supervisor
(若是apt-get install找不到包,先update一下)
而后编辑配置文件,vi /etc/supervisord.conf
1
2
3
4
5
6
7
|
[supervisord]
nodaemon=
true
[program:sshd]
command
=
/usr/sbin/sshd
-D
[program:tomcat]
command
=python ~
/manager
.py runserver 0.0.0.0:9999
|
而后保存退出便可。
用3小节方法从新制做新的镜像,清除当前容器便可。
五、运行新镜像
docker run -d -p 5001:22 -p 5000:9999 <image-name> /etc/supervisord
此时,能够访问主机5000端口,看看能不能访问到容器里面的django项目。
镜像制做大致过程至此完成。
*****************************************************************************************************************************************************
docker 自己是有push 来上传的 index.docker.io 的,使用是用pull拉取。可是没有条件搭建本地docker仓库或者须要将应用导出到另一个Docker环境中,咱们能够将docker镜像导出到一个文件,具体作法以下:
sudo docker export <容器id> > docker_app.tar
完成后咱们刚才制做的容器就导出成了 docker_app.tar 文件, 之后在其余机器部署的时候执行导入
cat docker_app.tar | sudo docker import - docker_app
管道后面的 docker_app 为导入后image命名,本身指定。
建立镜像的方法有三种:基于已有镜像的容器建立、基于本地模板导入、基于Dockerfile建立,本博文讲解前两种。
该方法是使用docker commit命令,其命令格式为:
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
主要参数选项包括:
好比,先建立一个运行bash的ubuntu容器:
docker run –it ubuntu /bin/bashroot@d8990fec2141:/# touch testroot@d8990fec2141:/# exit
而后根据建立的这个容器来提交一个新的镜像,提交时须要用到容器ID。
docker commit –m “test” –a “zmc” d8990fec2141 testimage
若是成功的话,就会返回新镜像的长ID号,而后能够查看看在本地已有的镜像:
docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEtestimage latest baea98d5a437 About a minute ago 188.3 MB……
第三行就是刚刚建立的镜像。
PS:利用此容器建立的镜像Id与此容器的镜像id不一样,可知它们不是同一镜像。
也能够从操做系统模板文件导入一个镜像,好比使用OpenVZ提供的模板建立,OPENVZ下载模板在:http://openvz.org/Download/template/precreated。
我尝试使用了Ubuntu14.04的模板:
1
|
wget http://download.openvz.org/template/precreated/ubuntu-14.04-x86_64-minimal.tar.gz
|
下载完以后就能够导入了:
sudo cat ubuntu–14.04–x86_64–minimal.tar.gz | docker import – ubuntu:14.04
其实只是两个命令,不过很显而易见,就不加解释了。成功的话,就会返回根据模板创建的镜像的长ID
sudo cat ubuntu–14.04–x86_64–minimal.tar.gz | docker import – ubuntu:14.04ab80404d13d580965b9919b640169ccb585ea7884e6aa9de1ec043075c65fe35
而后就能够查看本地的镜像:
docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEubuntu 14.04 ab80404d13d5 56 seconds ago 215.4 MBtestimage latest baea98d5a437 29 minutes ago 188.3 MB….
其实能够看出,虽然模板才75M,但建立的镜像并不小。
能够利用docker save和docker命令来存出和载入镜像。
若是想要把镜像存出到本地文件,可使用docker save命令,例如,存出本地的刚才建立的testimage:lastest为镜像文件testimage.tar文件:
docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEtestimage latest baea98d5a437 25 minutes ago 188.3 MBubuntu latest fa81ed084842 3 days ago 188.3 MB….docker save –o /data/testimage.tar testimage:latest
上面的第6行就是存出代码,这时在/data下就有一个testimage.tar文件,这时咱们把本地镜像rmi掉,而后尝试载入。
删除镜像以后的状态:
ubuntu@VM–223–238–ubuntu:/data$ docker rmi baea98d5a437Untagged: testimage:latestDeleted: baea98d5a4371a6abf9efc8c53a54a6fc5befd167bf91ce9fd4a28a6d1b7dc5bubuntu@VM–223–238–ubuntu:/data$ docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEubuntu 14.04 ab80404d13d5 5 minutes ago 215.4 MB
而后载入镜像:
docker load —input testimage.tardocker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEubuntu 14.04 ab80404d13d5 6 minutes ago 215.4 MBtestimage latest baea98d5a437 35 minutes ago 188.3 MB
第一行就是载入镜像,还能够简化写成:
docker load < testimage.tar
载入操做将会导入镜像以及相关的元数据信息(包括标签等)。
最后说点镜像的上传,镜像的管理方式很是像git,可使用docker push命令上传本身本地镜像到仓库,默认上传到DockerHub官方仓库(须要登录),命令格式:
docker push NAME[:TAG]
在上传以前通常会先为本身的镜像添加带本身名字(做者信息)的标签:
docker tag testimage:lastest zmc/testimage:lastestdocker pushzmc/testimage:lastest
有利于上传以后的区分。
我以为不管是运维团队仍是开发团队仍是一个实验室,都有必要有一个本身的Docker仓库,能够存放符合本身需求的环境或系统镜像,能够实现快速部署。
前言
在Docker Hub官网上注册账号,便可下载使用仓库里的所有的docker镜像。而由于网络缘由,国内的开发者没办法流畅的下载镜像,常常会出现下载中断的错误。解决方法就是使用国内的容器Hub加速服务,本质就是更改pull优先级较高的服务器为国内的站点。
国内docker镜像加速站
阿里云
DaoCloud
灵雀云
系统环境
操做系统: CentOS 7
docker版本: 1.9.1
DaoCloud加速
DaoCloud如今是提供一个一键脚本配置registry-mirror,然而对于上述环境是不起做用的。
执行docker守护服务的help命令,发现没有–registry-mirror这个选项,而是使用–add-registry选项。
具体命令以下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
$
sudo
docker daemon -h
Usage: docker daemon [OPTIONS]
Enable daemon mode
--add-registry=[] Registry to query before a public one
--api-cors-header= Set CORS headers
in
the remote API
-b, --bridge= Attach containers to a network bridge
--bip= Specify network bridge IP
--block-registry=[] Don't contact given registry
--cluster-advertise= Address or interface name to advertise
--cluster-store= Set the cluster store
--cluster-store-opt=map[] Set cluster store options
--confirm-def-push=
true
Confirm a push to default registry
-D, --debug=
false
Enable debug mode
--default-gateway= Container default gateway IPv4 address
--default-gateway-v6= Container default gateway IPv6 address
--default-
ulimit
=[] Set default ulimits
for
containers
--disable-legacy-registry=
false
Do not contact legacy registries
--dns=[] DNS server to use
--dns-opt=[] DNS options to use
--dns-search=[] DNS search domains to use
-e, --
exec
-driver=native Exec driver to use
--
exec
-opt=[] Set
exec
driver options
--
exec
-root=
/var/run/docker
Root of the Docker execdriver
--fixed-cidr= IPv4 subnet
for
fixed IPs
--fixed-cidr-v6= IPv6 subnet
for
fixed IPs
-G, --group=docker Group
for
the unix socket
-g, --graph=
/var/lib/docker
Root of the Docker runtime
-H, --host=[] Daemon socket(s) to connect to
--help=
false
Print usage
--icc=
true
Enable inter-container communication
--insecure-registry=[] Enable insecure registry communication
--ip=0.0.0.0 Default IP when binding container ports
--ip-forward=
true
Enable net.ipv4.ip_forward
--ip-masq=
true
Enable IP masquerading
--iptables=
true
Enable addition of iptables rules
--ipv6=
false
Enable IPv6 networking
-l, --log-level=info Set the logging level
--label=[] Set key=value labels to the daemon
--log-driver=json-
file
Default driver
for
container logs
--log-opt=map[] Set log driver options
--mtu=0 Set the containers network MTU
-p, --pidfile=
/var/run/docker
.pid Path to use
for
daemon PID
file
--registry-mirror=[] Preferred Docker registry mirror
-s, --storage-driver= Storage driver to use
--selinux-enabled=
false
Enable selinux support
--storage-opt=[] Set storage driver options
--tls=
false
Use TLS; implied by --tlsverify
--tlscacert=~/.docker
/ca
.pem Trust certs signed only by this CA
--tlscert=~/.docker
/cert
.pem Path to TLS certificate
file
--tlskey=~/.docker
/key
.pem Path to TLS key
file
--tlsverify=
false
Use TLS and verify the remote
--userland-proxy=
true
Use userland proxy
for
loopback traffic
|
在文件/etc/sysconfig/docker中增长如下代码:
ADD_REGISTRY='--add-registry [你的加速站网址]'
而后,重启Docker就能够了。
1
2
3
|
sudo
systemctl daemon-reload
sudo
service docker restart
|
使用镜像加速
1.拉取镜像前请先登陆: docker login daocloud.io(请使用用户名进行 login)
2.docker pull [你须要的镜像]
后续
通过使用测试:下载docker镜像时再也不出现下载失败提示,粗略估计下载速度在200k/s左右,基本知足使用需求。
一、概述
咱们制做好镜像后,有时须要将镜像复制到另外一台服务器使用。
能达到以上目的有两种方式,一种是上传镜像到仓库中(本地或公共仓库),可是另外一台服务器很肯能只是与当前服务器局域网想通而没有公网的,因此若是使用仓库的方式,只能本身搭建私有仓库,这会在另外一篇文章中介绍。
若是咱们仅仅是要复制到另外少数的服务器,搭建私有仓库显然没有这个必要,而将镜像保存为文件上传到其余服务器再从文件中载入镜像也是一个不错的选择。
可使用Docker save和Docker load命令来存储和载入镜像。
二、保存镜像为文件
若是要讲镜像保存为本地文件,可使用Docker save命令。
命令格式:
1
|
docker save -o 要保存的文件名 要保存的镜像
|
首先查看当前的镜像列表:
1
|
docker images
|
好比这里,咱们将java8的镜像保存为文件:
1
|
docker save -o java8.
tar
lwieske
/java-8
|
完成后经过 ls 命令便可看到文件。
三、从文件载入镜像
从文件载入镜像可使用Docker load命令。
命令格式:
1
|
docker load --input 文件
|
或者
1
|
docker load < 文件名
|
此时会导入镜像以及相关的元数据信息等。
首先使用SSH工具将文件上传到另外一台服务器。
而后经过命令载入镜像:
1
|
docker load < java8.
tar
|
导入后可使用docker images命令查看: