![5aac30054bfd925d5acf27a391c719bb.png](https://img-blog.csdnimg.cn/img_convert/5aac30054bfd925d5acf27a391c719bb.png)
代码迁移
之前编写的时候还运行的很好,现在怎么突然就不能运行了?
在我电脑上运行的很好,换了电脑怎么就不能运行了?
开发软件不能只顾写代码,更要确保代码可以迁移,易于部署,易于维护。
代码都需要依赖特定的环境才能运行。这个环境包括:
- 你的硬件有没有变化?网络断了吗?显卡换了吗?芯片是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。
画成一张图是这样的:
![620112d4cc55e8e71a88b9fe886d3d9f.png](https://img-blog.csdnimg.cn/img_convert/620112d4cc55e8e71a88b9fe886d3d9f.png)
【更多文章请点这里阅读】
每个人的智能时代
如果您发现文章错误,请不吝留言指正;
如果您觉得有用,请点喜欢;
如果您觉得很有用,欢迎转发~