AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 496530
Accepted
Marcus Junius Brutus
Marcus Junius Brutus
Asked: 2013-04-06 07:52:16 +0800 CST2013-04-06 07:52:16 +0800 CST 2013-04-06 07:52:16 +0800 CST

sudo /etc/init.d/postgresql restart(如何选择安装?)

  • 772

我有两个 postgresql 安装:

$ sudo /etc/init.d/postgresql status
9.1/main (port 5432): online
9.2/main (port 5433): online

我习惯于重新启动 postgres 数据库,执行以下操作:

$ sudo /etc/init.d/postgresql restart

……但是现在有两个,怎么选择重启哪一个呢?

更新:根据我从Micah Yoder收到的答案,我做了一个:

/usr/lib/postgresql/9.2/bin/pg_ctl -D /var/lib/postgresql/9.2/main restart

遇到“无法打开 PID 文件 /var/lib/postgresql/9.2/main/main/postmaster.pid 权限被拒绝”。当我尝试在sudo-i会话中运行pg_ctl时,我遇到了:

pg_ctl: cannot be run as root
Please log in (using, e.g., "su") as the (unprivileged) user that will
own the server process.

我应该如何运行pg_ctl程序?另外我不明白为什么我必须为重启指明数据文件。进程不知道它正在使用哪个数据文件吗?

更新 2 最后我放弃了pg_ctl并做了一个:

sudo /etc/init.d/postgresql restart 9.2

.. 根据公认的答案。

postgresql
  • 3 3 个回答
  • 41131 Views

3 个回答

  • Voted
  1. Best Answer
    m.sr
    2013-04-06T08:40:41+08:002013-04-06T08:40:41+08:00

    如果你使用的是 debian,你可以告诉 init 脚本你想要管理哪个版本:

    pg01:~# /etc/init.d/postgresql       
    Usage: /etc/init.d/postgresql {start|stop|restart|reload|force-reload|status} [version ..]
    pg01:~#
    
    • 6
  2. Micah Yoder
    2013-04-06T08:23:55+08:002013-04-06T08:23:55+08:00

    首先,您是故意同时运行两个版本,还是只是从不同的软件包安装了 9.2 而没有删除 9.1?(Postgres 软件包现在经常以这种方式设置。)如果您已经迁移,那么应该删除 9.1。

    如果你需要两者,那么每个都应该有自己的 pg_ctl 可执行文件,它可以做与普通 initscript 相同的事情。以“postgres”用户身份运行它。请参阅 .../path/bin/pg_ctl --help

    • 2
  3. Drt
    2013-04-06T08:33:47+08:002013-04-06T08:33:47+08:00

    您可能正在运行两个 postgresql 实例,使用存储在两个位置的两个名为 postgresql.conf 的不同配置文件。

    您应该检查/etc/sysconfig/pgsql/postgresql配置文件以验证它使用的是哪个 pgsql /etc/init.d/postgresql。它必须具有将存储 postgresql.conf 文件的 pgsql 目录的位置。在这个 conf 文件中,将有特定 pgsql 的端口号。

    • 0

相关问题

  • OS X 上的 Postgresql 安装问题

  • 修复 mysql 命令行程序中的 Control-C?

  • 有哪些好的 PostgreSQL 管理工具?[关闭]

  • Access 通过 ODBC 连接到远程 Postgresql 数据库是否可用?

  • 哪个数据库服务器扩展性更好:PostgreSQL 还是 MySQL?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve