上一篇我们讲了如何将asp.net core部署到linux系统上,这次我们以docker容器的方式把我们的站点部署到linux系统中

使用Docker来部署,其实比我们常规的部署方式更简单。因为Docker的存在,本来就是把复杂的事情简单化,让我们可以“一次部署,处处可用”。

如果你是使用windows操作系统,首先记得先安装好docker for windows,不清楚怎么安装可以自行查阅资料。

创建dockerfile

在上一次我们创建的asp.net core web项目中,我们在发布的目标文件夹根目录中创建一个Dockerfile的文件(就是一个文本文件没有扩展名),具体内容如下:

#从docker hub中拉取asp.net runtime基础镜像
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1
#将当前目录下的文件,拷贝到容器中的app目录下
COPY . /app 
#设置app为工作目录
WORKDIR /app
#暴露TCP端口5100
EXPOSE 5100/tcp
#设置程序启动入口函数库名,第一个参数表示执行命令的程序名,第二个函数表示带有主函数入口文件名
ENTRYPOINT ["dotnet","LinuxWebForTest.dll"]

特别注意:程序入口函数库文件名,一定是以dll作为入口函数库,不能以exe文件或者不带扩展名的文件名称作为入口函数库

如果入口函数指定错误,则会出现以下提示:

  ```txt
  It was not possible to find any installed .NET Core SDKs
  Did you mean to run .NET Core SDK commands? Install a .NET Core SDK from:
        https://aka.ms/dotnet-download
  ```

