H. Kamran
Posted on May 3, 2023
I recently worked on a Python project that used Python 3.11 and Poetry. When I went to deploy it on Amazon's Elastic Compute Cloud, better known by its moniker EC2, I ran into a major hurdle. EC2, running Amazon Linux 2, had Python 3.7.11. The project required 3.11, so I needed to compile Python from source.
Dependencies
I started by updating packages in YUM
, the package manager for Amazon Linux 2, with sudo yum update
. Then I installed some development dependencies, namely the aptly-named "Development Tools" group and a few others with the following command.
sudo yum groupinstall "Development Tools"
sudo yum install libffi-devel bzip2-devel
One more dependency is needed: OpenSSL. The openssl-devel
package included in the repositories with Amazon Linux 2 is 1.0.7, but Python 3 currently requires 1.1.1 or newer. This version is available through the openssl11-devel
package. To install it, uninstall openssl-devel
, then install openssl11-devel
.
sudo yum uninstall openssl-devel
sudo yum install openssl11-devel
Compilation
With the development dependencies installed, the next step was to download the Python source code. The Python Software Foundation maintains tarballs of every Python version released, and they're available through this user-friendly page or their plain directory listing. Either way, find the Python version your project needs, then copy the link to the file that ends in .tgz
, which is the gzipped tarball. With the link to the Python source in hand, download it with wget
, then extract the archive.
sudo wget https://www.python.org/ftp/python/3.11.1/Python-3.11.1.tgz
sudo tar xzf Python-3.11.1.tgz
cd Python-3.11.1
Next, run the configure
script, which will check to ensure that the necessary dependencies are installed: sudo ./configure --enable-optimizations
. The --enable-optimizations
flag optimizes the binary. After that finishes, there will be a Makefile
. Before proceeding, decide whether this new version should replace the system version, or if it should be installed alongside. I recommend the latter, and that's what I used. If you decided to replace the system version, use sudo make install
. If you decided to install it alongside, use sudo make altinstall
. On my t2.micro instance, it took about 35 minutes to build.
Shell Configuration
Python installs to /usr/local/bin
, but the PATH
doesn't contain it. To add this folder to the PATH
, open the ~/.bashrc
file in your favourite text editor and add the following to the end.
export PATH=/usr/local/bin:$PATH
Reload the .bashrc
file by running source ~/.bashrc
, then try opening a Python shell with python3.11
. Replace 3.11
with whatever Python version was installed.
Conclusion
If you have any questions or need any help, feel free to contact me on Twitter or Mastodon.
If you have any improvements to any of my articles or notes, please submit a pull request.
Thank you for reading!
Posted on May 3, 2023
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.