ADD
ADD与COPY很相似,ADD支持几使用tar文件和URL路径
ADD <src> ... <dest>
ADD ["<src>",..."<dest>"]
如果为URL且不是/结尾,则指定的文件将被下载并直接被创建为,如果以/结尾,则文件名URL指定的文件将被直接下载并保存为/
如果是一个本地的压缩tar文件,他将被展开成一个目录,其行为类似于"tar -x"命令;然而,通过URL获取到的tar文件将不会自动展开
如果有多个,或其间接或直接使用了通配符,则必须是一个以/结尾的目录路径;如果不以/结尾,则其被视作一个普通文件,的内容将被直接写入到
除此之外,ADD和COPY一样
- 示例
我們下載一個RUL的nginx到/usr/local/src/,来验证是否会被解压
[root@linuxEA_10_10_240_145 /data/linuxea]$ cat Dockerfile
# describe : test
FROM busybox:latest
MAINTAINER www.linuxea.com
LABEL maintainer="www.linuxea.com"
COPY index.html /data/wwwroot/index.html
COPY zabbix /data/wwwroot/zabbix/
ADD http://10.10.240.145/nginx-1.14.0.tar.gz /usr/local/src/
而后build
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker build -t marksugar/httpd:2 ./
Sending build context to Docker daemon 33.28kB
Step 1/6 : FROM busybox:latest
---> 59788edf1f3e
Step 2/6 : MAINTAINER www.linuxea.com
---> Using cache
---> 7f12e197dfba
Step 3/6 : LABEL maintainer="www.linuxea.com"
---> Using cache
---> c28e9c23ae2f
Step 4/6 : COPY index.html /data/wwwroot/index.html
---> Using cache
---> f51ffe499c66
Step 5/6 : COPY zabbix /data/wwwroot/zabbix/
---> Using cache
---> eb31fdcfcd13
Step 6/6 : ADD http://10.10.240.145/nginx-1.14.0.tar.gz /usr/local/src/
Downloading [==================================================>] 1.016MB/1.016MB
---> 0b2794e2984d
Successfully built 0b2794e2984d
Successfully tagged marksugar/httpd:3
而后进入容器查看,这个包事实上并没有被解压
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm marksugar/httpd:3 ls /usr/local/src
WARNING: IPv4 forwarding is disabled. Networking will not work.
nginx-1.14.0.tar.gz
接着在验证下本地的tag解压的方式,如下:
但是,有一个前提是我们要先现在这个nginx的tar包在本地
[root@linuxEA_10_10_240_145 /data/linuxea]$ wget http://10.10.240.145/nginx-1.14.0.tar.gz
--2018-12-06 21:24:39-- http://10.10.240.145/nginx-1.14.0.tar.gz
正在连接 10.10.240.145:80... 已连接。
已发出 HTTP 请求,正在等待回应... 200 OK
长度:1016272 (992K) [application/octet-stream]
正在保存至: “nginx-1.14.0.tar.gz”
100%[=====================================================================================================================>] 1,016,272 --.-K/s 用时 0.001s
2018-12-06 21:24:39 (688 MB/s) - 已保存 “nginx-1.14.0.tar.gz” [1016272/1016272])
那就成了这个样子
[root@linuxEA_10_10_240_145 /data/linuxea]$ cat Dockerfile
# describe : test
FROM busybox:latest
MAINTAINER www.linuxea.com
LABEL maintainer="www.linuxea.com"
COPY index.html /data/wwwroot/index.html
COPY zabbix /data/wwwroot/zabbix/
ADD nginx-1.14.0.tar.gz /usr/local/src/
在build,在看
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker build -t marksugar/httpd:4 ./
Sending build context to Docker daemon 1.05MB
Step 1/6 : FROM busybox:latest
---> 59788edf1f3e
Step 2/6 : MAINTAINER www.linuxea.com
---> Using cache
---> 7f12e197dfba
Step 3/6 : LABEL maintainer="www.linuxea.com"
---> Using cache
---> c28e9c23ae2f
Step 4/6 : COPY index.html /data/wwwroot/index.html
---> Using cache
---> f51ffe499c66
Step 5/6 : COPY zabbix /data/wwwroot/zabbix/
---> Using cache
---> eb31fdcfcd13
Step 6/6 : ADD nginx-1.14.0.tar.gz /usr/local/src/
---> d65a535b0842
Successfully built d65a535b0842
Successfully tagged marksugar/httpd:4
在查看,已经被解压
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm marksugar/httpd:4 ls /usr/local/src
WARNING: IPv4 forwarding is disabled. Networking will not work.
nginx-1.14.0
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm marksugar/httpd:4 ls /usr/local/src/nginx-1.14.0
WARNING: IPv4 forwarding is disabled. Networking will not work.
CHANGES
CHANGES.ru
LICENSE
README
auto
conf
configure
contrib
html
man
src
[root@linuxEA_10_10_240_145 /data/linuxea]$
WORKDIR
用于指定Dockerfile中所有的RUN,CMD,ENTRYPOINT,COPY和ADD指定设定工作目录
WORKDIR <dirpath>
在Dockerfile文件中,WORKDIR指令可出现多次,其路径也可以为相对路径,不过,其实相对此前一个WORKDIR指令指定的路径
另外,WORKDIR也可调用ENV指定定义的变量、
WORKDIR /var/log
WORKDIR $STATEPATH
像这样
WORKDIR /usr/local/src/
ADD nginx-1.14.0.tar.gz ./
WORKDIR
进入/usr/local/src/
目录,而后ADD nginx-1.14.0.tar.gz ./
将nginx-1.14.0.tar.gz
解压到当前目录,那当前目录也就是/usr/local/src/
目录
如果WORKDIR做了相对路径引用,逆序查找顺序的时候,逆序的第一个WORKDIR的位置就是他的工作目录。
Volume
此前,我们了解到,绑定挂载卷上可以指定容器和宿主机的目录的。但是,在dockerfile中的自动指定的时候,只能指定挂载点。
volume用于在image中创建一个挂载点目录,以挂载Docker host上的卷或其他容器上的卷
VOLUME <mountpoint> 或 VOLUME ["<mountpoint>"]
如果挂载点目录路径下此前的文件存在,docker run命令会在卷挂载完成后将此前的文件复制到新挂载的卷中
我们将VOLUME /data/mariadb/挂载
[root@linuxEA_10_10_240_145 /data/linuxea]$ cat Dockerfile
# describe : test
FROM busybox:latest
MAINTAINER www.linuxea.com
LABEL maintainer="www.linuxea.com"
COPY index.html /data/wwwroot/index.html
COPY zabbix /data/wwwroot/zabbix/
WORKDIR /usr/local/src/
ADD nginx-1.14.0.tar.gz ./
VOLUME /data/mariadb/
重新构建
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker build -t marksugar/httpd:5 ./
Sending build context to Docker daemon 1.05MB
Step 1/8 : FROM busybox:latest
---> 59788edf1f3e
Step 2/8 : MAINTAINER www.linuxea.com
---> Using cache
---> 7f12e197dfba
Step 3/8 : LABEL maintainer="www.linuxea.com"
---> Using cache
---> c28e9c23ae2f
Step 4/8 : COPY index.html /data/wwwroot/index.html
---> Using cache
---> f51ffe499c66
Step 5/8 : COPY zabbix /data/wwwroot/zabbix/
---> Using cache
---> eb31fdcfcd13
Step 6/8 : WORKDIR /usr/local/src/
Removing intermediate container 805c9be248af
---> 1659fdf0e432
Step 7/8 : ADD nginx-1.14.0.tar.gz ./
---> bcff476b6d7c
Step 8/8 : VOLUME /data/mariadb/
---> [Warning] IPv4 forwarding is disabled. Networking will not work.
---> Running in 2112dcfe986a
Removing intermediate container 2112dcfe986a
---> 664c3d943228
Successfully built 664c3d943228
Successfully tagged marksugar/httpd:5
run起来查看下是否被挂载
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm marksugar/httpd:5 mount|grep mariadb
WARNING: IPv4 forwarding is disabled. Networking will not work.
/dev/mapper/DTVG-root on /data/mariadb type xfs (rw,relatime,attr2,inode64,noquota)
也可以这样看
[root@linuxEA_10_10_240_145 ~]$ docker inspect linuxea1
...
"Mounts": [
{
"Type": "volume",
"Name": "49a020511459b54042ce42cfca7717455ced52b17d04ab8d92770832d4e8ab5a",
"Source": "/var/lib/docker/volumes/49a020511459b54042ce42cfca7717455ced52b17d04ab8d92770832d4e8ab5a/_data",
"Destination": "/data/mariadb",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
...
Voulume被定义在Dockerfile中,在启动的时候就不需要定义的,就会自动有一个存储卷,不过这个存储卷在宿主机的位置,用的是docker管理的路径格式。
EXPOSE
EXPOSE将容器内的已经监听的端口暴露出去,用于为容器打开指定的监听端口以实现与外部通信
EXPOSE <port>[/<protocol>][<promt>[/<protocol>] ...]
用于指定传输层协议,可为tcp或udp二者之一,默认为tcp协议
EXPOSE默认可以一次指定多个端口,如:
EXPOSE 11211/tcp 11211/udp
其中会自动生成一条DNAT规则,假如你使用的是默认网络
但是,这里只是负责暴露容器内监听的端口,并不意味着设置EXPOSE就已经暴露到宿主机。
至于到了宿主机上是什么端口,如果不指定,那就是随机的。一般情况下,在docker run的时候加-大P指定
-P表示要暴露的端口,而要暴露的端口是在镜象内EXPOSE配置的端口。
-P 11211:11211
我们试图暴露
[root@linuxEA_10_10_240_145 /data/linuxea]$ cat Dockerfile
# describe : test
FROM busybox:latest
MAINTAINER www.linuxea.com
LABEL maintainer="www.linuxea.com"
COPY index.html /data/wwwroot/index.html
COPY zabbix /data/wwwroot/zabbix/
WORKDIR /usr/local/src/
ADD nginx-1.14.0.tar.gz ./
VOLUME /data/mariadb/
EXPOSE 80/tcp
build
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker build -t marksugar/httpd:6 ./
Sending build context to Docker daemon 1.05MB
Step 1/9 : FROM busybox:latest
---> 59788edf1f3e
Step 2/9 : MAINTAINER www.linuxea.com
---> Using cache
---> 7f12e197dfba
Step 3/9 : LABEL maintainer="www.linuxea.com"
---> Using cache
---> c28e9c23ae2f
Step 4/9 : COPY index.html /data/wwwroot/index.html
---> Using cache
---> f51ffe499c66
Step 5/9 : COPY zabbix /data/wwwroot/zabbix/
---> Using cache
---> eb31fdcfcd13
Step 6/9 : WORKDIR /usr/local/src/
---> Using cache
---> 1659fdf0e432
Step 7/9 : ADD nginx-1.14.0.tar.gz ./
---> Using cache
---> bcff476b6d7c
Step 8/9 : VOLUME /data/mariadb/
---> Using cache
---> 664c3d943228
Step 9/9 : EXPOSE 80/tcp
---> [Warning] IPv4 forwarding is disabled. Networking will not work.
---> Running in 1b82b3db2f99
Removing intermediate container 1b82b3db2f99
---> 23efb60395d4
Successfully built 23efb60395d4
Successfully tagged marksugar/httpd:6
而后我们run起这个容器,并且使用httpd -f -h /data/wwwroot/
启动httpd
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm marksugar/httpd:6 httpd -f -h /data/wwwroot/
WARNING: IPv4 forwarding is disabled. Networking will not work.
获取到此容器的ip
[root@linuxEA_10_10_240_145 ~]$ docker inspect -f {{.NetworkSettings.Networks.bridge.IPAddress}} linuxea1
192.168.100.2
访问试试
[root@linuxEA_10_10_240_145 ~]$ curl 192.168.100.2
linuxea-2018年 12月 06日 星期四 19:52:14 CST
当然,你也可以这样
[root@linuxEA_10_10_240_145 ~]$ curl $(docker inspect -f {{.NetworkSettings.Networks.bridge.IPAddress}} linuxea1)
linuxea-2018年 12月 06日 星期四 19:52:14 CST
- -P
那么此时也是没有暴露端口的,因为没有加-p选项,没有-p选项就是待暴露,但是尚未暴露
[root@linuxEA_10_10_240_145 ~]$ docker port linuxea1
[root@linuxEA_10_10_240_145 ~]$
那现在可以使用-P指定,也就是随机的
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm -P marksugar/httpd:6 httpd -f -h /data/wwwroot/
WARNING: IPv4 forwarding is disabled. Networking will not work.
在看
[root@linuxEA_10_10_240_145 ~]$ docker port linuxea1
80/tcp -> 0.0.0.0:1024
我们通过宿主机的ip访问1024
[root@linuxEA_10_10_240_145 ~]$ curl 10.10.240.145:1024
linuxea-2018年 12月 06日 星期四 19:52:14 CST
有些乱码,我们暂且不管
- -p
也可以使用-p 使用-p 81:80,将容器的80暴露到宿主机的81端口
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm -p 81:80 marksugar/httpd:6 httpd -f -h /data/wwwroot/
WARNING: IPv4 forwarding is disabled. Networking will not work.
[root@linuxEA_10_10_240_145 ~]$ docker port linuxea1
80/tcp -> 0.0.0.0:81
[root@linuxEA_10_10_240_145 ~]$ curl 10.10.240.145:81
linuxea-2018年 12月 06日 星期四 19:52:14 CST
ENV
ENV用于镜象定义所需的环境变量,并可被Dockerfile文件中位于其后的其他指令(如ENV,ADD,COPY等)所调用
调用格式为$varibale_name
或${varibale_name}
ENV <key> <value> 或 ENV <key>=<value>
第一种格式中,之后的所有内容均会被起视作为的组成部分,因此,一次只能设置一个变量
第二种格式可用一次是设置多个变量,每个变量作为一个"="的键值对,如果中包含空格,可以以反射线()
进行转义,也可以通过对加引号进行标识;另外,反斜线也可用于续行
定义多个变量的时候,可以使用第二种方式,以便于在同一层中完成所有功能
我们添加几个变量而后在中应用,如下
ENV NG_PATH /usr/local/src/
ENV NG_VERSION="1.14.0"
ZABBIX=/data/wwwroot/zabbix/
引用
COPY zabbix $ZABBIX
WORKDIR ${NG_PATH:-/usr/local/src/}
ADD nginx-${NG_VERSION:-1.14.0}.tar.gz ./
${NG_PATH:-/usr/local/src/}
这里可以用${NG_PATH:-}
的方式,也就是说,如果没有变量或者变量为空值,默认参数就是/usr/local/src/
,最终如下:
[root@linuxEA_10_10_240_145 /data/linuxea]$ cat Dockerfile
# describe : test
FROM busybox:latest
MAINTAINER www.linuxea.com
ENV NG_PATH /usr/local/src/
ENV NG_VERSION="1.14.0"
ZABBIX=/data/wwwroot/zabbix/
LABEL maintainer="www.linuxea.com"
COPY index.html /data/wwwroot/index.html
COPY zabbix $ZABBIX
WORKDIR ${NG_PATH:-/usr/local/src/}
ADD nginx-${NG_VERSION:-1.14.0}.tar.gz ./
VOLUME /data/mariadb/
EXPOSE 80/tcp
而后build
root@linuxEA_10_10_240_145 /data/linuxea]$ docker build -t marksugar/httpd:7 ./
Sending build context to Docker daemon 1.05MB
Step 1/11 : FROM busybox:latest
---> 59788edf1f3e
Step 2/11 : MAINTAINER www.linuxea.com
---> Using cache
---> 7f12e197dfba
Step 3/11 : ENV NG_PATH /usr/local/src/
---> Running in e228dd6984c8
Removing intermediate container e228dd6984c8
---> e6c199578807
Step 4/11 : ENV NG_VERSION="1.14.0" ZABBIX=/data/wwwroot/zabbix/
---> Running in 0322efbf9c4c
Removing intermediate container 0322efbf9c4c
---> c0b20f2d3726
Step 5/11 : LABEL maintainer="www.linuxea.com"
---> Running in f5fdceb54d99
Removing intermediate container f5fdceb54d99
---> 9236122c20ae
Step 6/11 : COPY index.html /data/wwwroot/index.html
---> f13e97d53c76
Step 7/11 : COPY zabbix $ZABBIX
---> 4b46be31391c
Step 8/11 : WORKDIR ${NG_PATH:-/usr/local/src/}
Removing intermediate container 4ca70ebc77a9
---> 48b53e685832
Step 9/11 : ADD nginx-${NG_VERSION:-1.14.0}.tar.gz ./
---> d785091af380
Step 10/11 : VOLUME /data/mariadb/
---> Running in fb2d1a8ccdbf
Removing intermediate container fb2d1a8ccdbf
---> 7d93a3a2d717
Step 11/11 : EXPOSE 80/tcp
---> Running in 282a1384d563
Removing intermediate container 282a1384d563
---> 5f6b1362d52d
Successfully built 5f6b1362d52d
Successfully tagged marksugar/httpd:7
run起来验证下,变量被引用ok
[root@linuxEA_10_10_240_145 ~]$ docker run --name linuxea1 --rm -p 81:80 marksugar/httpd:7 ls /usr/local/src
nginx-1.14.0
[root@linuxEA_10_10_240_145 ~]$ docker run --name linuxea1 --rm -p 81:80 marksugar/httpd:7 ls /data/wwwroot/zabbix
scripts
zabbix_agentd.conf
zabbix_agentd.d
那么这些ENV定义在Dockerfile中,而后在启动的容器中是已经存在
[root@linuxEA_10_10_240_145 ~]$ docker run --name linuxea1 --rm -p 81:80 marksugar/httpd:7 printenv
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=af3e048f900f
NG_PATH=/usr/local/src/
NG_VERSION=1.14.0
ZABBIX=/data/wwwroot/zabbix/
HOME=/root
尽管在build的时候,已经使用了一次这些环境变量构建了此前Dockerfile中变量值的构建,并且完成。但是,这些变量仍然在docker容器中,在run启动的时候是可以被重新赋值的。这个赋值当然是不会影响到此前构建过的惊喜,如果此时第二次调用被重新赋值过的变量,就会得到新的变量赋值
这次我们将之前的NG_VERSION=1.14.0
改成 NG_VERSION=1.15.2
,只需要在启动的时候使用-e,如:-e NG_VERSION="1.15.2"
。
[root@linuxEA_10_10_240_145 ~]$ docker run --name linuxea1 --rm -p 81:80 -e NG_VERSION="1.15.2" marksugar/httpd:7 printenv
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=df943feee8b7
NG_VERSION=1.15.2
NG_PATH=/usr/local/src/
ZABBIX=/data/wwwroot/zabbix/
HOME=/root
RUN
用于指定docker build过程中运行的程序,可以说任何命令
RUN <command>
RUN ["<executable>","<param1>","<param2>"]
- 第一种格式中,通常是一个shell命令,且以“/bin/sh -c”来运行它,这意味着此进程在容器中的pid不为1,不能接受unix信号。因此,当使用docker stop 命令停止容器时,此进程接收不到SIGTERM信号;
- 第二种语法格式中的参数是一个json格式的数组,其中为要运行的命令,后面的为传递给命令的选项或参数;然而,此种格式指令的命令不会以"/bin/sh -c "来发起,因此常见的shell操作如变量替换以及通配符(?,*等)替换将不会进行;不过,如果要运行的命令依赖于此shell特性的话,可以将其替换为类似下面的格式。
RUN ["/bin/bash","-c","<executable>","<param1>"]
RUN和CMD,RUN是在docker build中运行,也就说在构建镜像时候build过程中运行的命令;而CMD是在镜像启动的时候运行的命令,如果没有指定运行的命令,CMD就是默认运行的命令
我们加一段RUN命令,内容是下载nginx安装包,而后解压,并且更名,主要体验下RUN命令使用
RUN cd /usr/local
&& wget http://10.10.240.145/nginx-${NG_VERSION}.tar.gz
&& tar -xf nginx-${NG_VERSION}.tar.gz
&& mv nginx-${NG_VERSION} nginx
# describe : test
FROM busybox:latest
MAINTAINER www.linuxea.com
ENV NG_PATH /usr/local/src/
ENV NG_VERSION="1.14.0"
ZABBIX=/data/wwwroot/zabbix/
LABEL maintainer="www.linuxea.com"
COPY index.html /data/wwwroot/index.html
COPY zabbix $ZABBIX
WORKDIR ${NG_PATH:-/usr/local/src/}
ADD nginx-${NG_VERSION:-1.14.0}.tar.gz ./
VOLUME /data/mariadb/
RUN cd /usr/local
&& wget http://10.10.240.145/nginx-${NG_VERSION}.tar.gz
&& tar -xf nginx-${NG_VERSION}.tar.gz
&& mv nginx-${NG_VERSION} nginx
EXPOSE 80/tcp
而后进行build,验证下RUN命令中的操作是否被正常执行了
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker build -t marksugar/httpd:8 ./
Sending build context to Docker daemon 1.051MB
Step 1/12 : FROM busybox:latest
---> 59788edf1f3e
Step 2/12 : MAINTAINER www.linuxea.com
---> Using cache
---> 7f12e197dfba
Step 3/12 : ENV NG_PATH /usr/local/src/
---> Using cache
---> e6c199578807
Step 4/12 : ENV NG_VERSION="1.14.0" ZABBIX=/data/wwwroot/zabbix/
---> Using cache
---> c0b20f2d3726
Step 5/12 : LABEL maintainer="www.linuxea.com"
---> Using cache
---> 9236122c20ae
Step 6/12 : COPY index.html /data/wwwroot/index.html
---> Using cache
---> f13e97d53c76
Step 7/12 : COPY zabbix $ZABBIX
---> Using cache
---> 4b46be31391c
Step 8/12 : WORKDIR ${NG_PATH:-/usr/local/src/}
---> Using cache
---> 48b53e685832
Step 9/12 : ADD nginx-${NG_VERSION:-1.14.0}.tar.gz ./
---> Using cache
---> d785091af380
Step 10/12 : VOLUME /data/mariadb/
---> Using cache
---> 7d93a3a2d717
Step 11/12 : RUN cd /usr/local && wget http://10.10.240.145/nginx-${NG_VERSION}.tar.gz && tar -xf nginx-${NG_VERSION}.tar.gz && mv nginx-${NG_VERSION} nginx
---> Running in 3b8cb3885487
Connecting to 10.10.240.145 (10.10.240.145:80)
nginx-1.14.0.tar.gz 100% |********************************| 992k 0:00:00 ETA
Removing intermediate container 3b8cb3885487
---> 13e679e9c193
Step 12/12 : EXPOSE 80/tcp
---> Running in dd7199f76aa3
Removing intermediate container dd7199f76aa3
---> 5b194defe89f
Successfully built 5b194defe89f
Successfully tagged marksugar/httpd:8
而后启动,ls /usr/local/nginx
,那说明run的命令是执行成功的。nginx解压后是nginx-1.14.0已经被重命名成nginx
[root@linuxEA_10_10_240_145 /data/linuxea]$ docker run --name linuxea1 --rm -p 81:80 marksugar/httpd:8 ls /usr/local/nginx
CHANGES
CHANGES.ru
LICENSE
README
auto
conf
configure
contrib
html
man
src
那么RUN是可以被运行成多次的,但是多次意味着被挂在多层,你可以使用一条RUN组织续航起来,否则build后的容器会非常之大的。
- 你需要明白,RUN命令是运行在基础镜像之上,那也就是说RUN命令的运行是随着基础镜像的变化而不同的,如:centos安装软件是yum,ubuntu则是apk-get ,其依赖包名称也是不相同的。