Docker打包及部署项目

一、什么是Docker?

Docker 是一个开源的容器化平台,用于构建、部署和运行应用程序。它使开发人员能够将软件及其所有依赖项打包到一个称为容器的标准单元中。这个容器可以在任何支持 Docker 的环境中运行,无论是开发人员的个人计算机、测试环境还是生产服务器。
通过使用 Docker,开发人员可以摆脱「在我的机器上可运行」的问题,因为容器提供了一种标准化的方式来打包和分发应用程序。开发人员可以创建一个 Docker 镜像,其中包含了应用程序以及所有依赖项的配置,并将其部署到任何支持 Docker 的地方,而无需担心环境差异和依赖项冲突。

二、Docker基本常识

2.1 Dockerfile

Dockerfile是一个文本文件,其中包含了构建 Docker 镜像所需的一系列步骤和指令。通过编写 Dockerfile 文件,可以生成我们想要的镜像

2.2 镜像

Docker 镜像是 Docker 容器的基础构建组件。它是一个只读的模板,包含了运行了我们打包的项目、环境变量、配置数据和依赖项。你可以将 Docker 镜像视为一个快照,其中包含了构建应用程序的完整文件系统。

2.3 容器

Docker 容器是 Docker 平台上运行的一个实例化的软件单元。容器是基于 Docker 镜像创建的,它使用镜像作为其文件系统和基础环境,运行应用程序及其所有依赖项,我们可以通过部署好的容器,在其他设备上访问我们打包的项目

三、项目打包

这里我们以php的web项目为例
该项目目录如下

1.Dockerfile文件编写

文件参数详解

FROM:指定基础镜像名称和版本,将打包的项目在该基础镜像上运行
LABEL:为镜像添加元数据,可以用于标识镜像的作者、版本、描述等信息(可忽略)
ENV:设置环境变量,可以在容器内部使用
WORKDIR:设置工作目录,用于指定容器内部的工作目录,后续的命令都将在该目录下执行
COPY:从本地复制文件至创建的镜像文件
RUN: 对创建的镜像使用的命令
CMD: 容器被创建启动时执行的命令

文件内容如下

FROM nickistre/ubuntu-lamp
LABEL Elite
RUN apt-get update -y
COPY ./friend/* /var/www/html/
RUN service apache2 restart

这里我们拉取了一个带有lamp(Linux+Apache+Mysql+Php)环境的ubuntu镜像作为web项目的基础镜像,然后将镜像表示设为 Elite,然后使用了RUN对镜像执行了两条命令(更新容器内部的软件包列表,以及开启Apache服务),然后使用COPY命令,将本地 friend 目录里的项目复制到了镜像的/var/www/html/目录里,这样我们的Dockerfile文件就做好了

2.开始打包

在Dockerfile文件所在目录,使用命令如下

docker build  -t frid1:1.0 .

具体解释如下:
这条命令的作用是在当前目录下的 Dockerfile 中定义的构建步骤中,根据 Dockerfile 的指令和配置构建一个新的镜像,并为用-t将该镜像命名为 frid1,标签为 1.0。

该命令语法如下:

docker build [OPTIONS] PATH

OPTIONS 是一些可选参数,而 PATH 则是指定包含 Dockerfile 的路径

常用的一些参数包括:

    -t 或 --tag:用于为构建的镜像指定名称和标签。例如 -t myimage:1.0 表示将构建的镜像命名为 myimage,标签为 1.0-f 或 --file:用于指定替代的 Dockerfile 文件路径。默认情况下,docker build 命令会在 PATH 目录中查找名为 Dockerfile 的文件,但你可以使用 -f 参数指定其他文件名。
    --build-arg:用于传递构建时的参数值给 Dockerfile 中的 ARG 指令。例如 --build-arg MY_VAR=value 表示将值 value 传递给 Dockerfile 中的变量 MY_VAR。
    --no-cache:表示在构建过程中不使用缓存的镜像层。如果之前的构建产生了缓存的镜像层,这个参数可以忽略并重新执行所有的指令

这样我们的镜像便制作成功

四、项目拉起

我们可以通过命令

docker images

来查看刚才制作的镜像

然后通过命令

docker run -itd -p 666:80  frid1:1.0

解释一下每个参数的含义:

-itd:-i 表示以交互模式运行容器,-t 可以分配一个伪终端,-d 表示以“后台模式”(detached mode)运行容器。
-p 666:80:将主机的 666 端口映射到容器的 80 端口。这样,可以通过访问主机的 666 端口来访问容器内运行的应用程序。
frid1:1.0:指定要使用的镜像名称和标签。在这里,使用的镜像名称是 frid1,版本号是 1.0。

该命令语法如下:

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

OPTIONS 是一些可选参数,IMAGE 是指定要运行的镜像名称或标签,COMMAND 是容器内部要执行命令,ARG... 是传递给容器命令的参数

常用的一些参数包括:

    -d:表示以“后台模式”(detached mode)运行容器,在容器内部执行的命令会在后台运行。如果不使用该参数,则容器会在前台运行,并将命令输出打印到终端。
    -p:用于设置主机和容器之间的端口映射。例如 -p 8080:80 表示将主机的 8080 端口映射到容器的 80 端口。
    -v:用于设置主机和容器之间的目录挂载。例如 -v /host/directory:/container/directory 表示将主机上的 /host/directory 目录挂载到容器内的 /container/directory 目录。
    --name:用于为容器指定一个名称。如果不指定名称,Docker 将自动生成一个唯一的容器名称。
    --rm:表示在容器退出后自动删除容器。这在临时运行的容器上非常有用。
    --network:用于指定容器连接的网络。可以使用默认的 bridge 网络或自定义网络。

项目成功拉起

  • 4
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
将 .NET Core 3.1 项目Docker 打包部署的步骤如下: 1. 在项目根目录下创建一个 Dockerfile 文件,文件内容如下: ``` FROM mcr.microsoft.com/dotnet/core/sdk:3.1 AS build-env WORKDIR /app # Copy csproj and restore as distinct layers COPY *.csproj ./ RUN dotnet restore # Copy everything else and build COPY . ./ RUN dotnet publish -c Release -o out # Build runtime image FROM mcr.microsoft.com/dotnet/core/aspnet:3.1 WORKDIR /app COPY --from=build-env /app/out . ENTRYPOINT ["dotnet", "YourProject.dll"] ``` 其中,第一行指定了基础镜像为 .NET Core SDK 3.1,第二行指定了工作目录为 /app。接下来,将项目的 csproj 文件复制到容器中,并执行 dotnet restore 命令安装项目依赖。然后,将整个项目复制到容器中,并执行 dotnet publish 命令将项目编译成可执行文件。最后,指定基础镜像为 .NET Core 3.1 运行时,将编译好的可执行文件复制到容器中,并指定入口点为 YourProject.dll。 2. 在项目根目录下执行以下命令,将项目打包Docker 镜像: ``` docker build -t your-image-name . ``` 其中,your-image-name 为自定义的镜像名称。 3. 将镜像上传到 Docker Hub 或私有镜像仓库: ``` docker push your-image-name ``` 4. 在目标服务器上安装 Docker,并从 Docker Hub 或私有镜像仓库中拉取镜像: ``` docker pull your-image-name ``` 5. 运行容器: ``` docker run -d -p 80:80 your-image-name ``` 其中,-d 表示容器在后台运行,-p 表示将容器的 80 端口映射到主机的 80 端口,your-image-name 为之前打包的镜像名称。 至此,.NET Core 3.1 项目已经成功打包部署Docker 容器中了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Elitewa

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值