OctoPrint tells me my Python environment is outdated and will soon no longer be supported, how do I upgrade?

Starting with version 1.11.0, OctoPrint comes with built-in health checks that regularly will check the health of the underlying runtime environment.

One of these checks is against the Python version that OctoPrint is running under: If it's already end-of-life or soon to be end-of-life, you'll get a health check warning.

We've seen plenty of instances that are running on now end-of-life Python versions, and as end-of-life Python versions also usually no longer are supported by third party dependencies of OctoPrint, having to support these outdated versions increases maintenance overhead severely. This is no longer sustainable and thus from now on OctoPrint will regularly update its minimum Python requirements in order to stay more within the current Python ecosystem. This has the added advantage of being able to make use of performance improvements in Python itself, as well as new language features that speed up maintenance and development.

However, updating Python is not something that OctoPrint can do itself, as it would basically have to rip the floor out beneath its own feet. Thus, this is something that you as the user need to do. In this FAQ item we provide some options to do this below.

Python version requirements in OctoPrint

OctoPrint Version Status Supported Python Versions Matches Python available on what versions of OctoPi?
1.11.x released as of 2025-04-22, getting bugfix updates 3.7 - 3.13 0.18.x, 1.0.x, 1.1.x
1.12.x in active development, release planned for early 2026 3.9 - 3.14 (upper limit subject to change) 1.0.x, 1.1.x
1.13.x in planning, release probably late 2026 to early 2027 3.10 - 3.15 (upper limit subject to change) 1.1.x

Upgrade options

:raised_hand: A warning about compiling Python yourself if you are on a Pi!

Instead of reflashing or running a dist-upgrade, you might be tempted to upgrade your Python installation by compiling Python yourself. On anything but a Raspberry Pi, that is fine. On a Pi, it can work. But in that case you really should disable the piwheels package index. Otherwise chances are high you'll pull in binary packages compiled for a different system than your's from there, especially if you are still on an older OctoPi version (e.g. 1.0.0 or even older). To disable piwheels on your Pi, you'll need to comment out the extra-index-url in your /etc/pip.conf:

sudo sed -i 's!extra-index-url=!#extra-index-url=!' /etc/pip.conf

Note that this will mean your Raspberry Pi will have to compile any python dependency that isn't already provided as a native wheel on the official Python packaging index itself, meaning that updates and also plugin installs will in all likelihood take significantly longer.

We therefore do not recommend this approach unless you really know what you are doing.

1) The easiest way for OctoPi & Raspberry Pi OS in general: Backup, flash a new image, restore

If you are running OctoPi or stock Raspberry Pi OS, the easiest way is probably to use OctoPrint's built-in backup tool to create a backup of all your data, plugins and configuration. Download it to your computer. Then download the latest version of OctoPi (or the OS image of your choice), flash it to a fresh SD card (you really want to do this from time to time as SD cards wear out, so this is a good timing for that!), fire up OctoPrint and restore from your backup.

:bulb: Heads-up: OctoPrint might appear offline after successful restore due to a bug

Current stable versions of OctoPrint have a bug that causes it to look like the server stays offline after a successful restore - the "offline" overlay will stay no matter how long you wait or how often you click the "Reconnect" button.

When OctoPrint tells you it finished restoring and will now restart the server, wait until the "reload" overlay pops up, then give it ~30s and then manually reload the tab in your browser. This should succeed.

This bug will be fixed in OctoPrint 1.11.4.

2) The hard way for OctoPi & Raspberry Pis in general: Perform a dist-upgrade and migrate the virtual environment

Instead of reflashing, Raspberry Pi OS (and thus also OctoPi) can in theory be updated in place to a newer Raspberry Pi OS version and thus also available Python version. However, that takes a long time and several steps, and things can go spectacularly wrong. This upgrade path is also not endorsed by the Raspberry Pi Foundation.

IF you indeed want to rather tackled this approach instead of opting for the faster backup/reflash/restore way, we urge you to make a backup regardless.

Then follow one of the tutorials available online (we are not linking one here, but recommend to do a web search for "raspberry pi dist-upgrade").

Once the OS has been upgraded and you have confirmed that a new Python version is now available, follow the "generic way for manual installs" below from step 2 onward.

3) The generic way for manual installs not on a Pi: Install a new Python version and migrate the virtual environment

In general, the recommended approach to migrating OctoPrint to a newer Python version that doesn't involve a full OS reinstall is to first make sure a newer Python version is available on the system (e.g. by installing it from the OS package manager, or by downloading it from python.org), and then using OctoPrint's venv-tool to migrate the virtual environment to this new version.

