53 lines
3.6 KiB
Markdown
53 lines
3.6 KiB
Markdown
---
|
|
title: Revert Arch linux packages to specific date
|
|
date: 2017-09-11
|
|
image: https://www.lumalab.net/download/archlogo/arch-logo-shiny-dark.png
|
|
subtitle: Arch is well known for going wrong, but today was the first time this affected me doing my job
|
|
tags: [arch, linux]
|
|
---
|
|
|
|
I'm one of those Arch users who _apparently_ doesn't use arch properly: I install updates daily, including packages from the AUR. This has the great benefit of giving me the most up-to-date packages available from upstream. However, the downside of meaning I have the latest packages from upstream, meaning if something breaks, even temporarily, it breaks for me.
|
|
|
|
I'm also one of those _crazy_ people who uses arch on my work machine. Craziness aside, it's never caused me an issue, until today.
|
|
|
|
After running updates this morning, as I normally would, I went to start the project I was working on today locally, and was met with this wonderful message:
|
|
|
|
```text
|
|
django.core.exceptions.ImproperlyConfigured: Error loading psycopg2 module: /home/jake/Projects/******/env/lib/python3.5/site-packages/psycopg2/.libs/libresolv-2-c4c53def.5.so: symbol __res_maybe_init, version GLIBC_PRIVATE not defined in file libc.so.6 with link time reference
|
|
```
|
|
|
|
As this was a work machine, I didn't have the time to research into the correct solution. I knew this was something to do with updates, because that's all that had changed between the last time it worked and now. But I had a feeling rolling back updates to a given date, especially on arch, would be fairly painful. Much to my surprise, it was super simple!
|
|
|
|
After frantically googling, so my boss didn't notice my downtime, I found [this](https://www.ostechnix.com/downgrade-packages-specific-date-arch-linux/) article, which solved my needs completely. A simple config edit, and one command, and I was back to working.
|
|
|
|
## Doing the rollback
|
|
The way this solution works is by rather than using the current state of the package repos, we use an archive from a specific date.
|
|
|
|
### 1. Change mirror to archive
|
|
Edit the mirrorlist to point to the archive at a specific date. Change the contents of `/etc/pacman.d/mirrorlist` to:
|
|
|
|
```text
|
|
Server=https://archive.archlinux.org/repos/2017/09/08/$repo/os/$arch
|
|
```
|
|
|
|
Remember to take a backup beforehand just in case! Here's I've set the date to last Friday (8th September 2017), but just replace the date in the URL with the date you need (`YYYY/MM/DD`).
|
|
|
|
|
|
### 2. Force install updates
|
|
Force update package repos, and install packages. If there are newer packages installed than are available in the repos, they'll be downgraded.
|
|
|
|
```bash
|
|
sudo pacman -Syyuu
|
|
```
|
|
|
|
### 3. Reboot?
|
|
Depending on what packages have been downgraded, you may have to reboot to apply these changes. For the change I needed, a reboot wasn't needed. I just relaunched the terminal, and got on as normal.
|
|
|
|
## Reverting
|
|
To revert, just restore the backup of the pacman mirrorlist, and re-run the above pacman command.
|
|
|
|
## Outdated Packages
|
|
Generally, having out of date packages on your system is a bad idea. Not only for security reasons, but stability and compatibility. [The article](https://www.ostechnix.com/downgrade-packages-specific-date-arch-linux/) goes through a couple more too.
|
|
|
|
## Actually solving my issue
|
|
A few days later, After [posting this article on twitter](https://twitter.com/RealOrangeOne/status/907591524644466688), I had a discussion with [@MortenLinderud](https://twitter.com/MortenLinderud) about the issue, who [pointed out](https://twitter.com/MortenLinderud/status/908262748718596096) that the library had already been fixed. So after updating `psycopg2`, my issue went away!
|