Archlinux回滚系统(回滚有风险,慎用)

2024-03-12 06:20

本文主要是介绍Archlinux回滚系统(回滚有风险,慎用),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

回滚前历程

前些天在Arch上配置docker,nvidia-docker使用一直报错,以为是显卡驱动的问题,于是就大意地升级了下系统(sudo pacman -Syu),然后很悲催地升级完后还是不要好用,原来的系统内核是5.5.11,升级之后变成了5.8.12。同样地,软件包也跟着一起更新了,nvidia驱动由之前的440.64变成了450.23,cuda由之前的10.2变成了11.1。

为何要回滚系统?

升级了内核,cuda版本变成了11.1,在运行pytorch程序时会报错,具体错误原因就不贴图了,但是在cuda10.2版本的电脑上运行没有错误,在cpu上运行也没有错误,估计是pytorch暂时不支持cuda11.1,于是去pytorch官网查看,也没有找到适用于cuda11.1版本的pytorch,于是这时我就想着要降低cuda版本。

降低软件包版本,有一个工具是downgrade,使用和安装过程参考这篇文章如何在 Arch Linux 中降级软件包,步骤为:

  • 添加一个源:编辑/etc/pacman.conf文件,或者pacman.d文件夹下面的源文件。
[archlinuxfr]
SigLevel = Never
Server = http://repo.archlinux.fr/$arch
  • 更新
sudo pacman -Sy
  • 安装
sudo pacman -S downgrade

上面3步完成了downgrade安装,就可以使用这个工具了,比如我要降级nvidia包,使用如下:

downgrade nvidia

输入上个命令后,会出现很多版本的nvidia驱动包,如果之前电脑上安装过该版本,会在后面显示(local),如果没有安装过,会显示(remote),因此选择一个之前安装过的版本即可。

如果你通过以上步骤降级nvidia驱动包的话,会发现有冲突,因此需要nvidia和nvidia-utils这两个包一起降级,只需要改个命令即可:

downgrade nvidia nvidia-utils

重点来了,降级之后会显示nvidia驱动和系统内核不一致,具体表现是输入nvidia-smi命令不能显示显卡运行状态,会报错。于是我就开始尝试降级系统内核版本。

降级内核版本具体参考这篇文章archlinux升级内核后,系统挂了,修复方法,具体思路为:

  • 查看安装包缓存
    一般使用pacman安装的软件包都会在/var/cache/pacman/pkg/目录下有缓存,因此只需要输入以下命令即可查看:
ls -l /var/cache/pacman/pkg/ | grep linux
  • 安装旧内核
    选择之前的旧内核,我是通过时间来判断的,安装本地软件包命令如下:
pacman -Udd xxx

安装过后还是不好用,可能得重启,但是我猜想即使安装旧内核成功,也会出现很多软件包与内核冲突的情况,于是这时候我就打算降级全部软件包,包括内核。

降级所有软件包

回滚系统,我是参考archwiki教程来实现的,wiki上介绍的很详细,链接地址为Arch Linux Archive。

主要参考的是这一段。
在这里插入图片描述
注意的是,下面已经说明,请谨慎使用该方法,这样降级所有软件包后会出现冲突的情况,不过我还是硬着头皮上了,安装后对我有较大影响的是anaconda环境中的软件包版本冲突了,需要重新安装了。

教程中说得很详细了,但是要注意的是,需要查看repo中对应日期中是否存在软件包,有可能对应日期下是空的。同时还要查看该日期的nvidia驱动是否是所需要的的版本,比如我要安装的是nvidia44.64版本,因此我选择了3.25日期的源。

安装后续

安装成功后,nvidia-smi还是不能使用,查看内核版本uname -a还是5.8.12,这时候需要将服务器重启一下就好了。

重启后nvidia-smi显示的nvidia驱动是44.64,cuda版本是10.2,查看内核版本是5.5.11,打开pytorch,测试gpu能够使用,降级完成。

不过还是不建议使用这种方法,可能后续会有很多问题出现,如果有更好的办法感谢提供。

这篇关于Archlinux回滚系统(回滚有风险,慎用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/800381

相关文章

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Linux系统之dns域名解析全过程

《Linux系统之dns域名解析全过程》:本文主要介绍Linux系统之dns域名解析全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、dns域名解析介绍1、DNS核心概念1.1 区域 zone1.2 记录 record二、DNS服务的配置1、正向解析的配置

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

Linux系统之authconfig命令的使用解读

《Linux系统之authconfig命令的使用解读》authconfig是一个用于配置Linux系统身份验证和账户管理设置的命令行工具,主要用于RedHat系列的Linux发行版,它提供了一系列选项... 目录linux authconfig命令的使用基本语法常用选项示例总结Linux authconfi

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创