質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

1289閲覧

Pythonで作成したプログラムをCentOS8にあげてPostgreSQLに接続したい

takahiro00

総合スコア84

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/04/08 14:43

編集2020/04/09 12:21

前提・実現したいこと

PythonでPostgreSQLに接続するプログラムを作成したので、
CentoOS8で動かしたいのですが、
CentOS8上で動かすとエラーになってしまい動かすことができません。。。
ローカル環境では正常に動いていたのですが、
CentOS8にPythonのソースをのせて、
CentOS8にpostgreSQL(10.6)をインストールして
ユーザの作成、DBの作成等して、その情報をPythonのソース内に記載したのですが動きません。。。
ユーザ(postgrs)にもパスワードを設定しています。

追記
ちなみに以下のやり方でも接続ができません。以下のエラーが出てしまいます。。。。
psql -h ホスト名 -p ポート番号 -U ロール名 -d データベース名

psql: could not connect to server: Connection refused Is the server running on host "xxx.xxx.xx.xxx" and accepting TCP/IP connections on port 5432?

ご教授お願いいたします。

発生している問題・エラーメッセージ

[xxx@xxx py]$ python3.6 test.py Traceback (most recent call last): File "test.py", line 21, in <module> conn = psycopg2.connect(" user=" + users + " dbname=" + dbnames + " password=" + passwords) File "/usr/local/lib64/python3.6/site-packages/psycopg2/__init__.py", line 127, in connect conn = _connect(dsn, connection_factory=connection_factory, **kwasync) psycopg2.OperationalError: FATAL: Peer authentication failed for user "postgres"

該当のソースコード

python

1import random 2 3import psycopg2 4import tempfile 5from selenium import webdriver 6 7from selenium.webdriver.chrome.options import Options 8from requests.exceptions import Timeout 9 10# postgreSQLに接続 11users = 'postgres' 12dbnames = 'testdb' 13passwords = 'xxxx' 14conn = psycopg2.connect(" user=" + users + " dbname=" + dbnames + " password=" + passwords)

以下、サーバー上のDB情報です。

postgres=# \l List of databases Name | Owner | Encoding | Collate | Ctype | Access privileges -----------+----------+----------+-------------+-------------+----------------------- testdb | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 |

/var/lib/pgsql/data/postgresql.conf
↑でlisten_addressesを'*'にして port = 5432 にしてます(関係あるか分かりませんが)

#------------------------------------------------------------------------------ # CONNECTIONS AND AUTHENTICATION #------------------------------------------------------------------------------ # - Connection Settings - listen_addresses = '*' # what IP address(es) to listen on; # comma-separated list of addresses; # defaults to 'localhost'; use '*' for all # (change requires restart) port = 5432 # (change requires restart) max_connections = 100 # (change requires restart) #superuser_reserved_connections = 3 # (change requires restart) #unix_socket_directories = '/var/run/postgresql, /tmp' # comma-separated list of directories # (change requires restart)

補足情報(FW/ツールのバージョンなど)

CentoOS8
python3.6
postgreSQL(10.6)

追加
ちなみにpgadmin3にも接続できません。

Server doesn't listen The server doesn't accept connections: the connection library reports could not connect to server: Connection refused Is the server running on host "xxx.xxx.xx.xxx" and accepting TCP/IP connections on port 5432?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

takahiro00

2020/04/09 12:09

別ユーザ作成しましたが、ダメでした
guest

回答2

0

自己解決

postgreSQLが二つインストールされてるのが原因のようでした。
一度全部アンインストールして入れ直したらうまくいきました。
ご回答いただいた皆さん
ありがとうございました。

投稿2020/04/09 13:19

takahiro00

総合スコア84

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

CentOSのファィアウォールが遮断しているか、pg_hba.confで接続の許可をしていないか、どちらかではないでしょうか?

投稿2020/04/09 12:53

hasami

総合スコア1277

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問