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

    在发布ASP.NET Core网站之前,先介绍一下DaoCloud 一个免费的docker云容器服务平台。登录官方网站,建立一台docker主机,这台主机有120分钟的使用时间,对于鄙人学习使用正好合适。这台docker主机通常是ubuntu主机,同时docker里面已经集成了一些镜像例如:mysql 、nginx等。html

  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中。mysql

        在制做镜像时咱们须要建立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
     在外网访问一下,看到这个页面说明今天成功了。
相关文章
相关标签/搜索