百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

阿里云主机源码编译安装python3常见错误处理

liuian 2024-12-27 15:15 28 浏览

关于源码编译安装python3环境网上有很多指导教程,一般按照步骤来执行的话都能够顺利完成安装,但是完成编译安装不代表python环境就真的没有问题了,在运行应用时也可能会抛出各种异常错误。比如以阿里ECS云主机(CentOS7.9操作系统)为例,编译安装python3.12环境之后运行python程序就可能遇到下面的异常:

import _ssl报错:

- ModuleNotFoundError: No module named '_ssl'

from smtplib import SMTP_SSL报错:

- ImportError: cannot import name 'SMTP_SSL' from 'smtplib'

使用sqlite3数据库报错:

- django.db.utils.NotSupportedError: deterministic=True requires SQLite 3.8.3 or higher

出现上述错误的原因一般都是系统内置的软件工具版本和python解释器依赖相应工具的版本不匹配导致的,比如前面两个问题是因为阿里云主机默认安装的是openssl1.0.2版本,而python3.12要求更高的openssl版本。sqlite3数据库报错的信息很明显也是版本原因,内置的sqlite3版本不符合python3.12的版本要求。

如果python的版本不能降级的情况下,解决这些问题的办法就只能升级对应工具的版本。这里需要重点强调的是,升级这些工具的版本之后需要重新编译安装python3.12,否则问题还是会存在。接下来就把openssl升级、sqlite3升级、源码编译安装python3的步骤、重新编译python3所需的清理命令一一列举供遇到同样问题的朋友参考。

升级openssl

与python3.12版本匹配的版本可以选择openssl1.1.1

  1. wget https://www.openssl.org/source/openssl-1.1.1u.tar.gz 下载openssl源码包到指定目录
  2. tar -zxvf openssl-1.1.1u.tar.gz解压下载的源码包
  3. cd openssl-1.1.1u进入解压目录
  4. ./config --prefix=/usr/local/openssl1.1.1配置指定安装的目录
  5. make && make install执行编译并安装
  6. mv /usr/bin/openssl /usr/bin/openssl_bak备份旧版本openssl可执行文件
  7. ln -sf /usr/local/openssl1.1.1/bin/openssl /usr/bin/openssl创建软链接指向最新的openssl版本
  8. openssl version检查版本应该为1.1.1.1版本

升级sqlite3

这里以sqlite3.45.3版本为例介绍sqlite3升级步骤

  1. wget https://www.sqlite.org/2024/sqlite-autoconf-3450300.tar.gz 下载sqlite3源码包
  2. tar zxvf sqlite-autoconf-3450300.tar.gz解压源码包
  3. cd sqlite-autoconf-3450300进入解压目录
  4. ./configure --prefix=/usr/local配置安装路径
  5. make && make install编译并安装
  6. mv /usr/bin/sqlite3 /usr/bin/sqlite3_old备份旧版本的sqlite3可执行文件
  7. ln -s /usr/local/bin/sqlite3 /usr/bin/sqlite3创建软链接指向最新的sqlite3
  8. echo "/usr/local/lib" > /etc/ld.so.conf.d/sqlite3.conf创建sqlite3.conf文件,指定动态链接库的搜索路径为sqlite3新版本位置
  9. ldconfig更新动态链接库的缓存
  10. sqlite3 -version查询版本信息应该为3.45.3

重新编译清理命令

如果你找到这篇文章,说明你遇到和我一样的错误,显然你应该已经执行过源码编译python3解释器环境了。为修复这些错误,你需要重新编译安装python3,重新编译前建议清理编译安装记录以免出现不可预知的问题。

假设python3源码包解压后存放在Python-3.12.0目录中,编译安装路径为/usr/local/python3.12,如果你的路径不同请做相应的调整,重新编译安装清理操作命令如下:

  1. rm -rf /usr/local/python3.12删除安装目录
  2. make clean
  3. rm -rf build
  4. rm -rf config.cache

源码编译python3.12

这里以python3.12.0版本为例介绍源码编译安装步骤

  1. wget https://www.python.org/ftp/python/3.12.0/Python-3.12.0.tgz 下载源码安装包
  2. tar -zxvf Python-3.12.0.tgz解压源码包
  3. cd Python-3.12.0进入解压路径
  4. ./configure --prefix=/usr/local/python3.12 --enable-shared --with-openssl=/usr/local/openssl1.1.1配置python3安装路径,指定openssl,--enable-shared表示启用共享动态链接库
  5. make && make install编译并安装
  6. ln -s /usr/local/python3.12/bin/python3 /usr/bin/python3创建软链接使得python3命令指向新版本
  7. ln -s /usr/local/python3.12/bin/pip3 /usr/bin/pip3创建软链接使得pip3命令指向新版本
  8. 如果在安装过程中遇到共享库加载问题,例如libpython3.12.so.1.0无法找到,可以尝试将相关的库文件复制到系统库目录中
    cp /usr/local/python3/lib/libpython3.12.so.1.0 /usr/lib64/
  9. 验证import _ssl是否正常,若正常说明问题已修复
