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

    在发布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
     在外网访问一下,看到这个页面说明今天成功了。

 


 
 
 
posted @ 2017-06-28 16:07  程序之美~我爱上编程  阅读(3248)  评论(3编辑  收藏  举报