Apache 経由の Postgres 認証に関する問題

Apache 経由の Postgres 認証に関する問題

私はRHEL 5.4を使っていて、ジャンゴデータベースとして PostgreSQL を使用するプロジェクトです (以前は MySQL を使用したことがありますが、新しいものを試してみたいと思っています :) )。Django テスト サーバーを実行すると、すべてが機能し、パスワード認証を使用してコマンド ライン経由で接続することもできます。

psql -U myuser -h 127.0.0.1

しかし、Apache 経由でプロジェクトにアクセスしようとすると、500 エラー コードが表示され、Apache のエラー ログに次の Python トレースバックが表示されます。

mod_wsgi (pid=7026): Exception occurred processing WSGI script '/var/www/myproject/myproject/hook.wsgi'.
Traceback (most recent call last):
  File "/var/www/myproject/myproject/src/django/django/core/handlers/wsgi.py", line 245, in __call__
    response = middleware_method(request, response)
  File "/var/www/myproject/myproject/src/django/django/contrib/sessions/middleware.py", line 36, in process_response
    request.session.save()
  File "/var/www/myproject/myproject/src/django/django/contrib/sessions/backends/db.py", line 55, in save
    obj = Session(
  File "/var/www/myproject/myproject/src/django/django/contrib/sessions/backends/base.py", line 152, in _get_session_key
    self._session_key = self._get_new_session_key()
  File "/var/www/myproject/myproject/src/django/django/contrib/sessions/backends/base.py", line 144, in _get_new_session_key
    if not self.exists(session_key):
  File "/var/www/myproject/myproject/src/django/django/contrib/sessions/backends/db.py", line 29, in exists
    Session.objects.get(session_key=session_key)
  File "/var/www/myproject/myproject/src/django/django/db/models/manager.py", line 132, in get
    return self.get_query_set().get(*args, **kwargs)
  File "/var/www/myproject/myproject/src/django/django/db/models/query.py", line 336, in get
    num = len(clone)
  File "/var/www/myproject/myproject/src/django/django/db/models/query.py", line 81, in __len__
    self._result_cache = list(self.iterator())
  File "/var/www/myproject/myproject/src/django/django/db/models/query.py", line 269, in iterator
    for row in compiler.results_iter():
  File "/var/www/myproject/myproject/src/django/django/db/models/sql/compiler.py", line 672, in results_iter
    for rows in self.execute_sql(MULTI):
  File "/var/www/myproject/myproject/src/django/django/db/models/sql/compiler.py", line 726, in execute_sql
    cursor = self.connection.cursor()
  File "/var/www/myproject/myproject/src/django/django/db/backends/__init__.py", line 75, in cursor
    cursor = self._cursor()
  File "/var/www/myproject/myproject/src/django/django/db/backends/postgresql_psycopg2/base.py", line 136, in _cursor
    self.connection = Database.connect(**conn_params)
OperationalError: could not connect to server: Permission denied
\tIs the server running on host "127.0.0.1" and accepting
\tTCP/IP connections on port 5432?

辞書をチェックしたところconn_params、正しいユーザー名とパスワードが含まれています。私のpg_hba.conf場合は次のようになります (Ubuntu 9.04 サーバーでまったく同じ構成を使用しており、すべて問題なく動作します)。

local   all         postgres                          ident
local   all         all                               md5
host    all         all         127.0.0.1/32          md5
host    all         all         ::1/128               md5

何が間違っているのでしょうか?

答え1

よくある間違いの一つは、パスワードをプレーンテキストで指定することです。pg_hba.conf設定では、md5 として提供される必要があります。
設定ファイルのパスワードを md5 で更新して、もう一度試してください。これには、次のような任意の MD5 ジェネレータを使用できます。これです

関連情報