介绍

    本篇介绍asp.net core web api如何部署到docker容器中,并通过外部访问web api服务。在编写完成dockerfile之后,可以通过docker [image] build命令来创建镜像。

    基本的格式为:docker build [options] path | url | -

    该命令将读取指定路径(包括子目录)的dickerfile,并将该路径下所有数据作为上下文发送给docker服务端。docker服务端在校验dockerfile格式通过后,啄条执行其中定义的指令,碰到ADD, COPY 和RUN指令会生成一层新的镜像。最终如果创建镜像成功,会返回最终镜像的ID。

  1.  dockerfile文件创建

    创建asp.net core web api应用程序,项目名为:k8swebapi。 dockerfile如下所示:

FROM mcr.microsoft.com/dotnet/core/aspnet:2.2 AS runtime
WORKDIR /app
EXPOSE 5000
COPY . .
ENTRYPOINT ["dotnet", "k8swebapi.dll", "--urls", "http://*:5000;http://*:5001"]

   2.上传

    asp.net core web api 发布后,上传到云服务器opt目录下

[root@VM_0_12_centos opt]# ls
containerd  kubectl-1.17.3-0.x86_64.rpm  rh  webapipublish
C#

    定位到webapipublish目录下,查看刚上传的web文件

[root@VM_0_12_centos opt]# cd webapipublish
[root@VM_0_12_centos webapipublish]# ls
appsettings.Development.json                         Microsoft.OpenApi.dll
appsettings.json                                     Swashbuckle.AspNetCore.Swagger.dll
dll                                                  Swashbuckle.AspNetCore.SwaggerGen.dll
Dockerfile                                           Swashbuckle.AspNetCore.SwaggerUI.dll
k8swebapi.deps.json                                  System.Runtime.CompilerServices.Unsafe.dll
k8swebapi.dll