Postgresql 阿里云部署排雷

news/2024/7/9 20:57:42 标签: postgresql, 阿里云, 数据库

启动服务bug:

根据你的输出,可以看到 PostgreSQL 服务启动失败,并且显示以下错误消息:

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

这个错误是因为 PostgreSQL 不允许以 root 用户身份启动。为了解决这个问题,你需要以 PostgreSQL 数据库的拥有者身份启动服务。

你可以使用以下步骤来解决这个问题:

1. 使用 `su` 命令以 `postgres` 用户身份登录:

   ```bash
   su - postgres
   ```

   输入 `postgres` 用户的密码(如果有密码的话)。

2. 在 `postgres` 用户会话中,启动 PostgreSQL 服务:

   ```bash
   /data/pgsql/bin/pg_ctl start -D /data/pgsql -s -w -t 270
   ```

   这将以 `postgres` 用户的身份启动 PostgreSQL 服务。

3. 检查 PostgreSQL 服务的状态:

   ```bash
   systemctl status postgresql.service
   ```

   确保服务现在处于 "active" 状态,并且没有错误。

如果你希望 PostgreSQL 服务在系统启动时自动启动,你可以使用以下命令启用服务:

```bash
systemctl enable postgresql.service
```

解除PID文件占用

是的,你的理解是正确的。如果之前运行的 PostgreSQL 实例状态为 "active (exited)",那么它已经处于停止状态,但是由于存在锁文件(`postmaster.pid`),因此无法重新启动新的 PostgreSQL 服务。在这种情况下,你需要执行以下操作:

1. 停止已经运行的 PostgreSQL 实例("active (exited)"状态的实例)以释放锁文件。你可以使用以下命令来尝试停止它:

   ```bash
   /data/pgsql/bin/pg_ctl stop -D /data/pgsql/dbdata -s -m fast
   ```

   这将尝试快速停止 PostgreSQL 服务。如果服务已成功停止,你可以继续下一步。

2. 如果上述步骤无法正常停止 PostgreSQL 服务,你可以手动杀死正在运行的 `postmaster` 进程。首先,查找并记下 `postmaster` 进程的 PID(在这种情况下是 PID 29613),然后使用 `kill` 命令停止它:

   ```bash
   kill -TERM 29613
   ```

   这将发送一个终止信号给进程,使其正常退出。如果没有正常退出,你可以尝试使用 `kill -KILL 29613` 强制终止它。

3. 一旦确保没有正在运行的 PostgreSQL 服务,你可以再次尝试启动服务:

   ```bash
   /data/pgsql/bin/pg_ctl start -D /data/pgsql/dbdata -s -w -t 270
   ```

   如果一切正确,PostgreSQL 服务应该能够成功启动。

这些步骤应该解决了由于锁文件导致 PostgreSQL 无法启动的问题。如果你仍然遇到问题,请提供错误消息,以便我能够更进一步帮助你。

BUG Active: active (exited)

在SysV初始化脚本下,Active: active (exited) 表示服务已经成功启动,但它不会一直在后台运行,而是在完成启动操作后立即退出。这在SysV方式下是正常的行为,因为SysV脚本通常不会自动后台运行。

PgSQL集群部署

Service文件配成两个

1. 第一个文件 `postgresql.service` 似乎是一个元单元(meta unit)用于管理系统上的所有 PostgreSQL 集群。这个单元本身不执行实际的操作,而是用于管理多个 PostgreSQL 集群的单元 `postgresql@.service` 的元单元。这个文件的内容包括了 `Description`、`ExecStart`、`ExecReload` 等字段,但它的 `ExecStart` 和 `ExecReload` 都设置为 `/bin/true`,这意味着它们不执行实际的操作。

2. 第二个文件是一个模板文件,用于启动和管理 PostgreSQL 集群的单元。它以 `postgresql@%i` 的形式命名,其中 `%i` 是一个变量,表示 PostgreSQL 集群的名称(例如,`9.3-main`)。这个文件包括了 `Description`、`AssertPathExists`、`RequiresMountsFor` 等字段,它定义了如何启动、停止和重新加载 PostgreSQL 集群。

第二个文件是用于管理 PostgreSQL 集群的 systemd 服务单元文件,而第一个文件是元单元,用于管理所有 PostgreSQL 集群的统一状态。

要启动或停止特定的 PostgreSQL 集群,使用 `systemctl` 命令,并指定要操作的单元名称,例如:

- 启动 PostgreSQL 集群:`sudo systemctl start postgresql@9.3-main`
- 停止 PostgreSQL 集群:`sudo systemctl stop postgresql@9.3-main`
- 重新加载 PostgreSQL 集群配置:`sudo systemctl reload postgresql@9.3-main`
- 查看 PostgreSQL 集群状态:`sudo systemctl status postgresql@9.3-main`

请注意,将上述命令中的 `9.3-main` 替换为你实际使用的 PostgreSQL 集群名称。


http://www.niftyadmin.cn/n/4994058.html

相关文章

docker安装elasticsearch、kibana

安装过程中,遇到最大的问题就是在安装kibana的时候发现 一直连接不上 elasticsearch。最后解决的问题就是 我通过 ifconfig en0 | grep inet| awk {print $2} 在mac中找到本机的ip,然后去到kibana容器中 修改 vi config/kibana.yml中的elasticsearch.hos…

Java- 虚拟机学习总结

Java文件编译,加载过程 写好java文件,jdk会通过javac编译class文件,classLaoder通过classpath将字节码文件加载进入jre jvm数据区 包含栈,堆,程序计数器,方法区,本地方法栈 JAVA里的常量&…

RK3288安卓7.1开机上电到显示logo需要在3s内完成

需求: 从上电到开始开机logo有一段黑屏时间,这个黑屏时间大概在6s左右,给客户体验很不好,现在需要将这段黑屏时间缩短到2-3s左右 思路: 因为只需要早点显示logo,其实整体从上电到开机动画到安卓系统启动整体…

【STM32】学习笔记(TIM定时器)

TIM(Timer)定时器 定时器可以对输入的时钟进行计数,并在计数值达到设定值时触发中断 16位计数器、预分频器、自动重装寄存器的时基单元,在72MHz计数时钟下可以实现最大59.65s的定时 不仅具备基本的定时中断功能,而且…

FPGA时序分析与约束(3)——时钟不确定性

一、前言 在之前的文章中,我们介绍了组合电路的时序和时序电路的时序问题,在阅读本文章之前,强烈推荐先阅读完本系列之前的文章,因为这是我们继续学习的理论的理论基础,前文链接: FPGA时序分析与约束&…

美客多(mercadolibre)测评下单技术(养号环境搭建详解)

MercadoLibre(美客多)是拉丁美洲的一个网购平台。该公司为其客户提供电子商务交易的购买,出售,支付和收集机制。目前全球第十大电商市场——巴西是MercadoLibre的主要市场,占据近60%的平台营收,接着是阿根廷…

算法系列-力扣234-回文链表判定

回文链表判定 给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。 方法一:栈反转对比法 解题思路:找到中间节点后用栈辅助反转对比 解题方法&#xff1…

政府网站之守护:如何确保信息真实与透明,避免政治风险?

在数字化时代,政府网站已经成为公众获取官方信息和政府政策的主要途径。确保这些信息的真实性、透明性和及时性是维护 政府公信力的关键。特别是在涉及落马官员、政治敏感信息等内容时,更需要加强审查与管理,避免带来不必要的政治风险。 那…