首页 > 解决方案 > 如何创建 docker-compose.yml 文件

问题描述

我是 docker 的初学者,所以我没有很好的知识,但我很想了解更多。所以我希望这个社区可以指导我。现在我有一个 Dockerfile。

# getting base image debian
 FROM debian
 RUN apt-get update && apt-get install -y sudo
 RUN apt-get update && apt-get install -y vsftpd
 RUN apt-get update && apt-get install -y ftp
 RUN apt-get install nano
 RUN sudo sed -i.$(date +%F) '/^#/d;/^$/d' /etc/vsftpd.conf

# Add configuration in /etc/vsftpd.conf
 RUN echo "write_enable=YES" >> /etc/vsftpd.conf
 RUN echo "chroot_local_user=YES" >> /etc/vsftpd.conf
 RUN echo "user_sub_token=\$USER" >> /etc/vsftpd.conf
 RUN echo "local_root=/home/\$USER/ftp" >> /etc/vsftpd.conf
 RUN echo "userlist_enable=YES" >> /etc/vsftpd.conf
 RUN echo "pasv_min_port=40000" >> /etc/vsftpd.conf
 RUN echo "pasv_max_port=50000" >> /etc/vsftpd.conf
 RUN echo "userlist_file=/etc/vsftpd.userlist" >> /etc/vsftpd.conf
 RUN echo "userlist_deny=NO" >> /etc/vsftpd.conf

# create new group "zanui"  
RUN groupadd zanui
#user "lal" with group lal
RUN useradd -G zanui --system --create-home --no-log-init lal
RUN echo "lal:123456" | chpasswd

RUN useradd -G zanui --system --create-home --no-log-init mausam
RUN echo "mausam:123456" | chpasswd

RUN echo "lal" | sudo tee -a /etc/vsftpd.userlist
RUN echo "mausam" | sudo tee -a /etc/vsftpd.userlist

RUN mkdir /home/lal/ftp
RUN chown nobody:nogroup /home/lal/ftp
RUN chmod a-w /home/lal/ftp

RUN mkdir /home/lal/ftp/files
RUN sudo chown lal:lal /home/lal/ftp/files

RUN mkdir /home/mausam/ftp
RUN chown nobody:nogroup /home/mausam/ftp
RUN chmod a-w /home/mausam/ftp

RUN mkdir /home/mausam/ftp/files
RUN sudo chown mausam:mausam /home/mausam/ftp/files

RUN apt-get update && apt-get install -y build-essential git libfuse-dev libcurl4-openssl-dev libxml2-dev mime-support automake libtool pkg-config libssl-dev
RUN git clone https://github.com/s3fs-fuse/s3fs-fuse
WORKDIR /s3fs-fuse
RUN ./autogen.sh && ./configure --prefix=/usr --with-openssl && make && make install
WORKDIR /../
ADD /conf/passwd-s3fs /etc/passwd-s3fs
RUN chmod 600 /etc/passwd-s3fs

# RUN s3fs bucket-name /home/lal/ftp/files

首先,我使用以下命令从 Dockerfile 构建映像:

docker build -t mydebiantest1:1.0 .

然后我使用以下命令使用此映像运行容器:

docker run --privileged -it mydebiantest1:1.0 bash

然后我会在 Debian Linux bash 实例里面

root@c875e352e4e7:/# 

所以现在我想要的是当我运行命令时如何运行这些步骤:

docker-compose up

不知何故,我设法构建了 docker-compose.yml 文件,该文件似乎无法满足我的要求。

version: '3'
services:
  # The Application
  s3bucketftp:
    container_name: s3bucketftp
    image: s3bucketftp:1.0
    build:
      context: ./
      dockerfile: Dockerfile
      args:
        environment: development

标签: dockerdocker-compose

解决方案


Dockerfile没有CMDENTRYPOINT。如果启动一个容器以交互方式使用作为目标,则添加

CMD /bin/bash

您不需要为您的服务提供两者imagebuild上下文。image如果指定了属性,您需要在本地或 docker 存储库中预先构建标记图像。

而是让 dockerbuild根据提供的context.

更新后的docker-compose.yaml样子,

version: '3'
services:
  s3bucketftp:
    container_name: s3bucketftp
    privileged: true
    tty: true
    build:
      context: ./
      args:
        environment: development

使用此 compose 文件,您可以构建映像并启动容器(请注意,您已从与 compose 文件相同的位置运行 compose 命令)。

另请注意,此服务无法按照container_name指定的方式进行缩放。

docker-compose up -d

-d就是把容器作为后台进程运行

并检查正在运行的容器,

docker-compose ps

容器运行后,可以直接访问容器,而无需重做任何设置。

docker exec -it s3bucketftp /bin/bash

推荐阅读