-
-
Notifications
You must be signed in to change notification settings - Fork 508
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
sqlalchemy.exc.OperationalError: (psycopg2.OperationalError) SCRAM authentication requires libpq version 10 or above #1360
Comments
These two together are not needed. If you install psycopg2-binary it will ignore the system libpq.
According to the news file, psycopg 2.8 binary was packaged with Postgres 11.2 libpq. Line 179 in 3430dcd
So I think you might have a stray psycopg2 version. I am sorry that the psycopg2 and psycopg2-binary version don't play well together. To look into it better try to get more info about the package installed in your container: >>> import psycopg2
# Checking where it is installed
>>> print(psycopg2)
<module 'psycopg2' from '/home/piro/dev/psycopg2/.venv/lib/python3.8/site-packages/psycopg2/__init__.py'>
# Checking the versions:
>>> print(psycopg2.__version__)
2.9.1 (dt dec pq3 ext lo64)
>>> print(psycopg2.__libpq_version__)
130003
>>> print(psycopg2.extensions.libpq_version())
130003 If the problem is a conflicting package try to add a |
I also saw this error running a container on an M1 laptop. Seems to be related to this SO question. I can run the ARM and x86 images on the machine via Docker Desktop, and this shows that the libpq versions differ # x86
$ docker run --platform linux/amd64 -it python:3.8-slim bash -c 'pip install psycopg2-binary && find / -name "libpq*"'
…
Successfully installed psycopg2-binary-2.9.1
…
/usr/local/lib/python3.8/site-packages/psycopg2_binary.libs/libpq-6f24e430.so.5.13
# ARM
$ docker run --platform linux/arm64 -it python:3.8-slim bash -c 'pip install psycopg2-binary && find / -name "libpq*"'
…
Successfully installed psycopg2-binary-2.9.1
…
/usr/local/lib/python3.8/site-packages/psycopg2_binary.libs/libpq-c98caf99.so.5.9 ARM gets 5.9 whilst x86 gets the newer 5.13. My guess is the usage of 5.9 is causing the problem reported in this issue. Could this be a packaging problem? If the aarch64 wheel is being built with an old 5.9 library by mistake? Edit: You can see the library version difference in the latest package build workflow:
|
Debugging further, I tried running the steps in the build script on the ARM container directly.
This doesn't look good:
You can see that libpq 9.6.23 gets installed. From what I can tell the PostgreSQL arm64 builds don't support Stretch (Debian 9), which the manylinux containers are based off. Will keep digging. |
These are these differences between the two build scripts ( diff --git a/scripts/build/build_manylinux2014.sh b/scripts/build/build_manylinux_2_24.sh
index 0e87bd54..d83c8414 100755
--- a/scripts/build/build_manylinux2014.sh
+++ b/scripts/build/build_manylinux_2_24.sh
@@ -1,10 +1,6 @@
#!/bin/bash
-# Create manylinux2014 wheels for psycopg2
-#
-# manylinux2014 is built on CentOS 7, which packages an old version of the
-# libssl, (1.0, which has concurrency problems with the Python libssl). So we
-# need to build these libraries from source.
+# Create manylinux_2_24 wheels for psycopg2
#
# Look at the .github/workflows/packages.yml file for hints about how to use it.
@@ -30,8 +26,12 @@ if [[ "${PACKAGE_NAME:-}" ]]; then
"${prjdir}/setup.py"
fi
-# Build depending libraries
-"${dir}/build_libpq.sh" > /dev/null
+# Install prerequisite libraries
+curl -s https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add -
+echo "deb http://apt.postgresql.org/pub/repos/apt stretch-pgdg main" \
+ > /etc/apt/sources.list.d/pgdg.list
+apt-get -y update
+apt-get install -y libpq-dev
# Create the wheel packages
for pyver in $PYVERS; do
@@ -45,7 +45,7 @@ for whl in "${prjdir}"/dist/*.whl; do
done
# Make sure the libpq is not in the system
-for f in $(find /usr/local/lib -name libpq\*) ; do
+for f in $(find /usr/lib /usr/lib64 -name libpq\*) ; do
mkdir -pv "/libpqbak/$(dirname $f)"
mv -v "$f" "/libpqbak/$(dirname $f)"
done To avoid using the PostgreSQL APT repository I tried modifying diff --git a/scripts/build/build_libpq.sh b/scripts/build/build_libpq.sh
index 32d2222d..c6483582 100755
--- a/scripts/build/build_libpq.sh
+++ b/scripts/build/build_libpq.sh
@@ -10,7 +10,8 @@ ldap_version="2.4.59"
sasl_version="2.1.27"
postgres_version="13.3"
-yum install -y zlib-devel krb5-devel pam-devel
+apt-get update -y
+apt-get install -y zlib1g-dev libkrb5-dev libpam-dev
# Build openssl if needed (It feels a little sketchy to me to download the Red Hat PG distribution on Debian, but maybe it's OK?) To test the full packaging flow, spin up a DB: $ docker run --rm -e POSTGRES_PASSWORD=password postgres Then run the container: $ docker run --rm -v $(pwd):/src \
-e PLAT=manylinux_2_24_aarch64 \
-e PACKAGE_NAME=psycopg2-binary \
-e PYVERS="cp38-cp38" \
-e PSYCOPG2_TESTDB=postgres \
-e PSYCOPG2_TESTDB_HOST=172.17.0.3 \
-e PSYCOPG2_TESTDB_USER=postgres \
-e PSYCOPG2_TESTDB_PASSWORD=password \
-e PSYCOPG2_TEST_FAST=1 \
--workdir /src \
quay.io/pypa/manylinux_2_24_aarch64 \
./scripts/build/build_manylinux_2_24.sh
…
+ /opt/python/cp38-cp38/bin/python -c 'import psycopg2; print(psycopg2.__version__)'
2.9.1 (dt dec pq3 ext lo64)
+ /opt/python/cp38-cp38/bin/python -c 'import psycopg2; print(psycopg2.__libpq_version__)'
90623
+ /opt/python/cp38-cp38/bin/python -c 'import psycopg2; print(psycopg2.extensions.libpq_version())'
130003 (Use One of the versions is now correct but the other is still outdated. |
I hit with the above error when I was using FYI, I didn't install |
I am also seeing this problem when installing psycopg2-binary on the official docker python:3.8 image (debian bullseye), for aarch64. This gets installed: Also tested with the pthon:3.9 image, same issue: from |
@smolyn what are the |
|
@smolyn on aarch64 the PostgreSQL packages don't seem upgraded https://github.com/psycopg/psycopg2/runs/4184035217?check_suite_focus=true#step:5:147 So you get version 9.6 there. Is there a way to get upgraded packages in this script? |
@dvarrazzo I tried updating that script but only managed to get one of the versions updated. Quoting:
I wasn't able to understand why |
The |
use psycopg3 to resolve this problem |
I'm experiencing this issue as well. Is there a temporary workaround anyone has found short of emulating amd64? |
Workarounds are discussed here: |
This is how you can really fix it: Debian StretchHere you have the problem that the Postgres Debian repo doesn't have ARM builds for libpq so you first have to build your own from source. Once you have that, you can just copy the two packages from the first Docker build to your machine and you'll never have to do the libpq build again. FROM debian:stretch AS libpqbuilder
RUN apt-get update && apt-get -y install curl ca-certificates gnupg dpkg-dev devscripts
RUN curl https://www.postgresql.org/media/keys/ACCC4CF8.asc | gpg --dearmor | tee /etc/apt/trusted.gpg.d/apt.postgresql.org.gpg >/dev/null
RUN echo "deb-src http://apt.postgresql.org/pub/repos/apt/ stretch-pgdg main" >> /etc/apt/sources.list.d/pgdg.list
# get source packages
RUN cd ~ && apt-get update && apt-get source pgdg-keyring postgresql-common postgresql-14
# disable running the postgres test suite after building
ENV DEB_BUILD_OPTIONS=nocheck
# build deps for building postgres
RUN cd ~/pgdg-* && mk-build-deps -ir -t "apt-get -o Debug::pkgProblemResolver=yes -y --no-install-recommends"
RUN cd ~/pgdg-* && debuild -i -us -uc -b
RUN cd ~/postgresql-common-* && mk-build-deps -ir -t "apt-get -o Debug::pkgProblemResolver=yes -y --no-install-recommends"
RUN cd ~/postgresql-common-* && debuild -i -us -uc -b
# install deps
RUN apt install -y ~/pgdg-keyring_*.deb
RUN apt install -y ~/postgresql-client-common_*.deb
RUN apt install -y ~/postgresql-common_*.deb
# build postgres
RUN cd ~/postgresql-14-14.* && mk-build-deps -ir -t "apt-get -o Debug::pkgProblemResolver=yes -y --no-install-recommends"
RUN cd ~/postgresql-14-14.* && debuild -i -us -uc -b
RUN mkdir /out && mv ~/libpq-dev_*.deb /out/ && mv ~/libpq5_*.deb /out/
RUN ls -alh /out
# use it
FROM python:3.7-stretch
COPY --from=libpqbuilder /out/libpq-dev_14.3-1.pgdg90+1_arm64.deb /var/cache/apt/archives/
COPY --from=libpqbuilder /out/libpq5_14.3-1.pgdg90+1_arm64.deb /var/cache/apt/archives/
# install libpq
RUN dpkg -i /var/cache/apt/archives/libpq-dev_14.3-1.pgdg90+1_arm64.deb /var/cache/apt/archives/libpq5_14.3-1.pgdg90+1_arm64.deb
# build a psycopg2 wheel
RUN pip install psycopg2==2.9.3 Debian BullseyeBullseye has libpq 13 so you can build directly against that. FROM python:3.8.13-bullseye
RUN pip install psycopg2==2.9.3 |
Changing my requirements.txt from psycopg2-binary to psycopg2 resolved this issue for me on M1 Mac. |
@piyh great job! |
I know that it's not a root of the problem, but I've changed the Postgres version from 14 to 11 and it's worked for me. With psycopg2-binary installed |
That worked like a charm, thanks @hyzyla |
@hyzyla @Doctorkvothe You can rollback to 13.3, you don't have to go all the way back to 11.
You'll probably need to delete and recreate your db container, and volumes if you are using them.
|
@steezeburger Awesome, much appreciated! |
see psycopg/psycopg2#1360 (comment) for more information. The idea is being able to run shadowmere in ARM
Since the psycopg2 fix went in, maybe we don't need it. psycopg/psycopg2#1360 (comment)
Since the psycopg2 fix went in, maybe we don't need it. psycopg/psycopg2#1360 (comment)
Since the psycopg2 fix went in, maybe we don't need it. psycopg/psycopg2#1360 (comment)
We've ran into the SCRAM authentication error thing on our Macbook M1/2, so use the simplest workaround that seems to work: psycopg/psycopg2#1360 (comment)
We've ran into the SCRAM authentication error thing on our Macbook M1/2, so use the simplest workaround that seems to work: psycopg/psycopg2#1360 (comment)
We've ran into the SCRAM authentication error thing on our Macbook M1/2, so use the simplest workaround that seems to work: psycopg/psycopg2#1360 (comment)
psycopg/psycopg2#1360 is resolved. Installation from source no longer needed.
psycopg/psycopg2#1360 is resolved. Installation from source no longer needed.
psycopg/psycopg2#1360 is resolved. Installation from source no longer needed.
Thanks! U help me. I love u |
@brumsilva This problem is resolved long time ago, as @dvarrazzo #1360 (comment) stated on his comment. No need for workarounds. |
The previously used "psycopg2-binary" has been used as a workaround initially, because it was difficult to build psycopg2. Now the usage with very recent PostgreSQL databases unveiled issues of the binary package at least on aarch64 architectures. Issue: #640 See-Also: psycopg/psycopg2#1360
@dvarrazzo I am using 2.9.6/2.9.9 of psycopgy2 and Python 3.8.18 still getting same error.
when I run this command in Python3.9 I get 150003 wondering if Python should be upgraded. My environment is for Airflow |
Hi, I'm using airflow version 2.8.2 and Python 3.8.10
and there was a mistake
Installed
when building your container with airflow
The problem has not been solved |
@Crogs366 I can try to replicate and check if you can share a snippet to replicate 🌸 |
I'm also encountering the same authentication error when attempting to connect to my Supabase database using the Supabase Vecs library on macOS M2. However, the connection works successfully when using psycopg2.connect. |
Is this issue has closed? |
@bajpaiabhas The issue is closed, as you can see from its status, and yes, it's resolved. Just try to use the latest version of the related tools. |
The previously used "psycopg2-binary" has been used as a workaround initially, because it was difficult to build psycopg2. Now the usage with very recent PostgreSQL databases unveiled issues of the binary package at least on aarch64 architectures. Issue: #640 See-Also: psycopg/psycopg2#1360
1: what you did
I have an application with multiple containers, one of which, container-A makes sql requests to another postgres container.
My container-A Dockerfile has (among other things):
RUN pip install libpq5
RUN pip install psycopg2-binary
2: what you expected to happen
Not see the error. It used to work before.
3: what happened instead
Getting the error:
sqlalchemy.exc.OperationalError: (psycopg2.OperationalError) SCRAM authentication requires libpq version 10 or above
The text was updated successfully, but these errors were encountered: