导航:首页 > IDC知识 > docker镜像生成域名

docker镜像生成域名

发布时间:2021-01-28 08:19:53

1、docker怎么修改拉取源从指定的国内仓库拉取镜像

我看到这个问题首先想到的就是去docker hub搜官方的镜像.然后看了redis的Dockerfile。官方的方法是(对应楼上的1)Additionally, If you want to use your own redis.conf ...You can create your own Dockerfile that adds a redis.conf from the context into /data/, like soFROM redisCOPY redis.conf /usr/local/etc/redis/redis.confCMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ]或者$ docker run -v /myredis/conf/redis.conf:/usr/local/etc/redis/redis.conf --name myredis redis redis-server /usr/local/etc/redis/redis.conf这个镜像启动的时候就默认运行redis-server了。无法通过docker run -it redis修改。试图docker run -it redis /bin/bash进去覆盖默认的启动命令然后添加自己的配置就好了。希望能帮到你

2、如何合并两个Docker 镜像

如何通过docker history命令来对docker 镜像进行反向工程推测它们的Dockerfile,从而在对不同的Docker 镜像反向工程获取Dockerfile 之后合并成一个。
常言道,“不要重复发明轮子!”
在使用docker 时,最好在构建你自己的镜像前上 Docker Hub 寻找一些直接可以用的。把你的软件架构分布到一系列容器中,每一个容器只做一件事情是非常有用的。构建分布式应用的最好的基石是使用来自Docker Hub 的官方镜像,因为你可以信任它们的质量。
在某些情况下,你可能想让一个容器做两件不同的事情。在另一些情况下,你可能想让一个Docker 镜像包含来自两个不同镜像的依赖。 如果你有每个镜像的Dockerfile,这是非常简单的。将它们组织到一个Dockerfile 里然后build 即可。
但是,如果大多数时间你都在使用Docker Hub 上准备好的镜像,你将没有它们的源Dockerfile。我花了一些时间来找这样一个工具,它可以合并(或flatten)两个不同的我没有它们的 Dockerfile 的Docker 镜像。即我在找一个能做下面这件事的东西:
image 1 --
\
---> merged_image_12
/
image 2 --

尽管这个问题在之前的两个进程中被关闭了( 1 , 2 ),当你想这么做时,这个问题仍然会产生。

3、如何使用Dockerfile构建镜像

你好,使用方法如下:
Dockerfile结构
dockerfile由4部分信息组成:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行指令。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# This dockerfile uses the ubuntu image
# VERSION 2 - EDITION 1
# Author: docker_user
# Command format: Instruction [arguments / command] ..

# Base image to use, this must be set as the first line
FROM ubuntu

# Maintainer: docker_user <docker_user at email.com> (@docker_user)
MAINTAINER docker_user [email protected]

# Commands to update the image
RUN echo "deb http://archive.ubuntu.com/ubuntu/ raring main universe" >> /etc/apt/sources.list
RUN apt-get update && apt-get install -y nginx
RUN echo "\ndaemon off;" >> /etc/nginx/nginx.conf

# Commands when creating a new container
CMD /usr/sbin/nginx

