Как запустить сервер PostgreSQL в Mac OS X? - PullRequest
899 голосов
/ 02 ноября 2011

ФИНАЛЬНОЕ ОБНОВЛЕНИЕ:

Я забыл выполнить команду initdb.

</ FINAL UPDATE>

, выполнив эту команду

ps auxwww | grep postgres

Я вижу, что postgres не работает

> ps auxwww | grep postgres
remcat          1789   0.0  0.0  2434892    480 s000  R+   11:28PM   0:00.00 grep postgres

. Возникает вопрос: как запустить сервер postgresql?

update:

>pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start
server starting
sh: /usr/local/var/postgres/server.log: No such file or directory

update2:

Тач не был успешным, поэтому я сделал это вместо:

> mkdir /usr/local/var/postgres
> vi /usr/local/var/postgres/server.log
> ls /usr/local/var/postgres/          
server.log

Но когда я пытаюсь запустить сервер rails, я все равно вижу это:

Is the server running on host "localhost" and accepting
TCP/IP connections on port 5432?

обновление 3:

> pg_ctl -D /usr/local/var/postgres status
pg_ctl: no server running

обновление 4:

Я обнаружил, что там не было pg_hba.conf (только pg_hba.conf.sample), поэтому я изменил образец и переименовал его (для удаления)пример).Вот содержимое:

 # IPv4 local connections:
 host    all             all             127.0.0.1/32           trust
 # IPv6 local connections:
 host    all             all             ::1/128                trust

но я не понимаю этого:

> pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start     
server starting
> pg_ctl -D /usr/local/var/postgres status                                     
pg_ctl: no server running

также:

sudo find / -name postgresql.conf
find: /dev/fd/3: Not a directory
find: /dev/fd/4: Not a directory

обновление 5:

sudo pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start
Password:
pg_ctl: cannot be run as root
Please log in (using, e.g., "su") as the (unprivileged) user that will own the server process.

обновление 6:

это кажется странным:

> egrep 'listen|port' /usr/local/var/postgres/postgresql.conf
egrep: /usr/local/var/postgres/postgresql.conf: No such file or directory

хотя я сделал это:

>sudo find / -name "*postgresql.conf*"
find: /dev/fd/3: Not a directory
find: /dev/fd/4: Not a directory
/usr/local/Cellar/postgresql/9.0.4/share/postgresql/postgresql.conf.sample
/usr/share/postgresql/postgresql.conf.sample

, поэтому я сделал это:

egrep 'listen|port' /usr/local/Cellar/postgresql/9.0.4/share/postgresql/postgresql.conf.sample 
#listen_addresses = 'localhost'     # what IP address(es) to listen on;
#port = 5432                # (change requires restart)
                # supported by the operating system:
                #   %r = remote host and port

, поэтому я попробовал это:

> cp /usr/local/Cellar/postgresql/9.0.4/share/postgresql/postgresql.conf.sample /usr/local/Cellar/postgresql/9.0.4/share/postgresql/postgresql.conf        
> cp /usr/share/postgresql/postgresql.conf.sample /usr/share/postgresql/postgresql.conf 

все еще получая то же самое "Сервер работает?"сообщение.

Ответы [ 26 ]

1 голос
/ 29 декабря 2016

$ brew upgrade postgres

исправил это для меня.

Это, конечно, обновит вашу версию postgres и обновит / установит все зависимости. ВНИМАНИЕ: Делайте это, зная, что ваша версия postgresql, вероятно, изменится. Для меня это не было проблемой.

0 голосов
/ 16 июля 2019

Если вы установили Postgres с помощью установщика EnterpriseDB, то, что предложил @Kenial, это путь.

sudo -u postgres pg_ctl -D /Library/PostgreSQL/{version}/data start
sudo -u postgres pg_ctl -D /Library/PostgreSQL/{version}/data stop
0 голосов
/ 13 июня 2019

Существует некий крайний случай, который, возможно, будет кому-то полезен:

Существует вариант, что вам будет заполнен postgres.pid с некоторым PID.Но если вы перезагрузите компьютер, и до того, как postgress вернется снова, какой-то другой процесс примет этот PID.Если это произойдет, и pg_ctl status, и brew service спросят о статусе postgres, сообщат, что это UP.Просто PS AUX |grep и проверь, действительно ли это postgress

0 голосов
/ 26 мая 2019

Для полноты: проверьте, находитесь ли вы в экземпляре Tmux или Screen, запуск не будет работать оттуда.

От: https://superuser.com/questions/879640/error-while-trying-to-start-postgres-installed-via-homebrew-operation-not-permi/898585

Это решило это для меня.

0 голосов
/ 03 мая 2019

Это работало для меня каждый раз, вдохновленный Крейгом Рингером:

brew install proctools
sudo pkill -u postgres

proctools включает в себя pkill. Если у вас нет Brew: https://brew.sh/

0 голосов
/ 20 октября 2016

Для Mac / OSX мне очень нравится LaunchRocket для этого и других фоновых сервисов, которые я использовал при разработке.

https://github.com/jimbojsb/launchrocket

На этом сайте есть хорошие инструкции по установке: http://macappstore.org/launchrocket/

Это дает вам хороший экран в системных настройках, который позволяет вам запускать, перезагружать, рутировать, запускать при входе в систему.

...