
私は Windows マシンで動作するボットを持っており、最近 Ubuntu 仮想サーバーを購入しました。無限にエラーが続いたため、サーバーを完全にリセットして最初からやり直しました。以前のエラーのいくつかについては、こちらで別の投稿をご覧ください。https://stackoverflow.com/questions/63310926/no-pg-hba-conf-entry-for-host-connect-call-failed-invalid-data-directory-for?noredirect=1#comment111984138_63310926
そのため、ボットを起動しようとすると、次のエラーが発生します。
Traceback (most recent call last):
File "bot.py", line 950, in <module>
bot.loop.run_until_complete(create_db_pool())
File "/usr/lib/python3.8/asyncio/base_events.py", line 616, in run_until_complete
return future.result()
File "bot.py", line 160, in create_db_pool
bot.pg_con = await asyncpg.create_pool(database='xxx', user='postgres', password='???')
File "/usr/local/lib/python3.8/dist-packages/asyncpg/pool.py", line 398, in _async__init__
await self._initialize()
File "/usr/local/lib/python3.8/dist-packages/asyncpg/pool.py", line 426, in _initialize
await first_ch.connect()
File "/usr/local/lib/python3.8/dist-packages/asyncpg/pool.py", line 125, in connect
self._con = await self._pool._get_new_connection()
File "/usr/local/lib/python3.8/dist-packages/asyncpg/pool.py", line 468, in _get_new_connection
con = await connection.connect(
File "/usr/local/lib/python3.8/dist-packages/asyncpg/connection.py", line 1718, in connect
return await connect_utils._connect(
File "/usr/local/lib/python3.8/dist-packages/asyncpg/connect_utils.py", line 663, in _connect
con = await _connect_addr(
File "/usr/local/lib/python3.8/dist-packages/asyncpg/connect_utils.py", line 642, in _connect_addr
await asyncio.wait_for(connected, timeout=timeout)
File "/usr/lib/python3.8/asyncio/tasks.py", line 483, in wait_for
return fut.result()
asyncpg.exceptions.InvalidAuthorizationSpecificationError: Peer authentication failed for user "postgres"
データベース、ユーザー、パスワードはすべて正しいです。ボットがWindowsマシンで実行されているので、今のところは機能しています。そのため、これはUbuntu固有の問題だと思います。私のリッスンアドレスは次のように設定されています。
listen_addresses = '*'
そして、pg_hba.conf は次のように設定されています:
# TYPE DATABASE USER ADDRESS METHOD
# IPv4 local connections:
host all all 0.0.0.0/0 md5
# IPv6 local connections:
host all all ::/0 md5
# Allow replication connections from localhost, by a user with the
# replication privilege.
host replication all 0.0.0.0/0 md5
host replication all ::/0 md5
以前はデフォルトの IP がありましたが、パスワードを使用して接続できるようにしようとしましたが、Ubuntu サーバーはまだ接続できません。また、現時点では、このファイルが Ubuntu システムに自然に存在しないようです。Windows マシンから編集することはできますが、それが両方に影響するかどうかはわかりません。データベースを完全に理解しているわけではありませんが、自分の PC でホストされているのは確かですか? ファイル自体を手動で Ubuntu サーバーに持ち込むこともできますが、もう一度何かを台無しにしてさらに行き詰まるのは避けたいです。host
に変更するとlocal
、Windows マシンでデータベースが機能しなくなるだけのようです。
この問題で長い間行き詰まっていて、どうしたらいいのか全くわかりません。誰かがこの問題を知っていることを心から願っています。また、私が十分な情報を提供できたことを願っています。ありがとうございます。