The steps are:

  1. Install a new Python version

  2. Install OctoPrint's venv-tool:

    • Linux/POSIX:

      curl -LO https://get.octoprint.org/octoprint-venv-tool && chmod +x octoprint-venv-tool
      
    • Windows:

      curl -LO https://get.octoprint.org/octoprint-venv-tool
      
  3. Stop OctoPrint.

  4. Recreate the virtual environment. Assuming OctoPrint's virtual environment is located at /path/to/your/venv and your new Python version's binary is at /path/to/python.

    • Linux/POSIX:

      octoprint-venv-tool recreate-venv /path/to/your/venv --python /path/to/python
      
    • Windows

      python octoprint-venv-tool recreate-venv /path/to/your/venv --python /path/to/python
      

    If any of your currently installed plugins will cause an error while attempting to install them into the new virtual environment, recreation will be aborted and the initial backup of your original venv rolled back.

    If that happens you can ignore errors caused by plugins and reattempt the recreation by adding the --ignore-plugin-errors parameter to the command, e.g.

    • Linux/POSIX:

      octoprint-venv-tool recreate-venv /path/to/your/venv --python /path/to/python --ignore-plugin-errors
      
    • Windows:

      python octoprint-venv-tool recreate-venv /path/to/your/venv --python /path/to/python --ignore-plugin-errors
      

    OctoPrint's venv-tool will also do its best to reinstall all plugins that you had installed as python packages into your existing virtual environment. Your data is not in the virtual environment and won't be touched by the migration.

  5. Restart OctoPrint. It should now be running under the new Python version, which you can confirm by looking at the lower left corner of the web interface.

2 Likes

I'm currently running Octopi 1.0:

  • OctoPrint 1.10.3
  • Python 3.9.2
  • OctoPi* 1.0.0cam (build 2023.07.20.144556)

It currently has Python 3.9.2 installed. This version is already EOL. But when I go to OctoPrint.org - Download & Setup OctoPrint, I see that the current version is still 1.0.0.

Are there plans to update Octopi before Octoprint drops support for Python 3.9?

OctoPi is a separately maintained project, that currently has a 1.1.0rc version available that has an updated python contained within.

For the record, security support for 3.9 is still available, by current knowledge until Oct 31st 2025, and as mentioned, @guysoft is currently also in the process of RC testing the next OctoPi release that ships with Python 3.11.2.

And as far as it is in my power, I'll do my best to support even EOL python versions until easy alternatives are there.

octoprint-venv-tool recreate-venv /path/to/your/venv --python /path/to/python

Although I have no idea where the virtual environment was installed in the first place
Python3 on the other hand is located at /usr/bin/python3

Thanks for your work here, a timely reminder to do backups, replace the SD card, and generally refresh things. New card, imaged, run up, restored in about 20 minutes, give or take. Really painless for what is a bit of a major usually! Thanks!

OctoPi is telling me that I need to update Python (I'm running Python 3.7.3). I followed your advice to flash the latest version of OctoPi using the Raspberry Pi imager to an SD card but the version of Python still shows 3.7.3. Am I missing something?

It's possible the image is cached inside your pi imager and not downloading the updated 1.1.0 version.

  1. Close Pi imager if open.
  2. Open File Explorer and navigate to C:\Users\<username>\AppData\Local\Raspberry Pi\Imager\cache.
  3. Delete the lastdownload.cache file:

Thanks for the suggestion. I'm on a Mac so the file path didn't work for me. I did try looking through the Application Support folders and Library folders and found a prefs file for Raspberry Pi Imager but trashing that didn't fix the problem. I'll post a solution if I find one.

"octoprint-venv-tool recreate-venv /path/to/your/venv --python /path/to/python"
??
I have installed python 3.13, so I guess the path to python is "/usr/bin/python3"
But I have no idea, where the path for the octoprint environment is! Can anybody tell me where it is?
Thanks!

1 Like

This depends on how you installed OctoPrint. Standard OctoPi image this path is ~/oprint/.

octoprint-venv-tool recreate-venv /home/pi/octoprint --python /usr/bin/python3.13
doesn't work, neither with nor without sudo.
Error: "no authorisation" or "command not found"
2025-06-04 migration errors

At no point did the instructions say to use sudo, and that will actually break things. Also noticed you didn't use the correct path in the command. Try this command.

./octoprint-venv-tool recreate-venv /home/pi/oprint --python /usr/bin/python3.13
1 Like

Thanks for this correction. :smiley:
This update is driving me crazy. :exploding_head:

Sudo or no sudo - I've tried both because nothing works. It happens often enough that sudo is omitted in descriptions even though it is required.
Python 3.13 is installed, but /usr/bin/python3.13 does not exist.
This means that the command does not work as specified:
./octoprint-venv-tool recreate-venv /home/pi/oprint --python /usr/bin/python3.13
--->Error running recreate-venv: [Errno 2] No such file or directory: '/usr/bin/python3.13'
2025-06-06 migration errors2

if you type python --version and python3 --version what is listed? if either of those return 3.13, then you can type which python or which python3 to get the path to that specific binary.

I was about to say: You made my day (and many others).

The binary for python 3.13 is /usr/local/bin/python3.13- for whatever reason.

Now I could start the migration - but unfortunately it cancelled again with an error:

> Error running recreate-venv: Command '('/home/pi/oprint/bin/python', '-m', 'pip', 'install', 'https://github.com/cmuche/octoprint-timelapseplus/archive/master.zip')' returned non-zero exit status 1.

Looks like it hung up on timelapse plus plugin, but OctoPrint was installed.

After what felt like 100 attempts, I managed to perform the migration twice in total.

Previously I had to remove almost all 3rd party plugins.

Octoprint is running - but: I can no longer log in to Octoprint with the Octoprint user/password, the password is now invalid!

What now?
20250610 WrongUsernameOrPasswordAfterMigration