其中#表注释,可以标注一些说明性的文字。
FROM关键字指定镜像的来源,默认为DockerHub,也可以写私有仓库的镜像,例如:localhost:5000/centos:6.7,如果本地已经存在指定的镜像名称,则会从本地缓存直接获取。MAINTAINER 指定镜像的作者,之后为镜像操作执行RUN、ADD等,最后是容器启动时发起的指令。
Dockerfile中的指令
FROM: 指定镜像名称,格式为FROM <image> 或FROM <image>:<tag>,例如FROM ubuntu 或 FROM ubuntu:12.04 
MAINTAINER: 镜像作者 ,格式为 MAINTAINER <name>
RUN:格式为 RUN <command> 或 RUN ["executable", "param1", "param2"]。
前者将在 shell 终端中运行命令,即 /bin/sh -c;后者则使用 exec 执行。指定使用其它终端可以通过第二种方式实现,例如 RUN ["/bin/bash", "-c", "echo hello"]。
每条 RUN 指令将在当前镜像基础上执行指定命令,并提交为新的镜像。当命令较长时可以使用 \ 来换行。
CMD:支持三种格式
1.CMD ["executable","param1","param2"] 使用 exec 执行,推荐方式;
2.CMD command param1 param2 在 /bin/sh 中执行,提供给需要交互的应用;
3.CMD ["param1","param2"] 提供给 ENTRYPOINT 的默认参数;
指定启动容器时执行的命令,每个 Dockerfile 只能有一条 CMD 命令。如果指定了多条命令,只有最后一条会被执行。如果用户启动容器时候指定了运行的命令,则会覆盖掉 CMD 指定的命令。
EXPOSE:格式为 EXPOSE <port> [<port>...]。
告诉 Docker 服务端容器暴露的端口号,供互联系统使用。在启动容器时需要通过 -P,Docker 主机会自动分配一个端口转发到指定的端口。
ENV:格式为 ENV <key> <value>。 指定一个环境变量,会被后续 RUN 指令使用,并在容器运行时保持。这就对应程序语言中的变量定义,可在需要的时候引用。例如:

1
2
3
4

ENV PG_MAJOR 9.3
ENV PG_VERSION 9.3.4
RUN curl -SL http://example.com/postgres-$PG_VERSION.tar.xz | tar -xJC /usr/src/postgress && …
ENV PATH /usr/local/postgres-$PG_MAJOR/bin:$PATH

ADD:格式为 ADD <src> <dest>。
该命令将复制指定的 <src> 到容器中的 <dest>。 其中 <src> 可以是Dockerfile所在目录的一个相对路径;也可以是一个 URL;还可以是一个 tar 文件(自动解压为目录)。
COPY:格式为 COPY <src> <dest>。
复制本地主机的 <src>(为 Dockerfile 所在目录的相对路径)到容器中的 <dest>。当使用本地目录为源目录时,推荐使用 COPY。
COPY和ADD的不同就是:ADD多了自动解压和支持URL路径的功能。
ENTRYPOINT:
两种格式:
ENTRYPOINT ["executable", "param1", "param2"]
ENTRYPOINT command param1 param2(shell中执行)。
配置容器启动后执行的命令,并且不可被 docker run 提供的参数覆盖。
每个 Dockerfile 中只能有一个 ENTRYPOINT,当指定多个时,只有最后一个起效。
CMD和ENTRYPOINT比较:两个命令都是只能使用一次,并且都是在执行docker run指令时运行,如果有多个,只执行最后一条。
两者的不同在于参数的传递方式,如果在Dockerfile中定义如下指令

1

CMD echo hello



1

ENTRYPOINT ["echo","hello"] 

那么在运行命令docker run containerId echo hello时,指定了CMD的输入结果为world,可以看出Dockerfile中指定的命令被覆盖了,而指定了ENTRYPOINT时,输出结果为hello echo world,可以看出指定的命令被作为ENTRYPOINT指定指令的参数了。

VOLUME:格式为 VOLUME ["/data"]。创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等。不过此属性在Dockerfile中指定并没有什么意义,因为没有办法指定本地主机的目录。如果需要指定挂载点可以在执行docker run命令时指定:

1

docker run -it -v /home/fengzheng/ftp/:/data 859666d51c6d /bin/bash

USER:格式为 USER daemon。指定运行容器时的用户名或 UID,后续的 RUN 也会使用指定用户。
当服务不需要管理员权限时,可以通过该命令指定运行用户。并且可以在之前创建所需要的用户,例如:RUN groupadd -r postgres && useradd -r -g postgres postgres。要临时获取管理员权限可以使用 gosu,而不推荐 sudo。
WORKDIR:格式为 WORKDIR /path/to/workdir。为后续的 RUN、CMD、ENTRYPOINT 指令配置工作目录。可以使用多个 WORKDIR 指令,后续命令如果参数是相对路径,则会基于之前命令指定的路径。例如

