如何在Mac OS X上启动PostgreSQL服务器?

本文档记录了在Mac OS X上启动PostgreSQL服务器遇到的问题及解决方法,包括使用Homebrew、Postgres.app、launchctl等工具进行启动、停止和管理PostgreSQL服务。此外,还提到了权限问题、pid文件冲突以及使用Docker等不同安装方式的启动步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最终更新:

我忘了运行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服务器?

更新:

>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

更新2:

触摸不成功所以我这样做了:

> 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)所以我修改了样本并将其重命名(以移除.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 

仍然是相同的“服务器正在运行吗?” 信息。


#1楼

我几乎完全相同的问题,你引用initdb命令作为修​​复。 这也是我的解决方案,但我没有看到有人在这里发布,所以对于那些正在寻找它的人:

initdb /usr/local/var/postgres -E utf8

#2楼

出于测试目的,我认为PostgreSQL App是最好的选择!

运行应用程序,服务器已启动并正在运行。 关闭应用程序,服务器关闭。

http://postgresapp.com/


#3楼

这里我的2美分:我为postgres pg_ctl创建了一个别名并将其放在.bash_profile中(我的postgresql版本是9.2.4,数据库路径是/Library/PostgreSQL/9.2/data)。

alias postgres.server="sudo -u postgres pg_ctl -D /Library/PostgreSQL/9.2/data"

推出新终端。

然后? 您可以使用以下命令启动/停止postgresql服务器:

postgres.server start
postgres.server stop

#4楼

另一种方法是使用lunchy gem(launchctl的包装器):

brew install postgresql
initdb /usr/local/var/postgres -E utf8
gem install lunchy

开始postgres:

lunchy start postgres

停止postgres:

lunchy stop postgres

有关详细信息,请参阅:“ 如何使用Homebrew和Lunchy在Mac上安装PostgreSQL ”


#5楼

PostgreSQL集成在Server.app中,可通过Mountain Lion的App Store获得。 这意味着它已经配置,您只需要启动它,然后创建用户和数据库。

提示 :不要从定义$ PGDATA等开始,按原样获取文件位置。

你会有这个文件: / Library/Server/PostgreSQL/Config/org.postgresql.postgres.plist

开始:

sudo serveradmin start postgres

流程以参数开头:

/Applications/Server.app/Contents/ServerRoot/usr/bin/postgres_real -D / Library / Server / PostgreSQL / Data -c listen_addresses = 127.0.0.1,:: 1 -c log_connections = on -c log_directory = / Library / Logs / PostgreSQL -c log_filename = PostgreSQL.log -c log_line_prefix =%t -c log_lock_waits = on -c log_statement = ddl -c logging_collector = on -c unix_socket_directory = / private / var / pgsql_socket -c unix_socket_group = _postgres -c unix_socket_permissions = 0770

你可以sudo:

sudo -u _postgres psql template1

或连接:

psql -h localhost -U _postgres postgres

您可以使用找到数据目录,版本,运行状态等

sudo serveradmin fullstatus postgres  

#6楼

要启动postgresql服务器:

pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start

结束postgresql服务器:

pg_ctl -D /usr/local/var/postgres stop -s -m fast

您还可以通过CLI创建别名以简化:

alias pg-start='pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start'
alias pg-stop='pg_ctl -D /usr/local/var/postgres stop -s -m fast'

有了这些,你可以输入“pg-start”来启动Postgres,然后输入“pg-stop”来关闭它。


#7楼

出于开发目的,最简单的方法之一是从官方站点安装Postgres.app。 它可以从Applications文件夹启动/停止,也可以在终端中使用以下命令:

# start
open -a Postgres

# stop
killall Postgres
killall postgres

#8楼

当您使用自制软件安装postgresql时:

brew install postgres

在输出结束时,您将看到此方法启动服务器:

To have launchd start postgresql at login:
    ln -sfv /usr/local/opt/postgresql/*.plist ~/Library/LaunchAgents
Then to load postgresql now:
    launchctl load ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist
Or, if you don't want/need launchctl, you can just run:
    postgres -D /usr/local/var/postgres

我认为这是最好的方法。

为方便起见,您可以在.profile中添加别名。


#9楼

如果你想手动启动和停止postgresql(通过自制软件安装),最简单的方法是:

brew services start postgresql

brew services stop postgresql

#10楼

这个答案的变化: https//stackoverflow.com/a/13103603/2394728

initdb `brew --prefix`/var/postgres/data -E utf8`` &&  pg_ctl -D /usr/local/var/postgres/data -l logfile start

#11楼

对于快速的一次性测试数据库,您可以在前台运行服务器。

在新目录中初始化一个新的postgres数据库

mkdir db
initdb db -E utf8
createdb public

在前台启动服务器(ctrl-C停止服务器)

postgres -d db

在另一个shell会话中,连接到服务器

psql -d public

#12楼

如果你通过brew安装了postgres,那么到目前为止最简单启动/停止/重启postgres的方法是简单地卸载和/或加载安装时附带的launchd配置文件:

launchctl unload ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist

第一行将停止postgres,第二行将启动它。 无需指定任何数据目录等,因为一切都在该文件中。


#13楼

我有同样的问题,并从第一篇文章执行所有更新。 但检查日志文件后:

/usr/local/var/postgres/server.log

我看到了真正的原因:

FATAL:  data directory "/usr/local/var/postgres" has group or world access
DETAIL:  Permissions should be u=rwx (0700).

在此目录上更改权限后

chmod 0700 /usr/local/var/postgres

postgres服务器已启动。

每次检查日志文件。


#14楼

如果您的计算机突然重新启动

首先,您必须删除文件/usr/local/var/postgres/postmaster.pid然后,您可以使用许多其他提到的方法之一重新启动服务,具体取决于您的安装。

你可以通过查看Postgres的日志来验证这一点,看看会发生什么: tail -f /usr/local/var/postgres/server.log


#15楼

对于Mac / OSX,我真的很喜欢LaunchRocket这个以及我在开发中使用的其他后台服务。

https://github.com/jimbojsb/launchrocket

这个网站有很好的安装说明: http//macappstore.org/launchrocket/

这为您在系统偏好设置中提供了一个漂亮的屏幕,允许您在登录时启动,重新启动,root,启动。


#16楼

$ brew upgrade postgres

为我修好了。

当然,这将升级您的postgres版本并更新/安装任何依赖项。 警告:知道你的postgresql版本可能会改变,这样做。 对我来说,这不是什么大问题。


#17楼

尽管得到了相同的错误消息,上述答案都没有为我解决问题。 通过删除已锁定且不允许连接的现有postmaster.pid文件,我能够恢复并运行我的实例。


#18楼

   # remove old database files (If there was any)
   $rm -rf /usr/local/var/postgres    # install the binary

    $ brew install postgresql

    # init it
    $ initdb /usr/local/var/postgres

    # start the postgres server
    $ postgres -D /usr/local/var/postgres

    # create your database
    $ createdb mydb


    # Access db.
    $ psql mydb
    psql (9.0.1)
    Type "help" for help.

#19楼

对于macport,只需使用load / unload命令和正在运行的服务器的端口名称:

sudo port load postgresql96-server
- or -
sudo port unload postgresql96-server

所以你不必记住/Library/LaunchDaemons/org.macports.postgresql96.plist文件的位置


#20楼

docker run --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -d postgres

https://hub.docker.com/_/postgres


#21楼

每次都受到Craig Ringer的启发,这对我有用:

brew install proctools
sudo pkill -u postgres

proctools包括pkill。 如果您没有Brew: https//brew.sh/


#22楼

为了完整起见:检查您是否在TmuxScreen实例中,启动将无法在那里工作。

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

这解决了我。


#23楼

有一些边缘案例可能会对某人有所帮助:

有选项,你将postgres.pid填充一些PID。 但是如果你重新启动你的机器,并且在postgress再次返回之前,其他一些进程将采用该PID。 如果发生这种情况,pg_ctl status和brew服务都会询问postgres状态,会告诉你它是UP。 只是ps aux | grep并检查它是否真的是postgress


#24楼

如果您已经使用brew安装,则下面的命令就足够了。

brew services restart postgresql

这有时可能不起作用,在这种情况下,下面两个命令肯定会起作用

rm /usr/local/var/postgres/postmaster.pid

pg_ctl -D /usr/local/var/postgres start

#25楼

如果你使用EnterpriseDB安装程序安装Postgres,那么@Kenial建议的是要走的路。

sudo -u postgres pg_ctl -D /Library/PostgreSQL/{version}/data start
sudo -u postgres pg_ctl -D /Library/PostgreSQL/{version}/data stop

#26楼

对我有用(macOS 10.13) sudo -u postgres /Library/PostgreSQL/9.6/bin/pg_ctl start -D /Library/PostgreSQL/9.6/data

或者第一个cd /Library/PostgreSQL/9.6/bin/


#27楼

Homebrew包管理器包含自动启动的launchctl plists。 有关更多信息,请运行brew info postgres

手动启动:

pg_ctl -D /usr/local/var/postgres start

手动停止:

pg_ctl -D /usr/local/var/postgres stop

自动启动:

“要立即启动postgresql并在登录时重新启动:”

brew services start postgresql


pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log start什么?

pg_ctl -D /usr/local/var/postgres status什么?

server.log中是否有任何错误消息?

确保在pg_hba.conf中启用了tcp localhost连接:

# IPv4 local connections:
host    all             all             127.0.0.1/32            trust

检查postgresql.conf中的listen_addresses和port:

egrep 'listen|port' /usr/local/var/postgres/postgresql.conf

#listen_addresses = 'localhost'     # what IP address(es) to listen on;
#port = 5432                # (change requires restart)

打扫干净

Postgres最有可能通过HomebrewFinkMacPortsEnterpriseDB安装程序安装。

检查以下命令的输出以确定安装它的软件包管理器:

brew && brew list|grep postgres
fink && fink list|grep postgres
port && port installed|grep postgres
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值