通过Dockerfile构建镜像

  1. 我们打开asp.net core web的根目录(也就是dockerfile所在目录),在资源管理器上方输入cmd命令,打开cmd命令窗口

  2. 登录docker仓库服务器,以上次构建的私有仓库为例

       > docker login 192.168.1.110:5000
       //之前已经登录过,所以直接从缓存里面查找用户和密码信息,自动登录
       Authenticating with existing credentials...
       Login Succeeded
       //如果没有登录过,输入用户名,密码进行登录。可参见:https://huchengv5.github.io//post/%E6%90%AD%E5%BB%BAdocker%E7%A7%81%E6%9C%89%E4%BB%93%E5%BA%93.html 中的登录部分。
    
  3. 构建镜像

       > docker build -t 192.168.1.110:5000/aspnetcoreapp:v1 .
    
       //执行过程
       Sending build context to Docker daemon  4.631MB
       Step 1/5 : FROM mcr.microsoft.com/dotnet/core/aspnet:3.1
       ---> bc877ac43e02
       Step 2/5 : COPY . /app
       ---> eaa31c882445
       Step 3/5 : WORKDIR /app
       ---> Running in f8db2aff9c73
       Removing intermediate container f8db2aff9c73
       ---> 97f999072fc2
       Step 4/5 : EXPOSE 5100/tcp
       ---> Running in ddeb5c939269
       Removing intermediate container ddeb5c939269
       ---> fbabdcf7447b
       Step 5/5 : ENTRYPOINT ["dotnet","LinuxWebForTest.dll"]
       ---> Running in 0d60745c61ea
       Removing intermediate container 0d60745c61ea
       ---> d2517be5dbd8
       Successfully built d2517be5dbd8
       Successfully tagged 192.168.1.110:5000/aspnetcoreapp:v1
    
    

    我们可以通过docker images来查看我们构建的镜像。

       > docker images
       REPOSITORY                             TAG                 IMAGE ID            CREATED             SIZE
       192.168.1.110:5000/aspnetcoreapp       v1                  26070ec7870f        18 hours ago        212MB
       linuxwebfortest                        dev                 8485a72fcf26        25 hours ago        207MB
       docker101tutorial                      latest              c57c605dedaa        3 days ago          25.1MB
       192.168.1.110:5000/python              test                f4df7f234e59        7 days ago          78.9MB
       python                                 alpine              f4df7f234e59        7 days ago          78.9MB
       mcr.microsoft.com/dotnet/core/aspnet   3.1                 bc877ac43e02        8 days ago          207MB
       mcr.microsoft.com/dotnet/core/aspnet   3.1-buster-slim     bc877ac43e02        8 days ago          207MB
       node                                   12-alpine           7a48db49edbf        4 weeks ago         88.7MB
       nginx                                  alpine              89ec9da68213        4 weeks ago         19.9MB
       registry                               latest              708bc6af7e5e        4 months ago        25.8MB
    

    ### 命令说明:

       docker build 构建镜像
    
       -t (tag) 指定镜像tag
    
       192.168.1.110:5000 镜像指定的仓库地址,会作为镜像名称的一部分,但这部分不能乱填
    
       aspnetcoreapp 镜像名称,可以任意填写
    
       v1 对应的标签,这里是表示仓库 192.168.1.110:5000 下的 aspnetcoreapp 镜像的 v1 版本
    
       最后面有个 . ,表示的是当前目录下的dockerfile文件,也可以通过 -f 显示指定dockerfile的文件路径
    
  4. 推送镜像

    镜像构建好后,我们需要将镜像推送到我们的私有仓库中

       > docker push 192.168.1.110:5000/aspnetcoreapp:v1
    
    

    基本语法:docker push <镜像完整名称>

  5. 启动容器

    镜像推送到服务器以后,我们需要进入到服务器,将镜像运行到容器中。(镜像就相当于是原始文件,容器可以理解为加载镜像文件后运行的程序实例)

       docker run -p 8000:5100 192.168.1.110:5000/aspnetcoreapp:v1
    

    执行成功效果如下:

       warn: Microsoft.AspNetCore.DataProtection.Repositories.FileSystemXmlRepository[60]
             Storing keys in a directory '/root/.aspnet/DataProtection-Keys' that may not be persisted outside of the container. Protected data will be unavailable when container is destroyed.
       warn: Microsoft.AspNetCore.DataProtection.KeyManagement.XmlKeyManager[35]
             No XML encryptor configured. Key {e0fd53e8-940f-4e70-b192-2b16c0f684dc} may be persisted to storage in unencrypted form.
       warn: Microsoft.AspNetCore.Server.Kestrel[0]
             Overriding address(es) 'http://+:80'. Binding to endpoints defined in UseKestrel() instead.
       info: Microsoft.Hosting.Lifetime[0]
             Now listening on: http://0.0.0.0:5100
       info: Microsoft.Hosting.Lifetime[0]
             Application started. Press Ctrl+C to shut down.
       info: Microsoft.Hosting.Lifetime[0]
             Hosting environment: Production
       info: Microsoft.Hosting.Lifetime[0]
             Content root path: /app
    
    

    参数说明:

       docker run:启动一个容器实例
       -p 8000:5100:将本地端口8000映射到容器端口5100
       192.168.1.110:5000/aspnetcoreapp:v1: 表示完整的镜像路径
    
    

    我们也可以通过 -d 参数启动后台运行,也可以通过设置 --restart=always 使其自动启动,小伙伴们可以自行尝试下。

  6. 使用浏览器,外部验证是否可以正常访问

    使用浏览器打开:http://192.168.1.110:8000。如果能正常打开,那么恭喜你已经成功了。

    Docker的最简易的部署就到这里了,基本思路有了,更复杂点的部署也会有个基本的思路了。


本文会经常更新,请阅读原文: https://huchengv5.gitee.io//post/%E5%A6%82%E4%BD%95%E9%80%9A%E8%BF%87docker%E5%AE%B9%E5%99%A8%E5%B0%86Asp.net-Core%E7%AB%99%E7%82%B9%E9%83%A8%E7%BD%B2%E5%88%B0CentOS.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

知识共享许可协议 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名胡承(包含链接: https://huchengv5.gitee.io/ ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系