aspnetcore+docker 容器目录挂载
2021-01-17 20:15
标签:设置 有一个 src 目录 配置 round cspro 数据 日志 玩过docker容器的人,对数据挂载肯定不陌生,volume :几种叫法,数据卷,资料卷 通过 -v 把宿主机目录绑定到容器中的目录 数据挂载的好处,仅仅是我认为的。不一定正确 1:数据能持久化保存,因为容器一旦删除,啥都没有了。但挂载的目录是不会删除的 2:修改和查看方便,比如要修改和查看数据,直接看本地,不用进去容器看,比较容器里面很多命令是没有安装的 首先来 看一个我们常用的netcore 打包成镜像的Dockerfile 首先build成images 如果不挂载的方式,运行容器 这样netcore文件都在容器的/app中,每次查看,都必须 docker exec ... 进入容器 那么已挂载的方式呢,相比很快就会想到了-v,立马尝试 -v /root/data:/app 意思是把容器内的app目录,挂载到宿主机的/root/data中,也就是2个目录bind 首先明确下,我这里是没有提前创建/root/data 这个目录的。不过挂载后,docker会给我们创建 但run之后,这个容器是起不来的,不过我这里加了restart,所以一直重启, 为什么这个容器run不起来?我们来分析下 只要理解了volume的意思, bind 一定要注意,主机目录为空的话,会清空容器的目录, 也就是说,我们没挂载的时候,容器内app是有东西的,当我们把本地一个空 目录(/root/data) 挂载到容器内的/app下,就会清空容器内文件夹的内容, 就是说:你挂载了宿主机目录,我就以宿主机目录为主,容器的内有数据,我都给清空,所以导致容器无法启动 因为你Dockefile 中的入口是:ENTRYPOINT ["dotnet", "mytest.dll"] 都没有这个mytest.dll,自然无法启动 也许有人会问,压根就没必要这样挂载啊,我只挂载需要的,比如日志文件,配置文件, 那好,继续干 logs 一开始肯定是为空,项目跑起来才生成,没问题 appsettings.json配置文件,手动拷贝即可 但我在开发的时候就有一个疑问,项目里面不仅仅这2个文件,还会有upload上传文件 template 模板文件,nlog 配置文件我觉得写多个-v不合适, 我就琢磨着。不能在容器启动的时候,把内部的数据拷贝到宿主机器吗。 容器数据拷贝到宿主机命令: 宿主机拷贝到容器,反过来即可 所以我想到了2种方法,估计不是最优的 1:数据挂载后,手动拷贝文件到本地目录,但我们是通过dockerfile 运行的 难道我又手动 dotnet publish ....一次,繁琐 2:容器运行后,把容器数据拷贝到本地,不行吗?是行的 分析: 既然数据在容器路径app中,运行的时候,会清空,那为什么不事先保存在其他目录中了 那修改下上面的Dockerfile 加了一个data存放文件,程序启动的时候,把data拷贝到宿主机目录,绑定到宿主机app中 自己写一个shell文件,init.sh,我是这样写的 然后执行 sh init.sh,OK,访问成功,洗漱睡觉!! aspnetcore+docker 容器目录挂载 标签:设置 有一个 src 目录 配置 round cspro 数据 日志 原文地址:https://www.cnblogs.com/nsky/p/13358142.htmlFROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
ENV TIMEZONE Asina/Shanghai
WORKDIR /app
EXPOSE 80
FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /src
COPY . .
RUN dotnet restore
RUN dotnet build
FROM build AS publish
RUN dotnet publish "mytest.csproj" -c Release -o /app/publish
FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "mytest.dll"]
docker build -t test .
docker run -d -p 8080:80 --restart=always --name my test
docker run -d -p 8080:80 --restart=always -v /root/data:/app --name my test
docker run -d -p 8080:80 --restart=always -v /root/logs:/app/logs -v /root/appsettings.json:/app/appsettings.json --name my test
docker cp my:/app /root/myapp
docker cp /root/myapp my:/app
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
ENV TIMEZONE Asina/Shanghai
WORKDIR /app
EXPOSE 80
FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /src
COPY . .
RUN dotnet restore
RUN dotnet build
FROM build AS publish
RUN dotnet publish "mytest.csproj" -c Release -o /app/publish
FROM base AS final
# 创建一个文件夹,存放文件,同时是被复制到宿主机的
RUN mkdir -p /data
# 这是程序的最终工作目录,也就是宿主机挂载的目录
WORKDIR /app
COPY --from=publish /app/publish /data
ENTRYPOINT ["dotnet", "mytest.dll"]
#运行容器,设置了restart,会一直重启,等待下面的拷贝完成,就会启动成功
docker run -d -p 8802:80 --restart=always -v /root/data:/app --name my test
#把容器内部的数据拷贝到本地挂载目录
docker cp my:/data /root
#删除容器中的data文件,非必须的操作
docker exec my rm -rf /data