本篇文章通过一个实例为大家演示如何在Docker容器中运行ASP.NET Core应用程序。
生成ASP.NET Core应用程序
打开vs创建一个ASP.NET Core Application,如图所示:
打开Index.cshtml, 修改里面的内容如图所示:
直接运行application,如图所示:
发布应用程序(可以理解成为应用程序打包)
在vs中右键单击web项目,然后在弹出的menu中选择Publish,弹出如图所示对话框:
点击Create Profile按钮,回到VS窗体中如图所示页面:
点击Publish按钮,开始Publish当前应用程序,成功Publish之后,会在VS Output中看到如图所示的信息:
我们成功将当前应用程序Publish到了制定的PublishOutput文件夹中,如图所示:
添加Dockerfile文件
对dockerfile陌生的小伙伴可以查看(在Docker容器中运行.Net Framework控制台应用程序)文章中对Dockfile的解释。
在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指令我们指定在容器启动时要运行的应用程序
创建镜像(Image)
打开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端口进行映射
浏览器中访问ASP.Net Core 站点
容器启动后,可以通过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:
网友评论