ミラーを作成するDockerfile-Dockerfile形式
1. FROM //どのベースイメージが基づいているかを指定します
FROM <ミラー名>またはFROM <ミラー名>:<タグ>の形式
といった
CentOSから
centosから:最新
2. MAINTAINER //作成者情報を指定します
フォーマットMAINTAIN <name>
といった
3. RUN //ミラー操作命令
形式は、RUN <command>またはRUN ["executable"、 "param1"、 "param2"]、
といった
yum installhttpdを実行します
RUN ["/ bin / bash"、 "-c"、 "echo hello"]
4. CMD // 3つの形式:
CMD ["実行可能"、 "param1"、 "param2"]
CMDコマンドparam1param2
CMD ["param1"、 "param2"]
RUNとCMDは似ていますが、CMDはコンテナの起動時に使用されるコマンドを指定するために使用され、1つしか存在できません。
といった
CMD ["/ bin / bash"、 "/ usr / local / nginx / sbin / nginx"、 "-c"、 "/usr/local/nginx/conf/nginx.conf"]
5.公開
形式は、EXPOSE <port> [<port> ...]などです。
公開2280 8443
これは、マップアウトするポートを指定するために使用されます。たとえば、コンテナ内でsshdとnginxを開始したため、ポート22と80を公開する必要があります。これは-P(大文字)で機能する必要があります。つまり、コンテナを起動するときに、-Pを追加して自動的に割り当てる必要があり、ホストが自動的にIPを割り当てます。特定のポートを指定する場合は、-p(小文字)を使用して指定することもできます。
6. ENV
ENV <キー> <値>などの形式
ENVパス/ usr / local / mysql / bin:$ PATH
これは主に、後続のRUN命令用の環境変数を提供するためのものであり、いくつかのカスタム変数を定義することもできます。
ENV MYSQL_version 5.6
7.追加
フォーマット追加<src> <dest>
ローカルファイルまたはディレクトリをコンテナのディレクトリにコピーします。srcは、Dockerfileが配置されているディレクトリの相対パスですが、urlにすることもできます。
といった
拷贝ADD <conf / vhosts> </ usr / local / nginx / conf>
URL接続を追加
8.コピー
形式は追加と同じです
使用法はaddと同じですが、違いはurlをサポートしていないことです
9.ENTRYPOINT 形式はCMDに似ています
コンテナの起動時に実行されるコマンドはCMDと非常によく似ており、1つだけが有効になります。複数のコマンドを作成すると、最後の1つだけが有効になります。
CMDとの違いは次のとおりです。CMDはdockerrunコマンドで上書きできますが、ENTRYPOINTは上書きできません。
たとえば、コンテナ名はamingです
Dockerfileで次のCMDを指定します。
CMD ["/ bin / echo"、 "test"]
コンテナを起動するコマンドはdockerrun amingです。これにより、テストが出力されます。
コンテナを起動するコマンドがdockerrun -it aming / bin / bashの場合、何も出力されません。
ENTRYPOINT不会被覆盖,而且会比CMD或者docker run指定的命令要靠前执行
ENTRYPOINT ["echo", "test"]
docker run -it aming 123
则会输出 test 123 ,这相当于要执行命令 echo test 123
10. VOLUME
格式 VOLUME ["/data"]
创建一个可以从本地主机或其他容器挂载的挂载点。
11. USER
格式 USER daemon
指定运行容器的用户
12. WORKDIR
格式 WORKDIR /path/to/workdir
指定当前工作目录,相当于cd命令
为后续的RUN、CMD或者ENTRYPOINT指定工作目录
Dockerfile创建镜像 – Dockerfile示例
先下载nginx的配置文件
wget http://www.apelearn.com/study_v2/.nginx_conf
vim Dockerfile //内容如下
## Set the base image to CentOS FROM centos # File Author / Maintainer MAINTAINER aming [email protected] # Install necessary tools RUN yum install -y pcre-devel wget net-tools gcc zlib zlib-devel make openssl-devel # Install Nginx ADD http://nginx.org/download/nginx-1.8.0.tar.gz . RUN tar zxvf nginx-1.8.0.tar.gz RUN mkdir -p /usr/local/nginx RUN cd nginx-1.8.0 && ./configure --prefix=/usr/local/nginx && make && make install RUN rm -fv /usr/local/nginx/conf/nginx.conf COPY .nginx_conf /usr/local/nginx/conf/nginx.conf或者ADD http://www.apelearn.com/study_v2/.nginx_conf /usr/local/nginx/conf/nginx.conf # Expose ports EXPOSE 80 # Set the default command to execute when creating a new container ENTRYPOINT /usr/local/nginx/sbin/nginx && tail -f /etc/passwd
创建镜像:
docker build -t centos_nginx .
注:
❶ docker build:用于使用Dockerfile创建镜像,其实就是去找Dockerfile
❷ -t指定新镜像的名字
❸ 后边这个点意思是当前路径,指的是刚才编辑的Dockerfile的路径,指定路径build就回去这个路径下找dockerfile
docker images //可以看到我们新建的镜像
启动一下刚刚Dockerfile创建完的镜像并映射8088端口
docker run -itd -p 8088:80 centos_nginx bash
用Docker compose部署服务
docker compose可以方便我们快捷高效地管理容器的启动、停止、重启等操作,它类似于linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像、数据卷、网络模式、监听端口等信息。我们可以在一个compose文件中定义一个多容器的应用(比如jumpserver),然后通过该compose来启动这个应用。
安装compose方法如下
下载最新的compose
curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
给权限
chmod 755 /usr/local/bin/docker-compose
docker-compose version 查看版本信息
[root@localhost ~]# docker-compose version docker-compose version 1.17.0-rc1, build a0f95af docker-py version: 2.5.1 CPython version: 2.7.13 OpenSSL version: OpenSSL 1.0.1t 3 May 2016
Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)从1.6.0以后就是2版本了。Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1将来会被弃用。
用Docker compose部署服务 – 示例
vim docker-compose.yml //加入以下内容
version: "2" services: app1://第一个容器的名字 image: centos_nginx//对应的镜像 ports://就是你要映射的端口-p - "8080:80" networks://使用哪个网络(在下边driver处定义,不定义默认就是bridge) - "net1" volumes://目录映射-v//下边是本地的目录和容器的目录做映射,如果只写一个data那他就是一个数据卷,用来做分享 - /data/:/data app2:第二个容器名字 image: centos_with_nettool//对应的镜像 networks: - "net2" volumes: - /data/:/data1 entrypoint: tail -f /etc/passwd//为了让容器一直启动,上边镜像不加是因为他是用Dockerfile创建的镜像,他里边就有一个这样的语句。 networks: net1: driver: bridge net2: driver: bridge
docker-compose up -d 启动容器
docker-compose stop关闭
docker-compose ps 查看启动镜像
docker-compose 删除镜像
docker-compose --help 查看使用方法
关于docker-compose语法的参考文档 http://www.web3.xin/index/article/182.html