今天,我们兴奋地宣布在Mesosphere DC/OS服务目录当中发布TensorFlow的beta测试版本。只需要一条命令,您现在即可将分布式TensorFlow部署在任意裸机、虚拟或者公有云基础设施当中。与其它可用于DC/OS的软件包一样,新的TensorFlow软件包亦可利用GPU来加速各类机器学习与深度学习应用。
在由深度学习技术掀起的新一轮军备竞赛当中,专注于尝试学习的数据科学家已经成为人才市场上的新宠。而有效的数据科学基础设施将帮助您吸引更多顶尖数据科学家,并获得由他们倾力构建起的工作成果,最终为您的企业带来远超竞争对手的战略优势。向DC/OS当中引入分布式TensorFlow的作法,也进一步巩固了Mesosphere长久以来作出的支持开发人员、运营人员以及数据科学家群体的承诺。
TensorFlow是一套极具人气的开源库,由谷歌Brain团队所打造,专门面向机器学习类场景。事实上,TensorFlow为2015年GitHub上的头号fork项目,且在之后的两年当中一直雄踞fork活跃度榜前十位名次。TensorFlow的高人气主要源自其利用一套基于数据流图形的计算模型实现深层神经网络开发与训练简化的强大能力。
在以上示例当中,输入层负责寻找局部对比模式,隐藏层1负责利用这些对比结果发现个人面部特征,隐藏层2则基于这些面部特征进行整体面部识别。资料来源:https://www.edureka.co/blog/what-is-deep-learning。
一般来讲,深层神经网络的生命周期需要经历两个不同的阶段:训练与推理。在我们的示例当中,训练阶段需要为神经网络提供成千上万图像,帮助其训练面部识别能力。这一训练过程可能需要数个小时、数天甚至数周时间才能完成,具体取决于数据集规模、模型复杂度以及硬件性能等各类因素。一旦训练工作完成,该神经网络即可用于“瞬时”识别图像中的面部要素。
下图所示为训练与推理过程的细节判断:
虽然TensorFlow适用于上述分类网络的设计与实现,但其强大的能力并不仅限于此。TensorFlow还能够在对象追踪(https://github.com/akosiorek/hart)、文本到语音生成(https://github.com/ibab/tensorflow-wavenet)甚至自动驾驶车辆(https://github.com/udacity/self-driving-car/)领域有所建树。
TensorFlow通过提供可直接集成至代码当中的基础机器学习原语以简化深层神经网络的开发工作。TensorFlow以库的形式提供此类原语,并将其绑定至多种高人气语言(例如C/C++、Go、Java以及Python等)当中。此外,TensorFlow还能够自动计算出运行代码的最佳处理单元(CPU、GPU或者TPU等)。
在Python当中开发TensorFlow应用程序,且此应用将CPU与GPU相结合以完成运行。
深度神经网络的设计与实现(即使是在TensorFlow的帮助之下)并非小事。数据科学家们必须首先构建起机器学习模型,确保其适合分布式计算特性,而后将其映射至深层神经网络当中,最终编写代码以为这套新模型提供支持。另外,他们还必须决定是否有必要以分布式方式定义并实现自己的深层神经网络,抑或直接将其设计为可在单一工作站之上运行。
各类组织机构在部署分布式TensorFlow应用程序时,可通过在DC/OS上运行该服务的方式解决众多常见的挑战。
在TensorFlow当中运行分布式计算时,要求大家理解不同组件之间的复杂交互方式;其中Parameter Server负责将最新值交付至Worker处,而后者则负责执行具体计算;此外,Master则协调并同步以上一切分布式处理工作。
开发人员与数据科学家们承担着设计模型并编写适合的分布式TensorFlow应用程序,从而达成最终目标的艰巨任务——但这还仅仅只是开始。在实际集群部署工作当中,分布式TensorFlow代码的运行与维护如果缺少DC/OS的帮助,则将成为一项劳动密集型任务。
TensorFlow提供的原语有助于在大型设备集群之上进行工作负载分发。
开发人员的工作是为每套部署体系定义一个惟一的ClusterSpec,这些部署体系必须为不同的工作节点与参数服务器启动IP地址与端口列表。此后,开发人员必须手动配置各设备以确保其与ClusterSpec当中的定义内容保持一致;最终,代码才能被部署到这些设备上并开始运行。即使是在基于云的动态环境当中,ClusterSpec仍然必须在基础设施发生变化时进行手动更新。
然而,传统的TensorFlow实现方案会交ClusterSpec嵌入至深度学习模型代码当中。如此一来,管理人员必须熟知ClusterSpec的编辑周期并针对每个工作节点进行重启以逐一进行修改测试,方可实现操作参数的配置与微调。DC/OS则能够自动实现ClusterSpec更新,帮助数据科学团队摆脱这种枯燥且极易出错的负担。
DC/OS上发布的全新TensorFlow beta测试版本能够解决以上所有难题。具体来讲,其有助于:
简化分布式TensorFlow的部署:将分布式TensorFlow集群中的全部组件部署在任意基础设施之上——包括裸机、虚拟或者公有云——将变得异常简单,具体操作类似于将JSON文件传递至一条CLI命令。参数的更新与调整亦可轻松实现,意味着微调与优化不再令人困扰。
在不同团队间共享基础设施:DC/OS允许多个团队共享同一基础设施并启动多项不同TensorFlow任务,同时始终保持资源隔离。一旦TensorFlow任务完成,相关容量即被释放并可供其它团队使用。
在同一集群之上部署不同TensorFlow版本:与众多其它DC/OS服务一样,您同样可以在同一集群之上轻松部署同一服务的多个实例,并保证其采用不同的版本。这意味着当TensorFlow发布新版本时,您的一支团队可以使用其最新功能与特性,但又不必对其它团队的代码作出变更。
动态分配GPU资源:GPU能够显著提升深度学习模型的执行速度,特别是在训练阶段。然而,GPU是一种宝贵的资源,因为必须得到有效利用。由于DC/OS能够自动检测集群上的所有GPU,所以其将实现基于GPU的资源调度,允许TensorFlow基于各项任务请求全部或者部分GPU资源(类似于请求CPU、内存以及磁盘等其它常规资源)。一旦任务完成,GPU资源将被释放并可供其它任务使用。
专注于模型开发,而非部署:DC/OS 将模型开发从集群配置工作当中剥离出来,从而消除了以手动方式将ClusterSpec引入模型代码的难题。相反,用户在部署TensorFlow软件包时只需要指定其希望模型在运行中使用的各工作节点以及参数服务器属性,而后软件包自身会在部署时为此生成一个独特的ClusterSpec。从实现层面来讲,该软件包会找到一组作为各工作节点/参数服务器运行基础的设备,使用合适的值填充CLusterSpec,启动各参数服务器与工作节点任务,并传递其生成的ClusterSpec。开发人员只需要编写出需要填充的代码,该软件包即可自行完成剩余任务。
下图所示为一条JSON片段,其可用于将来自DC/OS CLI的TensorFlow软件包部署至一组CPU与GPU工作节点当中。
此命令将使用以上配置启动TensorFlow:
dcos package install beta-tensorflow --options=
该软件包亦可通过在UI中指定参数的方式立足DC/OS服务目录进行部署。
自动完成故障恢复:TensorFlow软件包利用DC/OS SDK编写而成,并使用了自动重启等内置弹性功能,因此能够顺利且高效地实现任务自我修复。
在运行时中安全部署任务配置参数:DC/OS秘密服务在运行时会为每个TensorFlow实例动态部署凭证与秘密配置选项。操作人员可以轻松添加凭证以访问秘密信息或者特定配置URL,从而确保其不会暴露在模型代码当中。
原文链接:https://mesosphere.com/blog/tensorflow-gpu-support-deep-learning/
深入学习Kubernetes
本次培训内容包含:Kubernetes架构、Kubernetes安装、Kubernetes功能导览、监控解决方案、Kubernetes高阶——设计和实现、Kubernetes落地实践等,点击识别下方二维码加微信好友了解具体培训内容。