如何在 Docker 主机中挂载 S3 容器?有没有一种透明的方法来实现这一点?或者我是否需要使用 VOLUME 指令将卷挂载到主机驱动器上,然后手动使用 CRON 将文件备份到 S3 中?
如何在 Docker 主机中挂载 S3 容器?有没有一种透明的方法来实现这一点?或者我是否需要使用 VOLUME 指令将卷挂载到主机驱动器上,然后手动使用 CRON 将文件备份到 S3 中?
根据您想要实现的目标,有不同的方法,但以下是我使用s3fs-fuse完成它的方式:
我创建了一个基于Ubuntu的Docker镜像,并
Dockerfile
FROM ubuntu:18.04
## Some utilities
RUN apt-get update -y && \
apt-get install -y build-essential libfuse-dev libcurl4-openssl-dev libxml2-dev pkg-config libssl-dev mime-support automake libtool wget tar git unzip
RUN apt-get install lsb-release -y && apt-get install zip -y && apt-get install vim -y
## Install AWS CLI
RUN apt-get update && \
apt-get install -y \
python3 \
python3-pip \
python3-setuptools \
groff \
less \
&& pip3 install --upgrade pip \
&& apt-get clean
RUN pip3 --no-cache-dir install --upgrade awscli
## Install S3 Fuse
RUN rm -rf /usr/src/s3fs-fuse
RUN git clone https://github.com/s3fs-fuse/s3fs-fuse/ /usr/src/s3fs-fuse
WORKDIR /usr/src/s3fs-fuse
RUN ./autogen.sh && ./configure && make && make install
## Create folder
WORKDIR /var/www
RUN mkdir s3
## Set Your AWS Access credentials
ENV AWS_ACCESS_KEY=YOURAWSACCESSKEY
ENV AWS_SECRET_ACCESS_KEY=YOURAWSSECRETACCESSKEY
## Set the directory where you want to mount your s3 bucket
ENV S3_MOUNT_DIRECTORY=/var/www/s3
## Replace with your s3 bucket name
ENV S3_BUCKET_NAME=your-s3-bucket-name
## S3fs-fuse credential config
RUN echo $AWS_ACCESS_KEY:$AWS_SECRET_ACCESS_KEY > /root/.passwd-s3fs && \
chmod 600 /root/.passwd-s3fs
## change workdir to /
WORKDIR /
## Entry Point
ADD start-script.sh /start-script.sh
RUN chmod 755 /start-script.sh
CMD ["/start-script.sh"]
启动脚本应指定为:
start-script.sh
#!/bin/bash
s3fs $S3_BUCKET_NAME $S3_MOUNT_DIRECTORY
然后构建您的镜像,并且如果您在指定的目录中创建文件,则它也应该在S3控制台上反映出来,反之亦然。
我在这里提供了更详细的说明和一个可工作的示例: https://github.com/skypeter1/docker-s3-bucket
.passwd-s3fs
文件,然后在运行时将其挂载到docker容器中。在启动脚本中,使用带有参数passwd_file=<PATH_TO_MOUNTED_PASS_FILE>
的s3fs。 - cya