4.dockerfile

ミラーを作成するDockerfile-Dockerfile形式

1. FROM    //どのベースイメージが基づいているかを指定します

FROM <ミラー名>またはFROM <ミラー名>:<タグ>の形式

といった

CentOSから

centosから:最新

2. MAINTAINER   //作成者情報を指定します

フォーマットMAINTAIN <name> 

といった

メンテナ私たちの  [email protected]

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


おすすめ

転載: blog.51cto.com/12922638/2595876