本篇文章经过一个实例为你们演示如何在Docker容器中运行ASP.NET Core应用程序。html
打开vs建立一个ASP.NET Core Application,如图所示:web
打开Index.cshtml, 修改里面的内容如图所示:docker
直接运行application,如图所示:windows
在vs中右键单击web项目,而后在弹出的menu中选择Publish,弹出如图所示对话框:浏览器
点击Create Profile按钮,回到VS窗体中如图所示页面:app
点击Publish按钮,开始Publish当前应用程序,成功Publish以后,会在VS Output中看到如图所示的信息:工具
咱们成功将当前应用程序Publish到了制定的PublishOutput文件夹中,如图所示:post
对dockerfile陌生的小伙伴能够查看(在Docker容器中运行.Net Framework控制台应用程序)文章中对Dockfile的解释。ui
在Dockerfile文件中咱们添加以下命令:命令行
FROM microsoft/dotnet:2.2-aspnetcore-runtime-nanoserver-1803
经过FROM指令来指定咱们所要使用的基本镜像
WORKDIR /app
经过workdir指令来设置dockerfile中所写的命令(例如:RUN,ENTRYPOINT等等)在container中执行的地址
COPY PublishOutput/ /app
经过COPY指令来将publish的包copy到container中指定的地址
ENTRYPOINT ["dotnet", "HelloDockerNetCore.dll"]
经过ENTRYPOINT指令咱们指定在容器启动时要运行的应用程序
打开cmd命令行工具,进入到Dockerfile所在的文件夹,键入以下命令:
docker build -t hellodockercoreimage:v1 . 如图所示:
docker经过build指令来建立镜像(Image),build指令后的-t表示的是指定当前Image的Tag,你们能够理解成Image的Name,镜像名称冒号后面的v1你们能够理解成当前Image的版本号,若是不指定的话默认会为latest,最后的. 表示的是Dockerfile所在的当前目录。上面的指令能够理解成基于Dockerfile建立一个v1版本的名为hellodockercoreimage的镜像,执行该命令会获得如图所示的结果:
截图中显示了Dockerfile中咱们所写的指令的执行状况,最后会提示你Image建立成功。若是你们是第一次执行FROM指令,docker daemon会去docker registry中拉取该基镜像,这个过程至关于下载该镜像到本地,执行起来会慢一些,你们不要着急。
咱们经过docker images指令来查看建立的镜像,如图所示:
经过运行指令docker run -d -p 9001:80 --name hellodockercorecontainer hellodockercoreimage:v1 来运行容器,结果如图所示,返回的是当前Container的ID,C:\ProgramData\Docker\windowsfilter\ 中找到该容器:
该指令表达的意思是基于hellodockercoreimage:v1镜像在detached模式下运行一个名为hellodockercorecontainer的容器,而且将宿主机器的9001端口与容器的80端口进行映射
容器启动后,能够经过http://locahost:9001 来访问当前运行的站点,如图所示:
还有另一种访问方式,即经过container运行的IP+Port的方式访问:http://{IP}:{Port}, 其中IP为container的IP,Port为container暴露的端口,不指定的话默认暴露的是80端口,咱们能够经过以下指令获取到container的IP:
docker inspect -f '{{.NetworkSettings.Networks.nat.IPAddress}}' container-name
能够经过访问地址http://cotainerip 来访问当前运行的站点
以上咱们便完成了对ASP.NET Core应用程序容器化的过程,目前在VS2017中已经集成了对Docker的support,即咱们能够在建立project的时候就直接指定当前project须要docker支持,这样建立出来的程序就默认带了Dockerfile文件,如图所示,在建立工程的时候勾选中Enable Docker Support: