“一键飞桨”,轻松实现飞桨框架和套件的下载安装!

大家好,我是散步,很荣幸能和大家分享一个搭建飞桨全系列产品开发和使用环境的小工具。希望它能够帮助你在新场景下快速搭建飞桨工作台,让大家能够更简单地将飞桨安利给身边的朋友。

80a4807861edbe2a7d8884524aa42451.png

简介

你是否在新的虚拟环境或者新电脑上配置飞桨环境时发现一个个克隆飞桨的仓库很麻烦?没有关系!我给大家提供了一个超级方便的工具,你可以一键安装飞桨框架以及CUDA(目前该工具默认安装CUDA11.2版本)和CUDNN的环境配置,并且可以一键下载并安装自己想要的飞桨套件,省去搜索、下载、环境配置的时间,更专注于项目内容的开发。

你可以通过AI Studio项目的挂载数据集或者GitHub仓库获取该工具(后文统称“一键飞桨”工具)。

  • AI Studio项目

https://aistudio.baidu.com/aistudio/datasetdetail/189777

  • GitHub仓库

https://github.com/sanbuphy/fool-proof-paddle

4f1fee94e35af4bdb12bf2b46d2edfa9.png操作步骤

接下来我将详细介绍在Linux和Windows系统上如何使用“一键飞桨”工具。

备注:所有操作都在安装工具解压后的文件夹内完成。

c61d7c7fe8231fd33f094cd79f068696.png

Linux环境下使用说明

Linux环境下的下载

如果仅仅为了下载,你可以直接在解压“一键飞桨”后的文件目录下输入bash main.sh命令行,随后输入1即可进入下载选择界面。

1de05a5dc004187741416b7c2bd6d2dd.png

在下载选择界面,通过连续输入飞桨框架或者飞桨套件对应的大写字母,即可下载对应的仓库。假设我们想下载飞桨框架Paddle仓库、飞桨模型压缩工具PaddleSlim仓库、飞桨轻量化推理引擎Paddle Lite仓库,我们可以连续输入大写字母ABC,即可实现以上仓库的自动下载。根据图片所示,可以大概了解套件的下载方法,例如:

64e3659311932fde85c752414582b19d.jpeg

最后看到以下内容,就说明已下载成功!

7498e46673c8c5011a62ed1c989cfa7b.png

Linux环境下的安装

为了实现飞桨框架以及飞桨套件的安装,首先在命令行输入source main.sh,即出现以下界面。

0b1b3929f0bbc91954bec5b2b76bd3ef.jpeg

随后输入2以执行安装飞桨框架以及飞桨套件,出现的界面如下图所示。

4ca9d49883fd106419c73fcf9e198db5.jpeg

随后输入1以安装飞桨框架及对应CUDA环境。输入2以安装之前下载好的飞桨套件。

058f786317def18434d0b1f02b5c9960.png

Windows环境下使用说明

Windows环境中的下载

输入python main.py然后输入对应的字母完成下载。如果你没有安装git bash,此时会自动下载并安装git bash。注意,请一路按照默认安装!不要自己改安装地点。

7109b38166e83cdb9b42d750d4ed848e.png

输入字母后便进入下载方式的选择,此时推荐第一次选择N,第二次选择Y即可使用gitee的http方式下载各个仓库,速度较快。

最后,当看到下方内容,就说明已经下载成功啦!

4f422b7e4d14a6c0bb10f229cedf3c09.png

Windows环境下的安装

在对应虚拟环境中执行python main.py,其他按照提示操作即可完成飞桨框架的安装和所有已下载套件的安装。

21ad49bab2e73280a1822a1a0a4191c5.png

除了可以安装飞桨框架,目前“一键飞桨”工具支持下载和安装的飞桨套件如下:(不断更新中)

  • PaddleDetection

  • PaddleSpeech

  • PaddleClas

  • PaddleSeg

  • PaddleNLP

  • PaddleVideo

  • PaddleOCR

  • PaddleGAN

  • PaddleSlim

  • FastDeploy 

83d05c56865ed8da20f1da0e99831113.png工具制作过程分享

虽然该项目看起来简单,但实际整个工具的制作过程遇见了较多困难。在此特别感谢帮助我测试的每个朋友,因为你们让项目更为稳健。制作工具的初始,我也考虑过直接使用Python做成跨平台下载与安装工具,但考虑到可实现性和速度,最终采用了更简单直接的功能实现方式。同时,为了防止安装问题发生,安装代码中还加入了很多防御性检查(是否安装、是否下载、是否安装成功),最大程度提高了工具的稳健性。接下来我将针对Linux和Windows版本分别介绍实现过程中的困难点:

647b85d37533c55b5eb302436c52e3cf.png

Linux环境工具制作分享

主项目的入口主要起到任务分发的作用,制作过程中先保证了每部分的独立功能后才进行整体集成,以保证单元的可执行、可测试。

e17b9be3c826b702f6ee802169b93298.png

为了快速实现功能,这里选择了简单粗暴的shell数组方式。对于下载部分的实现可在download_paddle.sh里查看:

3c685a25ce56e32520a3f73ab4a7848d.png

如果你想要加入新的下载仓库,可以用同样的方式在下面加入即可。在环境安装环节,考虑到网络可能存在不稳定的情况,采用“wget -c”保证飞桨程序安装包能顺利安装。