1
2
3
4

WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd

则最终路径为 /a/b/c。
ONBUILD:格式为 ONBUILD [INSTRUCTION]。
配置当所创建的镜像作为其它新创建镜像的基础镜像时,所执行的操作指令。
例如,Dockerfile 使用如下的内容创建了镜像 image-A。

1
2
3
4

[...]
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src
[...]

如果基于 image-A 创建新的镜像时,新的Dockerfile中使用 FROM image-A指定基础镜像时,会自动执行ONBUILD 指令内容,等价于在后面添加了两条指令。

1
2
3
4
5

FROM image-A

#Automatically run the following
ADD . /app/src
RUN /usr/local/bin/python-build --dir /app/src

使用 ONBUILD 指令的镜像,推荐在标签中注明,例如 ruby:1.9-onbuild。
基于CentOS6.7并源码安装nginx
首先准备了nginx-1.9.9.tar.gz安装包和CentOS6-Base-163.repo(163源),将这两个文件放到同一目录下,并在此目录下创建名称为Dockerfile的文件。之后在此文件中实现源替换、nginx编译安装、及一些依赖包的安装,Dockerfile内容如下:

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

# this is a test ubuntu 12.04 image dockerfile
# Author:fengzheng

# Base image,this must be set as the first line
#localhost:5000/centos:6.7是我的私有仓库的镜像,可替换为centos:6.7(DockerHub中的镜像)
FROM localhost:5000/centos:6.7

MAINTAINER fengzheng

# Commands to update the image

RUN mkdir /usr/nginx1.9.9
ADD nginx-1.9.9.tar.gz /usr/nginx1.9.9/
#RUN yum -y install tar
#RUN tar -zxvf /usr/nginx1.9.9/nginx-1.9.9.tar.gz
RUN cd /etc/yum.repos.d/ && mv CentOS-Base.repo CentOS-Base.repo.bak
ADD CentOS6-Base-163.repo /etc/yum.repos.d/
RUN cd /etc/yum.repos.d/ && mv CentOS6-Base-163.repo CentOS-Base.repo \
&& yum clean all && yum makecache \
&& yum -y install gcc \
&& yum -y install yum install -y pcre-devel \
&& yum -y install zlib zlib-devel \
&& yum -y install openssl openssl--devel \
&& cd /usr/nginx1.9.9/nginx-1.9.9/ && ./configure && make && make install

#如果设置daemon off; nginx无法启动
#RUN echo "\ndaemon off;" >> /etc/nginx/nginx.conf

# Commands when creating a new container
# 启动nginx 需进入/usr/local/nginx/sbin 执行./configure
CMD /bin/bash

最后执行命令"docker build -t nginx-centos:6.7 ."
其中.表示在当前目录下搜索Dockerfile文件,-t参数指定镜像名称和tag。

4、如何构建docker镜像

?

5、如何用Gradle创建Docker镜像

Dockerfile结构
dockerfile由4部信息组:基础镜像信息、维护者信息、镜像操作指令容器启执行指令

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# This dockerfile uses the ubuntu image
# VERSION 2 - EDITION 1
# Author: docker_user
# Command format: Instruction [arguments / command] ..

# Base image to use, this must be set as the first line
FROM ubuntu

# Maintainer: docker_user (@docker_user)
MAINTAINER docker_user [email protected]

# Commands to update the image
RUN echo "deb raring main universe" >> /etc/apt/sources.list
RUN apt-get update && apt-get install -y nginx
RUN echo "\ndaemon off;" >> /etc/nginx/nginx.conf

# Commands when creating a new container
CMD /usr/sbin/nginx

