欢迎关注我的专栏( つ•̀ω•́)つ【人工智能通识】
代码迁移
之前编写的时候还运行的很好,现在怎么突然就不能运行了?
在我电脑上运行的很好,换了电脑怎么就不能运行了?
开发软件不能只顾写代码,更要确保代码可以迁移,易于部署,易于维护。
代码都需要依赖特定的环境才能运行。这个环境包括:
- 你的硬件有没有变化?网络断了吗?显卡换了吗?芯片是intel的还是AMD的?内存有没有变多或变少?...
- 你的操作系统是Windows10?还是Windows7?还是MacOS?还是Ubuntu(Linux)?还是CentOS(Linux)?...
- 你的Python版本是2.7?还是3.1?还是3.7?还是4.8?...
- 你用的第三方库的版本是不是一样?你用的TensorFlow是1.4还是1.7?你用的Numpy是1.1还是2.8?...
如果你的代码突然不能运行了,那么上面这些事情都需要检查一番。你要尽力保证所有环境都没变,否则你的代码就很可能无法正常运行。
让环境适应代码比让代码适应环境容易得多,如果条件允许的话。
为代码单独安装一个老版本的TensorFlow并不麻烦,但要阅读新版本TensorFlow全部的更新说明文档,然后再逐行检查代码符合这些繁文缛节的变化,往往就会要了你的命。最好的建议是,不要冒险,不要冒险,不要冒险!
版本管理
不止是管理自己代码的版本,更要管理第三方依赖库的版本。
最好的办法是将代码及其依赖的整个环境打包到一起。是的,最好把操作系统也打包到一起,部署的时候直接连操作系统一起装。这不是玩笑,Docker容器化部署就是这个思路,而Unikernel(LibOS)模式则更加彻底。
比较轻量化的方法是将所依赖的环境配置记录到文件,迁移到其他设备上之后再依赖配置文件重新建造和原来一样的环境。这样的优点是不必把整个庞大的环境(系统+第三方依赖)都塞进项目中,缺点是每次都需要重建,这个重建过程往往不仅耗时而且不很可靠。
Pipenv工具属于后者,早期比较流行的Virtualenv工具已经被其取代。它的基本流程是:
- 创建项目文件夹,配置相应的项目管理,如Git和Github,参见这个简易教程。
- 使用
pipenv install
初始化,自动创建配置文件Pipfile和Pipfile.lock。如果已经存在配置文件,它将根据配置文件重建环境。 - 如果你要使用特定Python版本初始化项目,可以用
pipenv install --python 3.6
命令。 - 把配置文件中第三方库的安装源地址替换为国内镜像,如阿里
url = "https://mirrors.aliyun.com/pypi/simple"
。 - 项目中使用的所有第三方依赖都要使用
pipenv install xxx
安装,这样才能确保安装记录被正确写入配置文件。如果你需要移除某个依赖,可以使用命令pipenv uninstall xxx
命令。 - 运行项目文件要使用
pipenv run python xxx.py
。或者使用pipenv shell
进入项目环境再python xxx.py
,退出环境的命令是exit
或ctrl+D。
项目管理
这里再啰嗦一些内容,补充或强调。
- 安装Python的时候一定要确保路径Path被正确添加到系统中,在Windows里就是安装的时候勾选
Add Path...
选项。 - 下载和安装Git软件。
- 为Git设定你的用户名和邮箱,
git config --global user.name "zhyuzh"
和git config --global user.email "zhyuzh3d@hotmail.com"
。 - 创建项目文件夹,建个README.md文件,随便写点什么。
- 如果你需要把远程Github的项目复制到本地,使用
git clone https://username:password@github.com/yourname/myproject.git
,如果是公开项目可以省略username和password。 - 命令行进入项目文件夹,使用
git init
初始化Git,其实就是建立一个隐身的.git
文件夹。 - 你最好建一个
.gitignore
文件,把不需要Git管理的目录加进去,比如不想公开的密码文件secret.py
,或者程序临时生成的日志文件夹log/
等。 - 注册和登录Github网站,新建一个完全空白的项目比如myproject。
- 使用你从Github获得的命令建立远程关联,比如
git remote add origin https://username:password@github.com/yourname/myproject.git
- 如果你搞错了可以
git remote remove origin
删除关联再来。 - 修改项目代码或内容之后,
git add .
扫描所有文件,git commit -m "xxx"
提交到Git。 - 同步本地Git到Github项目
git push origin master
。 - 把远程的项目拉取到本地的命令
git pull origin master
。
画成一张图是这样的:
<未完待续>
欢迎关注我的专栏( つ•̀ω•́)つ【人工智能通识】
每个人的智能新时代
如果您发现文章错误,请不吝留言指正;
如果您觉得有用,请点喜欢;
如果您觉得很有用,欢迎转载~
END
网友评论