723d72dd91b18ce21b825d870a19b17e.png

与CPU版本的飞桨不同,GPU版本安装好后还需进行环境配置。

1212ef99ff0c43c0e332e84b3e217518.png

环境配置环节,CUDA和CUDNN的安装最为让人头痛。为此,加入检测环境和驱动CUDA版本的判断,以覆盖大部分用户安装的基础环境。同时根据NVIDIA官方文档详细对照了gcc版本确定了安装逻辑(CUDA程序安装对gcc版本有要求)。这让不同用户都可以稳定安装,避免报错。

b123a984e96782fb71a743fe7010bd5a.png

接下来是CUDNN安装环节,在这一部分我还做了多项检查保证安装的正确:

f7f2d74b4e611016a5674197b6f8d939.png

脚本的最后加入环境变量,以让默认链接过程能搜索到对应的依赖。

这里使用CUDA而非网上常见的CUDA 11.2 等完成操作,是因为CUDA的本质是软链接,在完成安装后会被自动软链接为安装版本。软链接对象可在对应文件夹下使用ll命令查看。通过这种方式,可实现WSL和Linux实体机的共同兼容。

e4639e8da4964871fa71d3a2765030eb.png

至此,下载和安装的脚本思路已经介绍完毕,接下来我将介绍有关套件安装脚本的一个值得注意的小技巧:

部分套件需要运行python脚本以验证效果。通过使用```覆盖部分python脚本,实现了用python – c在shell脚本中验证完整套件。

94f51475cb05500eae33dafc1ef5f929.png

也可以通过逐个分割实现相同目的。但过于繁琐,并不推荐。

b1d0874ed0d467b27eed697c051ca9e6.png

至此,Linux环境工具制作过程已经大概介绍完毕。总体来说使用Linux安装脚本制作较为简单(个人偏爱)。

7813d2a69c65df4461418293634d3c90.png

Windows环境工具制作分享

Windows工具的制作比Linux环境要繁琐的多。因为很多调用方式特殊,且与Linux完全不兼容,所以在查阅工具的过程中花费了很多时间。这里我采用在脚本中直接下载安装git-windows的方式,以实现Linux环境的下载工具的直接复用。

对于Windows环境下的飞桨安装工具,一开始我没有想好怎么利用当前虚拟环境解释器去安装对应的环境,只能用这种方法对需要pip安装的库进行安装:

b8f7159bfe0a5d6ce02eda82d24a076f.png

之后我看到了可以通过sys.executable获得当前解释器的路径,这就给了我们直接运行命令行的可能,之后的pip安装都会在前面加上这样一句用于对应虚拟环境解释器的指定:

da44a913a70066471c9d3b342f489bec.png

在Windows环境下,由于默认命令行缺少很多工具,所以我们要通过powershell简介进行下载、安装、转移操作:

defcc66d8c5c7004717f41147d8c2397.png

此时最难的一步是安装CUDNN,需要满足以下条件:

1)管理员权限操作,因为CUDA的安装地点默认在需要管理员操作权限的地方;

2)复制文件后需要覆盖目标文件;

3)在powershell或者cmd中实现这些操作。

最后我和小伙伴讨论出一个折中的方案,我们通过一个间接的python文件执行拷贝,同时显式指定了需要覆盖。

faceef405afee681c573548d8f93abe6.png

394e90e5d9b8c2ad8cd0e637aeb5f7fe.png

但这里面临另一个问题,由于我们安装的环境是python3.7,但shutil的copytree只有在python3.8之后的版本才支持显式覆盖的操作,所以在这里对源码进行了改进:

ea13855fbe1b614292c260e717f6ff33.png

看完了飞桨安装和环境配置,我们最后来看下套件的安装,其全部实现逻辑在paddle_tools.py中。由于我们需要把套件安装到对应的执行环境中,并且要满足在对应文件夹下执行命令的需求,所以在每个执行函数的开头都必须进行一个“初始化”的操作:

69551ad4e55e15229bc0a79d577dee2d.png

这里的cd_dst_dir就是进入目标文件夹的意思,通过获取函数名和当前目录可以直接让os.system运行的cmd进入预期文件夹,便可实现后续指令的顺利运行:

8d5548b8cd371ba52d970a69ac47face.png

部分Windows用户会在安装PaddleDetection过程中遇到pycootools编译问题,导致库无法使用。这里加入了提示和下载,以保证安装后的直接使用:

866b8a4247db5c6579b9e7204c4c7ad3.png

至此,我们大致浏览了Linux和Windows的飞桨环境配置、安装、套件下载工具的制作流程。希望对你有些帮助,理论上你也可以根据这样的一套模板改造出自己的任何安装工具。

7c7c5c062cd6ce4a80767a4741d42c20.png总结

本项目还在不断更新迭代,后续还将加入PaddleRS、PaddleTS 、Paddle3D、PaddleRec、VisualDL库和飞桨awesome-DeepLearning仓库。如果你有想法,欢迎加入和我一起完善这个工具或各类bug报告。后续,我们还会逐步补充完善各库的简介,以帮助大家简单轻松的探索其他套件。

欢迎大家fork项目,和我一起体验使用飞桨的快乐!

https://aistudio.baidu.com/aistudio/projectdetail/5448389

​​​​​​​

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值