生成python依赖包文件

Kubernetes

本文首先需要安装python环境,可以自行查阅文档,这里不再说明。

假如,我们有一个名为hello-flask的flask应用,该应用只依赖flask外部包。

有两种方式可以生成该应用的依赖包文件,分别介绍:

方式一

在hello-flask应用的根目录下,执行如下命令:

pip freeze > requirements.txt

则会自动生成requirements.txt文件,内容如下:

alabaster @ file:///home/ktietz/src/ci/alabaster_1611921544520/work
anaconda-client==1.2.2
anaconda-navigator==2.0.3
anaconda-project @ file:///tmp/build/80754af9/anaconda-project_1621348054992/work
anyio @ file:///C:/ci/anyio_1620153418380/work/dist
appdirs==1.4.4
argh==0.26.2
argon2-cffi @ file:///C:/ci/argon2-cffi_1613037959010/work
asgiref==3.7.2
asn1crypto @ file:///tmp/build/80754af9/asn1crypto_1596577642040/work
astroid @ file:///C:/ci/astroid_1613501047216/work
astropy @ file:///C:/ci/astropy_1617745647203/work
async-generator @ file:///home/ktietz/src/ci/async_generator_1611927993394/work
atomicwrites==1.4.0
attrs @ file:///tmp/build/80754af9/attrs_1620827162558/work
.
.
.
太多了,省略一万行
.
.
.
wcwidth @ file:///tmp/build/80754af9/wcwidth_1593447189090/work
webencodings==0.5.1
Werkzeug==2.3.7
widgetsnbextension==3.5.1
win-inet-pton @ file:///C:/ci/win_inet_pton_1605306167264/work
win-unicode-console==0.5
wincertstore==0.2
wrapt==1.12.1
xlrd @ file:///tmp/build/80754af9/xlrd_1608072521494/work
XlsxWriter @ file:///tmp/build/80754af9/xlsxwriter_1617224712951/work
xlwings==0.23.0
xlwt==1.3.0
xmltodict==0.12.0
yapf @ file:///tmp/build/80754af9/yapf_1615749224965/work
zict==2.0.0
zipp==3.16.2
zope.event==4.5.0
zope.interface @ file:///C:/ci/zope.interface_1616357322857/work

卧槽,应用只依赖了flask外部包,竟然生成了这么多依赖,明显有问题吧?通过安装验证,确实有问题,而且根本安装不成功,不要再使用这种方式生成包依赖了。

下面看第二种。

方式二

安装工具
pip install pip-tools
创建文件

在应用根目录下创建requirements.in文件,内容如下:

flask==2.3.1
生成依赖包文件

在应用根目录下执行:

pip-compile requirements.in

则requirements.txt文件内容如下:

#
# This file is autogenerated by pip-compile with Python 3.8
# by the following command:
#
#    pip-compile requirements.in
#
blinker==1.6.2
    # via flask
click==8.1.7
    # via flask
colorama==0.4.6
    # via click
flask==2.3.1
    # via -r requirements.in
importlib-metadata==6.8.0
    # via flask
itsdangerous==2.1.2
    # via flask
jinja2==3.1.2
    # via flask
markupsafe==2.1.3
    # via
    #   jinja2
    #   werkzeug
werkzeug==2.3.7
    # via flask
zipp==3.16.2
    # via importlib-metadata

文件内容很少,而且还有依赖关系,非常清晰。

安装

在应用的根目录下,执行:

pip install -r requirements.txt

命令执行完以后,接着就可以运行该应用了。

最后,推荐一个部署应用的平台: https://github.com/512team/dhorse

演示地址:http://dhorse-demo2.512.team

0
0
0
0
关于作者
相关资源
云原生机器学习系统落地和实践
机器学习在字节跳动有着丰富业务场景:推广搜、CV/NLP/Speech 等。业务规模的不断增大对机器学习系统从用户体验、训练效率、编排调度、资源利用等方面也提出了新的挑战,而 Kubernetes 云原生理念的提出正是为了应对这些挑战。本次分享将主要介绍字节跳动机器学习系统云原生化的落地和实践。
相关产品
评论
未登录
看完啦,登录分享一下感受吧~
暂无评论