其#表注释标注些说明性文字
FROM关键字指定镜像源默认DockerHub写私仓库镜像例:localhost:5000/centos:6.7本已经存指定镜像名称则本缓存直接获取MAINTAINER 指定镜像作者镜像操作执行RUN、ADD等容器启发起指令
Dockerfile指令
FROM: 指定镜像名称格式FROM 或FROM :例FROM ubuntu 或 FROM ubuntu:12.04 
MAINTAINER: 镜像作者 格式 MAINTAINER
RUN:格式 RUN 或 RUN ["executable", "param1", "param2"]
前者 shell 终端运行命令即 /bin/sh -c;者则使用 exec 执行指定使用其终端通第二种式实现例 RUN ["/bin/bash", "-c", "echo hello"]
每条 RUN 指令前镜像基础执行指定命令并提交新镜像命令较使用 \ 换行
CMD:支持三种格式
1.CMD ["executable","param1","param2"] 使用 exec 执行推荐式;
2.CMD command param1 param2 /bin/sh 执行提供给需要交互应用;
3.CMD ["param1","param2"] 提供给 ENTRYPOINT 默认参数;
指定启容器执行命令每 Dockerfile 能条 CMD 命令指定条命令条执行用户启容器候指定运行命令则覆盖掉 CMD 指定命令
EXPOSE:格式 EXPOSE [...]
告诉 Docker 服务端容器暴露端口号供互联系统使用启容器需要通 -PDocker 主机自配端口转发指定端口
ENV:格式 ENV 指定环境变量续 RUN 指令使用并容器运行保持应程序语言变量定义需要候引用例:

1
2
3
4

ENV PG_MAJOR 9.3
ENV PG_VERSION 9.3.4
RUN curl -SL | tar -xJC /usr/src/postgress && …
ENV PATH /usr/local/postgres-$PG_MAJOR/bin:$PATH

ADD:格式 ADD
该命令复制指定 容器 其 Dockerfile所目录相路径; URL; tar 文件(自解压目录)
COPY:格式 COPY
复制本主机 ( Dockerfile 所目录相路径)容器 使用本目录源目录推荐使用 COPY
COPYADD同:ADD自解压支持URL路径功能
ENTRYPOINT:
两种格式:
ENTRYPOINT ["executable", "param1", "param2"]
ENTRYPOINT command param1 param2(shell执行)
配置容器启执行命令并且 docker run 提供参数覆盖
每 Dockerfile 能 ENTRYPOINT指定起效
CMDENTRYPOINT比较:两命令都能使用并且都执行docker run指令运行执行条
两者同于参数传递式Dockerfile定义指令

1

CMD echo hello



1

ENTRYPOINT ["echo","hello"] 

运行命令docker run containerId echo hello指定CMD输入结world看Dockerfile指定命令覆盖指定ENTRYPOINT输结hello echo world看指定命令作ENTRYPOINT指定指令参数

VOLUME:格式 VOLUME ["/data"]创建本主机或其容器挂载挂载点般用存放数据库需要保持数据等属性Dockerfile指定并没意义没办指定本主机目录需要指定挂载点执行docker run命令指定:

1

docker run -it -v /home/fengzheng/ftp/:/data 859666d51c6d /bin/bash

USER:格式 USER daemon指定运行容器用户名或 UID续 RUN 使用指定用户
服务需要管理员权限通该命令指定运行用户并且前创建所需要用户例:RUN groupadd -r postgres && useradd -r -g postgres postgres要临获取管理员权限使用 gosu推荐 sudo
WORKDIR:格式 WORKDIR /path/to/workdir续 RUN、CMD、ENTRYPOINT 指令配置工作目录使用 WORKDIR 指令续命令参数相路径则基于前命令指定路径例

1
2
3
4

WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd

则终路径 /a/b/c
ONBUILD:格式 ONBUILD [INSTRUCTION]
配置所创建镜像作其新创建镜像基础镜像所执行操作指令
例Dockerfile 使用内容创建镜像 image-A

