docker asp.net core部署


介紹

    本篇介紹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                                        System.Text.Encodings.Web.dll k8swebapi.pdb                                        System.Text.Json.dll k8swebapi.runtimeconfig.json                         web.config k8swebapi.Views.dll                                  wwwroot k8swebapi.Views.pdb                                  YLYUN.Common.Dapper.dll Microsoft.AspNetCore.Mvc.Versioning.ApiExplorer.dll  YLYUN.Common.Dapper.pdb Microsoft.AspNetCore.Mvc.Versioning.dll              YLYUN.Common.Dapper.xml Microsoft.Bcl.AsyncInterfaces.dll
C#

   3.構建鏡像

   執行格式:docker build -t <要生成的鏡像的名稱>  .   

        k8swebapi為鏡像的名稱

     結尾的 . 指dockerfile路徑(.是代表上下文路徑,因為dockerfile就在當前目錄下)

[root@VM_0_12_centos webapipublish]# docker build -t k8swebapi .
Sending build context to Docker daemon 7.513MB
Step 1/5 : FROM mcr.microsoft.com/dotnet/core/aspnet:2.2 AS runtime
---> e7e3b238011c
Step 2/5 : WORKDIR /app
---> Running in f6496d30d085
Removing intermediate container f6496d30d085
---> 5657f984ae35
Step 3/5 : EXPOSE 5000
---> Running in 93c58d4b5fc1
Removing intermediate container 93c58d4b5fc1
---> 1a6657883eb9
Step 4/5 : COPY . .
---> 9badab908e55
Step 5/5 : ENTRYPOINT ["dotnet", "k8swebapi.dll", "--urls", "http://*:5000;http://*:5001"]
---> Running in 25a44038e606
Removing intermediate container 25a44038e606
---> 3068b399a9f4
Successfully built 3068b399a9f4
Successfully tagged k8swebapi:latest

    構建鏡像成功后,顯示Successfully ,返回鏡像ID 3068b399a9f4

  4.創建容器並啟動容器

    使用docker run  

    -d代表是后台運行容器

    --rm指定容器停止后自動刪除容器, 用docker stop  contriner 停止后自動刪除該容器

    --P(大寫)  宿主主機自動分配端口並關聯容器暴露的5000端口,外部使用宿主主機自動分配的端口訪問web api服務

    --name    容器名稱

    最后一個參數是鏡像名稱,前面的參數都是[OPTIONS]  格式:docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

[root@VM_0_12_centos webapipublish]# docker run -d --rm -P  --name  k8swebapi  k8swebapi dd8b01b33183f621d98043fdddbb7fda5817d312b7943a53718d6e6b0b0b94aa
C#

    通過docker ps查看創建的容器,和宿主自動分配的端口32770。 容器內訪問api服務端口5000, 容器外訪問api服務端口32770

[root@VM_0_12_centos webapipublish]# docker ps CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                     NAMES dd8b01b33183        k8swebapi           "dotnet k8swebapi.dl…"   About an hour ago   Up About an hour    0.0.0.0:32770->5000/tcp   k8swebapi 3ddee94cef3a        ubuntu:latest       "/bin/bash"              6 days ago          Up 6 days                                     quizzical_nash
C#

 

  5. 進入容器  

   進入k8swebapi容器,查看app目錄,再請求api服務,如下所示:

[root@VM_0_12_centos webapipublish]# docker exec -it dd8b01b33183 /bin/bash root@dd8b01b33183:/app# ls Dockerfile                         System.Text.Encodings.Web.dll  k8swebapi.Views.pdb Microsoft.AspNetCore.Mvc.Versioning.ApiExplorer.dll  System.Text.Json.dll        k8swebapi.deps.json Microsoft.AspNetCore.Mvc.Versioning.dll             YLYUN.Common.Dapper.dll        k8swebapi.dll Microsoft.Bcl.AsyncInterfaces.dll             YLYUN.Common.Dapper.pdb        k8swebapi.pdb Microsoft.OpenApi.dll                     YLYUN.Common.Dapper.xml        k8swebapi.runtimeconfig.json Swashbuckle.AspNetCore.Swagger.dll             appsettings.Development.json   web.config Swashbuckle.AspNetCore.SwaggerGen.dll             appsettings.json            wwwroot Swashbuckle.AspNetCore.SwaggerUI.dll             dll System.Runtime.CompilerServices.Unsafe.dll         k8swebapi.Views.dll root@dd8b01b33183:/app# curl http://localhost:5000/api/v1/user/IndexList [{"id":1,"name":"張三"},{"id":2,"name":"李四"}]root@dd8b01b33183:/app#
C#

  6. 外部訪問

    在宿主主機上訪問,如下所示:

[root@VM_0_12_centos webapipublish]# curl http://localhost:32770/api/v1/user/IndexList [{"id":1,"name":"張三"},{"id":2,"name":"李四"}][root@VM_0_12_centos webapipublish]#
C#

    外面通過windows系統的瀏覽器訪問(這里的ip為服務器雲網ip),如下所示:

 docker asp.net core部署


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM