psql: не удалось подключиться к серверу: в соединении отказано Сервер работает на хосте localhost (::1) и принимает соединения TCP/IP через порт 5432?

Мне жаль, что я бегал по сообщениям SO уже больше дня и просто чувствую, что никуда не иду. Недавно я обновил свое программное обеспечение до Mavericks, и мое приложение rails больше не работает. В частности, моя база данных psql не работает. Когда я набираю psql в своей консоли, он возвращает «не удалось подключиться к серверу: соединение отклонено ...», и когда я запускаю сервер rails, я получаю «Плохое соединение с PG» с тем же текстом.

Вот мой файл pg_hba.conf:

# TYPE  DATABASE        USER            ADDRESS                 METHOD

# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            trust
# IPv6 local connections:
host    all             all             ::1/128                 trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local   replication     Brian_Liou                                trust
#host    replication     Brian_Liou        127.0.0.1/32            trust
#host    replication     Brian_Liou        ::1/128                 trust

Вот мой postgresql.conf

# FILE LOCATIONS
#------------------------------------------------------------------------------

# The default values of these variables are driven from the -D command-line
# option or PGDATA environment variable, represented here as ConfigDir.

#data_directory = 'ConfigDir'       # use data in another directory
                # (change requires restart)
#hba_file = 'ConfigDir/pg_hba.conf' # host-based authentication file
                # (change requires restart)
#ident_file = 'ConfigDir/pg_ident.conf' # ident configuration file
                # (change requires restart)

# If external_pid_file is not explicitly set, no extra PID file is written.
#external_pid_file = ''         # write an extra PID file
                # (change requires restart)


#------------------------------------------------------------------------------
# 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)
# Note:  Increasing max_connections costs ~400 bytes of shared memory per
# connection slot, plus lock space (see max_locks_per_transaction).
#superuser_reserved_connections = 3 # (change requires restart)
#unix_socket_directories = '/tmp'   # comma-separated list of directories
                # (change requires restart)
#unix_socket_group = ''         # (change requires restart)
#unix_socket_permissions = 0777     # begin with 0 to use octal notation
                # (change requires restart)
#bonjour = off              # advertise server via Bonjour
                # (change requires restart)
#bonjour_name = ''          # defaults to the computer name
                # (change requires restart)

# - Security and Authentication -

#authentication_timeout = 1min      # 1s-600s
#ssl = off              # (change requires restart)
#ssl_ciphers = 'DEFAULT:!LOW:!EXP:!MD5:@STRENGTH'   # allowed SSL ciphers
                # (change requires restart)
#ssl_renegotiation_limit = 512MB    # amount of data between renegotiations
#ssl_cert_file = 'server.crt'       # (change requires restart)
#ssl_key_file = 'server.key'        # (change requires restart)
#ssl_ca_file = ''           # (change requires restart)
#ssl_crl_file = ''          # (change requires restart)
#password_encryption = on
#db_user_namespace = off

# Kerberos and GSSAPI
#krb_server_keyfile = ''
#krb_srvname = 'postgres'       # (Kerberos only)
#krb_caseins_users = off

# - TCP Keepalives -
# see "man 7 tcp" for details

#tcp_keepalives_idle = 0        # TCP_KEEPIDLE, in seconds;
                # 0 selects the system default
#tcp_keepalives_interval = 0        # TCP_KEEPINTVL, in seconds;
                # 0 selects the system default
#tcp_keepalives_count = 0       # TCP_KEEPCNT;
                # 0 selects the system default

Я попытался удалить эту папку: /usr/local/var/postgres, а затем переустановить postgresql с помощью brew.

Мой профиль Bash включает

export PGDATA=/usr/local/var/postgres
export PGHOST=localhost

Я знаю, что проблема связана с Postgres, который Mac устанавливает автоматически, и с тем, который устанавливает brew, кроме того, что я полностью потерян. К вашему сведению, я тоже новичок в рельсах/программисте. Пожалуйста, дайте мне знать о любой дополнительной информации, которую я могу предоставить, чтобы решить эту проблему!


person Blou91    schedule 31.03.2014    source источник
comment
Действительно ли работает PostgreSQL? ps -ef |grep postgres ?   -  person Craig Ringer    schedule 01.04.2014


Ответы (1)


Наконец-то я смог получить личную помощь от друга! Спасибо, Марк Мияшита!!!!

reset-postgres(){
  rm -rf /usr/local/var/postgres
  sudo sysctl -w kern.sysv.shmall=65536
  sudo sysctl -w kern.sysv.shmmax=16777216
  initdb /usr/local/var/postgres -E utf8
  sleep 2
  launchctl unload -w ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist
  cp /usr/local/Cellar/postgresql/9.3.4/homebrew.mxcl.postgresql.plist               ~/Library/LaunchAgents/
  launchctl load -w ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist
  sleep 3
  createdb DATABASENAME_development
  sleep 1
}

возможно, придется изменить номер версии в зависимости от того, какой у вас postgres

person Blou91    schedule 01.04.2014
comment
Что делает этот код, так это безоговорочно удаляет все ваши базы данных (rm -rf /usr/local/var/postgres), так что это не может быть рекомендуемым решением для незапускаемого сервера. - person Daniel Vérité; 06.12.2014