[root@xxxx admin]# python3
Python 3.12.0 (main, Apr 16 2024, 22:29:05) [GCC 4.8.5 20150623 (Red Hat 4.8.5-44)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import _ssl
>>> 

相关推荐

【常识】如何优化Windows 7

优化Windows7可以让这个经典系统运行更流畅,特别是在老旧硬件上。以下是经过整理的实用优化方案,分为基础优化和进阶优化两部分:一、基础优化(适合所有用户)1.关闭不必要的视觉效果右键计算机...

系统优化!Windows 11/10 必做的十个优化配置

以下是为Windows10/11用户整理的10个必做优化配置,涵盖性能提升、隐私保护和系统精简等方面,操作安全且无需第三方工具:1.禁用不必要的开机启动项操作路径:`Ctrl+S...

最好用音频剪辑的软件,使用方法?

QVE音频剪辑是一款简单实用的软件,功能丰富,可编辑全格式音频。支持音频转换、合并、淡入淡出、变速、音量调节等,无时长限制,用户可自由剪辑。剪辑后文件音质无损,支持多格式转换,便于存储与跨设备播放,满...

Vue2 开发总踩坑?这 8 个实战技巧让代码秒变丝滑

前端开发的小伙伴们,在和Vue2打交道的日子里,是不是总被各种奇奇怪怪的问题搞得头大?数据不响应、组件传值混乱、页面加载慢……别慌!今天带来8个超实用的Vue2实战技巧,每一个都能直击痛...

Motion for Vue:为Vue量身定制的强大动画库

在前端开发中,动画效果是提升用户体验的重要手段。Vue生态系统中虽然有许多动画库,但真正能做到高性能、易用且功能丰富的并不多。今天,我们要介绍的是MotionforVue(motion-v),...

CSS view():JavaScript 滚动动画的终结

前言CSSview()方法可能会标志着JavaScript在制作滚动动画方面的衰落。如何用5行CSS代码取代50多行繁琐的JavaScript,彻底改变网页动画每次和UI/U...

「大数据」 hive入门

前言最近会介入数据中台项目,所以会推出一系列的跟大数据相关的组件博客与文档。Hive这个大数据组件自从Hadoop诞生之日起,便作为Hadoop生态体系(HDFS、MR/YARN、HIVE、HBASE...

青铜时代的终结:对奖牌架构的反思

作者|AdamBellemare译者|王强策划|Tina要点运维和分析用例无法可靠地访问相关、完整和可信赖的数据。需要一种新的数据处理方法。虽然多跳架构已经存在了几十年,并且可以对...

解析IBM SQL-on-Hadoop的优化思路

对于BigSQL的优化,您需要注意以下六个方面:1.平衡的物理设计在进行集群的物理设计需要考虑数据节点的配置要一致,避免某个数据节点性能短板而影响整体性能。而对于管理节点,它虽然不保存业务数据,但作...

交易型数据湖 - Apache Iceberg、Apache Hudi和Delta Lake的比较

图片由作者提供简介构建数据湖最重要的决定之一是选择数据的存储格式,因为它可以大大影响系统的性能、可用性和兼容性。通过仔细考虑数据存储的格式,我们可以增强数据湖的功能和性能。有几种不同的选择,每一种都有...

深入解析全新 AWS S3 Tables:重塑数据湖仓架构

在AWSre:Invent2024大会中,AWS发布了AmazonS3Tables:一项专为可扩展存储和管理结构化数据而设计的解决方案,基于ApacheIceberg开放表格...

Apache DataFusion查询引擎简介

简介DataFusion是一个查询引擎,其本身不具备存储数据的能力。正因为不依赖底层存储的格式,使其成为了一个灵活可扩展的查询引擎。它原生支持了查询CSV,Parquet,Avro,Json等存储格式...

大数据Hadoop之——Flink Table API 和 SQL(单机Kafka)

一、TableAPI和FlinkSQL是什么TableAPI和SQL集成在同一套API中。这套API的核心概念是Table,用作查询的输入和输出,这套API都是批处理和...

比较前 3 名Schema管理工具

关注留言点赞,带你了解最流行的软件开发知识与最新科技行业趋势。在本文中,读者将了解三种顶级schema管理工具,如AWSGlue、ConfluentSchemaRegistry和Memph...

大数据技术之Flume

第1章概述1.1Flume定义Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构,灵活简单。1.2Flume的优点1.可以和...