您的位置:首页 > 运维架构 > Docker

docker 初识之二(简单发布ASP.NET Core 网站)

2017-06-28 16:07 951 查看
在发布ASP.NET Core网站以前,先介绍一下DaoCloud 一个免费的docker云容器服务平台。登陆官方网站,创建一台docker主机,这台主机有120分钟的使用时间,对于鄙人学习使用正好合适。这台docker主机一般是ubuntu主机,同时docker里面已经集成了一些镜像例如:mysql 、nginx等。

  1.获取microsoft/dotnet

  登陆这台主机,下载dotnet的镜像:docker pull microsoft/dotnet。如果有什么疑问大家可以移步(Docker 初步认识),由于是云主机所以下载速度很快,这也是鄙人为什么使用这个云主机的主要原因之一。

docker pull microsoft/dotnet




下载完成以后使用命令:docker images 查看是否镜像下载成功。

docker images




2.运行 microsoft/dotnet-samples

  安装完成后,在容器中来运行一个测试的Application,下面是运行结果,这是microsoft写好的一个简单的.net core Dome。

docker run microsoft/dotnet-samples




  3.运行APS.Net core MVC

  需要下载安装dotnet core环境到主机,自己写一个简单的APS.Net core MVC,然后把这个做成一个镜像,然后运行这个镜像。





  上图是在主机中运行了 asp.net mvc 后的结果,说明创建的项目成功运行了。下面把这个asp.net mvc 制作成镜像发布到docker中。

在制作镜像时我们需要创建Dockerfile,下文为VS为我们创建的Dockerfile 模板: 

#镜像来源为 microsoft/dotnet:1.1-runtime  分号后面表示版本信息
FROM microsoft/dotnet:1.1-runtime
#声明变量 在docker build创建镜像时 使用--build-arg 传入参数source
ARG source
#设置路径指令 相当于cd  切换到根目录/app路径下
WORKDIR /app
#复制指令 如果source创建是没有赋值,默认路径为obj/Docker/publish
COPY ${source:-obj/Docker/publish} .
#指定容器启动时执行的命令
ENTRYPOINT ["dotnet", "ConsoleApp1.dll"]


Dockerfile基本语法,就大致说明一下,具体的大家需要去看官方文档
1.用#注释代码
2.命令是从上到下 逐条执行
3.From指令告诉Docker使用哪个基础镜像
4.后面是维护的一些说明信息
在程序中创建的Dockerfile 镜像为microsoft/dotnet 切换到docker 的/app目录下 复制当前目录out到/app目录下,然后执行 dotnet app.dll 命令

FROM microsoft/dotnet:lastest
WORKDIR /app
COPY out .
ENTRYPOINT ["dotnet","app.dll"]


发布重新生成的应用程序到out目录下:

dotnet restore
dotnet publish -c Release -o out




制作成镜像同时运行应用程序,-p 设置访问端口 前面为主机端口 后面位docker容器端口,-e为设置环境变量 这里设置变量ASPNETCORE_URLS=http://+:80,-it 运行前台程序, -d表示运行后台容器,--rm表示运行完成退出时删除由这个镜像生成的容器实例,这里就直接删除了。

docker build -t app .
docker run -p 5000:80 -e "ASPNETCORE_URLS=http://+:80"  -it --name test --rm app


在外网访问一下,看到这个页面说明今天成功了。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: