平和喜乐 發表於 2018-12-6 09:50:00

Docker最全教程——从理论到实战(五)

<h2><strong>往期内容链接</strong></h2>
<h1 class="postTitle"><span style="font-size: 15px">Docker最全教程——从理论到实战(一)</span></h1>
<h1 class="postTitle"><span style="font-size: 15px">Docker最全教程——从理论到实战(二)</span></h1>
<h1 class="postTitle"><span style="font-size: 15px">Docker最全教程——从理论到实战(三)</span></h1>
<h1 class="postTitle"><span style="font-size: 15px">Docker最全教程——从理论到实战(四)</span></h1>
<h2>&nbsp;</h2>
<p><strong>本篇教程持续编写了3个星期左右并且一直在完善、补充具体的细节和实践,</strong><strong>预计全部完成需要1到2个月的时间</strong><strong>。由于编写的过程中极其费时,并且还需要配合做一些实践(有些实践存在一些坑,而且极其费时费事)。因此目前产出的速度已经跟不上发布的速度了,后续的发布节奏会放慢,请大家多多理解和多多包含。</strong></p>
<p><strong>在这个过程中,我们希望能够多多交流,多多分享。根据目前和大家的交流,笔者针对大家的情况进行了一些修改和补充,希望对大家有所帮助。</strong><strong>另外,对于熟悉容器服务的你,也可以参与进来,让我们一起打造这个系列教程,以帮助更多的人。</strong><strong>同时,我们也希望得到大家的支持,你们的支持是我们前进的最大动力!</strong></p>
<p>&nbsp;</p>
<h1><strong>运行 Docker 应用程序</strong></h1>
<p>如果应用程序只有一个容器,则可通过将其部署到 Docker 主机(虚拟机或物理服务器)来运行该程序。 但如果应用程序包含多项服务,则可使用单个 CLI 命令 (docker-compose up) 或使用 Visual Studio(会在其中使用该命令)将其部署为组合应用程序。</p>
<p>单个应用,就如我们上面的demo :</p>
<p>docker run --name aspnetcore_sample --rm -it -p 8000:80 microsoft/dotnet-samples:aspnetapp</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093156406-1956457614.png" alt=""></p>
<p>应用程序启动后,使用浏览器打开http://localhost:8000,即可看到以下界面:</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093317794-1258397949.png" alt=""></p>
<p>但是如Magicodes.Admin框架所示,有后台接口、后台前端应用、前端接口、小程序端、APP等等,那么我们可以通过上面配置的docker-compose文件来部署为组合应用程序。执行起来很简单,只需要运行以下命令:</p>
<p>docker-compose up</p>
<p>执行之后,我们可以看到:</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093359927-310418271.png" alt=""></p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093414037-276480232.png" alt=""></p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093429057-594952439.png" alt=""></p>
<p>Magicodes.Admin提供了本地编译、打包、构建镜像以及运行等整套脚本,在通常情况,我们仅需一键运行脚本即可。</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093459540-727215529.png" alt=""></p>
<p>脚本会自动完成对后台服务和前端应用的构建以及运行。在上一节中,我们说到,Visual Studio对这块已经完成了相关的支持,如果是使用Visual Studio的开发者,仅需按下F5即可运行。</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093535846-1184309844.png" alt=""></p>
<h2>&nbsp;</h2>
<h2>测试</h2>
<p>容器正常运行了,我们可以让测试人员来访问我们的服务来进行相关的功能测试和可用性测试。当然,我们也可以编写自定义脚本进行自动化测试,就如前面章节中Docker-compose常用场景中提到的自动化测试环境:</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093612969-1874266051.png" alt=""></p>
<h2>&nbsp;</h2>
<h2>部署或继续开发</h2>
<p>开发完成后,我们就需要部署我们的应用,并且继续项目迭代。在部署之前,我们需要推送我们的镜像,比如使用docker push命令,我们可以将镜像推送到docker的官方镜像库,也可以推送到各大云自己的镜像库,然后再通过docker pull命令拉取镜像进行部署。同时,也可以使用一些CI(持续集成)工具来完成自动化的边开发边部署的工作。CI这块,我们接下来会介绍基于Azure DevOps、Tencent hub、Jenkins以及TeamCity等服务或工具来完成CI。在本节,我们继续了解镜像推送的语法:</p>
<p>docker push {镜像名称}:{镜像版本}</p>
<p>在推送之前,我们需要登录到一个镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub。相关语法如下所示:</p>
<p>docker login --username {用户名} --password {密码} {仓库地址}</p>
<p>推送成功之后,如下所示:</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206093652663-585871845.png" alt=""></p>
<p>关于部署和托管这块,接下来我们以腾讯云的容器服务进行举例。</p>
<p>为什么是腾讯云,因为他家的创业服务支持活动赞助了我们很多代金券,基本上接近免费,因此从成本考虑,我们首选腾讯云(腾讯云:瞎说什么大实话)。</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206094114045-1475907846.png" alt=""></p>
<p>部署完成之后,我们可以继续产品或项目的迭代。在整个开发工作流中,我们可以显著的看到,由于Docker的出现,在一定层次上改变了我们的工作和交付流程,并且可以大大的简化CI、CD流程。或者就从构建上来说,配置dockerfile来完成构建,比传统的方式来的迅猛多了。而配置docker-compose.yml一次启动多个服务,简直是分布式架构、微服务架构开发和测试人员的福音。</p>
<p>至此,整个Docker持续开发工作流程就到此结束,在后面的篇幅,我们侧重于从实战的角度来讲解这些内容。</p>
<p>&nbsp;</p>
<h1><strong>使用Kitematic来管理docker容器</strong></h1>
<p>这里,我们先插播一个内容。本节,我们先来介绍下Kitematic。</p>
<p>Kitematic是一个开源项目,旨在简化在Mac或Windows PC上使用Docker的过程。Kitematic自动化Docker安装和设置过程,并提供直观的图形用户界面(GUI)来运行Docker容器。</p>
<p>因此,我们推荐大家使用Kitematic工具来查看和管理自己的容器服务,如果尚未安装此工具,大家可以通过以下方式进行安装:</p>
<ul class="list-paddingleft-2">
<li>
<p>从Docker for Mac或Docker for Windows菜单中选择Kitematic,开始使用Kitematic安装。如下图所示:</p>
</li>
</ul>
<p>&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206094156148-538314738.png" alt=""></p>
<ul>
<li>直接从Kitematic版本页面下载Kitematic 。下载地址:https://github.com/docker/kitematic/releases/</li>
</ul>
<p><span style="background-color: rgba(0, 204, 255, 1)">注意:</span>这里我们不推荐使用Docker Toolbox,原因我们在前面已经说过,Docker Toolbox仅支持老版本的操作系统,属于过时的工具。</p>
<p>安装完成之后,启动后可以看到如下界面:</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206094306712-222543209.png" alt=""></p>
<p>也可以点击某个服务来查看详情、相关设置、日志等:</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206094321918-1548965202.png" alt=""></p>
<p>另外,Kitematic 集成了Docker Hub,允许通过搜索、拉取任何需要的镜像,并在上面部署应用。它同时也能很好地切换到命令行模式。目前,它包括了自动映射端口、可视化更改环境变量、配置卷、流式日志以及其它功能。</p>
<p><span style="background-color: rgba(0, 204, 255, 1)">注意:</span>如果安装完成后如果无法打开,请将Kitematic安装后的文件迁移到Docker指定目录【C:\Program Files\Docker\Kitematic】。</p>
<p>&nbsp;</p>
<p>kitematic 是开源的,如果大家有兴趣,可以访问其开源库下载全部源代码进行研究:</p>
<p>https://github.com/docker/kitematic</p>
<p><img src="https://img2018.cnblogs.com/blog/70544/201812/70544-20181206094331968-578401621.png" alt=""></p>

</div>
<div id="MySignature" role="contentinfo">
    作者:雪雁<br>出处:http://www.cnblogs.com/codelove/
<br>如果喜欢作者的文章,请关注【CodeSpirit-码灵】公众号以便第一时间获得最新内容。本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。<br><b>静听鸟语花香,漫赏云卷云舒。</b>
<br>
<img src="https://images.cnblogs.com/cnblogs_com/codelove/315887/o_251224070213_%E5%85%AC%E4%BC%97%E5%8F%B7.jpg" width="100" height="100"><br><br>
来源:https://www.cnblogs.com/codelove/p/10075006.html
頁: [1]
查看完整版本: Docker最全教程——从理论到实战(五)