网站首页 > 教程文章 正文
1. 离线安装Python
https://www.python.org/ftp/python/3.7.1/Python-3.7.1.tgz 解压,编译,安装
tar xzvf Python-3.7.1.tgz
./configure
make
make install
离线环境下如果系统不是完整版安装编译会报错,需要解决依赖问题,如下:
The necessary bits to build these optional modules were not found:
_bz2 _curses _curses_panel
_dbm _gdbm _hashlib
_lzma _sqlite3 _ssl
_tkinter _uuid readline
下载依赖包 第一种方式: 在pkgs.org 上搜索依赖包 第二种方式:
yum install --downloadonly --downloaddir=DLDIR zlib-devel bzip2-devel openssl-devel ncurses-devel epel-release gcc gcc-c++ xz-devel readline-devel gdbm-devel sqlite-devel tk-devel db4-devel libpcap-devel libffi-devel
下载完成后上传到目标服务器
2. 离线安装flask包
在有网的机器上下载whl包
pip download flask==1.0.2 -d pip-package #pip-package为存放whl文件的路径,会自动生成
在没有网络的服务器上安装flask模块
python3 -m pip install flask --no-index --find-link=pip-package
遇到的问题: pip-package路径下已经存在MarkupSafe的whl文件但是仍然报错
Could not find a version that satisfies the requirement MarkupSafe>=2.1.1 (fro m Werkzeug>=0.14->flask) (from versions: ) No matching distribution found for MarkupSafe>=2.1.1 (from Werkzeug>=0.14->flask )
$ ls
MarkupSafe-2.1.2-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
解决python通过pip离线安装flask依赖包MarkupSafe报错No matching distribution found for MarkupSafe>=2.1.1
单独安装这个MarkupSafe试试:
$ python3 -m pip install MarkupSafe-2.1.2-cp37-cp37m -manylinux_2_17_x86_64.manylinux2014_x86_64.whl --no-index
报错 MarkupSafe-2.1.2-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl is not a s upported wheel on this platform. 平台不支持,在https://pypi.org/project/MarkupSafe/2.1.3/#files 上看所有的whl文件
- "musllinux"和"manylinux"都是Linux系统的名称。
- "musllinux"是基于MUSL libc库的一种Linux发行版,MUSL libc是一个超轻量级的C标准库,它相对于glibc等标准库来说更小巧,更适合嵌入式设备或者资源有限的系统。
- "manylinux"则是一个软件打包规范,在多种Linux发行版上运行的二进制包。这个规范主要是为了解决在不同Linux发行版上软件依赖方面的问题。符合这个规范的二进制包能够在多种Linux发行版上运行,因为它们包含了不同Linux发行版上所需的所有依赖库。
版本并没有什么问题 查看系统版本(通过python方法查看): python3
from distutils import util
util.get_platform()
>> 'macosx-11.0-arm64'
没有问题 ,但是系统监测不到 解决: 尝试修改whl包的名称:
mv MarkupSafe-2.1.3-cp37-cp37m-manylinux_2_17_x86_6 4.manylinux2014_x86_64.whl MarkupSafe-2.1.3-cp37-cp37m-manylinux_2_17_x86_64.linux_x86_64.whl
将manylinux2014_x86_64修改为linux_x86_64 问题解决,离谱 知识点:
Python的whl文件是一种Python软件包的二进制分发形式,它通常用于方便地安装和分发Python库。 关于whl文件的命名规范,一般采用以下格式: distribution_name-version-cp[python_version]-[abi_tag]-[platform_tag].whl 其中,各个字段的含义如下:
- distribution_name:软件包名称
- version:软件包版本号
- cp[python_version]:Python版本号,如cp37表示Python 3.7 - abi_tag:软件包兼容的Python ABI标签,如cp37m表示CPython 3.7的ABI标签
- platform_tag:软件包适用的操作系统平台标签,如linux_x86_64表示Linux下的64位系统,macosx_10_9_x86_64表示Mac OS X 10.9下的64位系统
举个例子,一个包名为mymodule,版本号为1.0.0,适用于Python 3.7,使用CPython 3.7m作为ABI标签,适用于Linux 64位系统的whl文件应该命名为:
mymodule-1.0.0-cp37-cp37m-linux_x86_64.whl
需要注意的是,上述命名规范只是约定俗成的规范,并非Python官方标准。实际上,它还有一些变种和衍生,具体的命名方式可以参考各个Python库的官方文档或源码仓库。
3. 离线安装numpy
安装方式同上:
报错: python3 -m pip install numpy --no-index --find-li nk=. Looking in links: . Collecting numpy Could not find a version that satisfies the requirement numpy (from versions: ) No matching distribution found for numpy
解决同上:
mv numpy-1.21.6-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl numpy-1.21.6-cp37-cp37m-manylinux_2_12_x86_64.linux_x86_64.whl
猜你喜欢
- 2024-12-13 基于Python+Flask+MySQL+Vue的失业保险人员信息管理系统系统
- 2024-12-13 基于Python+MySql+Flask+Vue的电脑运维管理系统
- 2024-12-13 基于Python+Flask+MySQL+HTML的视频数据可视化分析系统
- 2024-12-13 Python+Pandas+Flask+Vue:模拟WPS表格合并收费功能!
- 2024-12-13 是时候学习Web开发了,1小时用Python开发一个博客系统
- 2024-12-13 几个炫酷的Python开源项目,让你从此走上人生巅峰
- 2024-12-13 AdminLTE-Jinja2模板:Flask,Bottle框架使用的一种模板语言Python
- 2024-12-13 Docker在手,天下我有,Win10下Docker部署Gunicorn+Flask独立镜像
- 2024-12-13 CentOS 下用 Nginx 和 uwsgi 部署 flask 项目
- 2024-12-13 Flask Web开发:基于Python的Web应用开发实战-第 1 章 安装
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- md5 sha1 (32)
- mybatis plus page (35)
- semaphore 使用详解 (32)
- update from 语句 (32)
- vue @scroll (38)
- 堆栈区别 (33)
- 在线子域名爆破 (32)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)