1
2
3
4

[...]
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src
[...]

基于 image-A 创建新镜像新Dockerfile使用 FROM image-A指定基础镜像自执行ONBUILD 指令内容等价于面添加两条指令

1
2
3
4
5

FROM image-A

#Automatically run the following
ADD . /app/src
RUN /usr/local/bin/python-build --dir /app/src

使用 ONBUILD 指令镜像推荐标签注明例 ruby:1.9-onbuild
基于CentOS6.7并源码安装nginx
首先准备nginx-1.9.9.tar.gz安装包CentOS6-Base-163.repo(163源)两文件放同目录并目录创建名称Dockerfile文件文件实现源替换、nginx编译安装、及些依赖包安装Dockerfile内容:

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

# this is a test ubuntu 12.04 image dockerfile
# Author:fengzheng

# Base image,this must be set as the first line
#localhost:5000/centos:6.7我私仓库镜像替换centos:6.7(DockerHub镜像)
FROM localhost:5000/centos:6.7

MAINTAINER fengzheng

# Commands to update the image

RUN mkdir /usr/nginx1.9.9
ADD nginx-1.9.9.tar.gz /usr/nginx1.9.9/
#RUN yum -y install tar
#RUN tar -zxvf /usr/nginx1.9.9/nginx-1.9.9.tar.gz
RUN cd /etc/yum.repos.d/ && mv CentOS-Base.repo CentOS-Base.repo.bak
ADD CentOS6-Base-163.repo /etc/yum.repos.d/
RUN cd /etc/yum.repos.d/ && mv CentOS6-Base-163.repo CentOS-Base.repo \
&& yum clean all && yum makecache \
&& yum -y install gcc \
&& yum -y install yum install -y pcre-devel \
&& yum -y install zlib zlib-devel \
&& yum -y install openssl openssl--devel \
&& cd /usr/nginx1.9.9/nginx-1.9.9/ && ./configure && make && make install

#设置daemon off; nginx启
#RUN echo "\ndaemon off;" >> /etc/nginx/nginx.conf

# Commands when creating a new container
# 启nginx 需进入/usr/local/nginx/sbin 执行./configure
CMD /bin/bash

执行命令"docker build -t nginx-centos:6.7 ."
其.表示前目录搜索Dockerfile文件-t参数指定镜像名称tag

6、docker 怎么从镜像仓库获取镜像

配置docker的启动参数。

执行:

# systemctl status docker 1

如图红框所示,修改/usr/lib/systemd/system/docker.service

启动参数增加--add-registry=master.example.com:5000  --insecure-registry=master.example.com:5000

重启docker:

# systemctl daemon-reload# systemctl restart docker12

验证

执行:

# docker info1

输出最后一行有:回

Registries: master.example.com:5000 (insecure), docker.io (secure)1

registry添加成功。答

我的docker本地镜像仓库中有tomcat:8.5.16。内网环境下测试执行:

# docker pull tomcat:8.5.161

可以看出,这里在执行docker pull的时候不需要带上本地镜像仓库的地址,直接会自动从本地镜像仓库拉取。

7、怎么把docker做成镜像文件

方法/步骤
在使用Docker的过程中,我们除了从Docker Hub上下载已经做好的镜像,很多时候回需要我们自己制作答镜像。下面想在这个文章中说明一下镜像的制作方法。

制作镜像的方式主要有两种:

通过docker commit 制作镜像
通过docker build 制作镜像
这两种方式都是通过改进已有的镜像来达到自己的目的。制作基础镜像,会在另外一篇文章“从零开始制作基础镜像”中介绍。

docker commit
docker commit 是往版本控制系统里提交一次变更。使用这种方式制作镜像,本质上是运行一个基础镜像,然后在基础镜像上进行软件安装和修改。最后再将改动提交到版本系统中。

与docker镜像生成域名相关的知识