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
    • 最新
    • 标签
主页 / computer / 问题 / 1424293
Accepted
João Rodrigues
João Rodrigues
Asked: 2019-04-12 07:17:15 +0800 CST2019-04-12 07:17:15 +0800 CST 2019-04-12 07:17:15 +0800 CST

在 CentOS 7 中设置 PGOPTS 变量的位置

  • 772

我正在使用 Postgresql 10,在安装数据库后,我将其放入PGOPTS="-i"此文件/etc/sysconfig/pgsql/postgresql中,以便 Postgresql 可以监听所有接口。

当我使用 CentOS 6 时,这有效并且 postgresql 以-i命令行中的选项启动。

但是,我需要将数据库迁移到 CentOS 7,而 postgresql(现在它开始使用postmaster而不是postgres)不会使用该选项启动。

我知道在 EL7 中,systemd使用了并且可能无法读取 sysconfig 目录中的文件。但是,我在哪里可以设置这个变量呢?

我也在考虑将此变量设置为新文件。当我使用 Ansible 时,我需要有一个具有此配置的新文件。这意味着我不想编辑现有的文件,比如postgres.conf放在数据库安装目录中的文件。只有在没有任何其他选项可以在某处设置 PGOPTS 变量的情况下,才会这样做。

我努力了:

  • /usr/lib/systemd/system/postgresql.service.d/postgresql.conf在组内有以下内容[Service]:Environment=PGOPTS=-i. 我可以看到目录被读取(并且其他变量被读取 - 如 PGDATA - 但它没有读取 PGOPTS 或者至少 postmaster 进程没有使用该选项启动);为此,我也尝试过设置,但/usr/lib/systemd/system/postgresql.service没有成功;
  • /etc/conf.d/postgresql但是,正如我在某处读到的那样,它不再被使用了;
  • /etc/profile.d/postgresql.sh设置和导出变量;
  • ~postgres/.bash-profile设置和导出变量;
linux environment-variables centos
  • 1 1 个回答
  • 423 Views

1 个回答

  • Voted
  1. Best Answer
    user1686
    2019-04-12T07:38:17+08:002019-04-12T07:38:17+08:00

    您在 systemd Environment=设置的正确轨道上。(另一方面,服务启动过程不涉及用户 shell 和交互式登录等任何内容,因此“配置文件”文件绝对无关紧要。)

    但问题是 PostgreSQL 守护进程不使用并且从来没有首先使用过这个环境变量。实际软件中没有任何东西可以使 $PGOPTS 的内容神奇地附加到守护程序的命令行。

    所说的魔法过去是在旧的启动脚本中完成的(/etc/rc.d/init.d/postgresql在 systemd 之前被 RedHat/CentOS 使用)——它实际上并没有用作“环境”变量,而是作为“postgres”命令行中的直接替代:

    111 # 如果文件存在,覆盖 /etc/sysconfig/pgsql 中的默认值
    112 [-f /etc/sysconfig/pgsql/${名称}] && 。/etc/sysconfig/pgsql/${名称}
    113
    ...
    攀上漂亮女局长之后178
    179 $SU -l postgres -c "$PGENGINE/postmaster -p '$PGPORT' -D '$PGDATA' ${PGOPTS} &" >> "$PGLOG" 2>&1 < /dev/空
    180睡2
    

    那么在哪里添加-i命令行选项,如果不是 $PGOPTS?当然,将它直接添加到“postgres”命令行。完整的命令行在ExecStart=中为 systemd 的 postgresql.service 指定;你可以看到它仍然保留了一些替换,但你也可以直接添加自定义选项:

    ExecStart=/usr/pgsql-11/bin/postmaster -D ${PGDATA}
    

    将此更改为:

    ExecStart=/usr/pgsql-11/bin/postmaster -D ${PGDATA} -i
    

    注意:不要在 /usr/lib 中编辑 systemd 单元;相反,将单元文件复制到 /etc/systemd/system 并编辑您的副本,这样您的更改就不会在包升级期间丢失。


    postmaster(1) 手册页说:

    DESCRIPTION
        postmaster is a deprecated alias of postgres.
    
    • 1

相关问题

  • 以 root 身份运行 docker 容器

  • 如何从Win10使用RDP登录Centos 7

  • 如何在域和 Linux 活动目录中启用指纹传感器

  • 如何在CentOS 7 中将Ctrl+C 永久更改为Ctrl+K?

Sidebar

Stats

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

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    Windows 10 服务称为 AarSvc_70f961。它是什么,我该如何禁用它?

    • 2 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Marko Smith

    ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] 证书验证失败:无法获取本地颁发者证书 (_ssl.c:1056)

    • 4 个回答
  • Marko Smith

    我如何知道 Windows 安装在哪个驱动器上?

    • 6 个回答
  • Martin Hope
    Albin 支持结束后如何激活 WindowsXP? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 “HTTPS Everywhere”仍然相关吗? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch Windows 10 删除大量小文件的速度非常慢。有什么办法可以加快速度吗? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Ctrl+C 和 Ctrl+V 是如何工作的? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve