免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3599 | 回复: 8
打印 上一主题 下一主题

postgres为什么不能用超户启动,我看代码都写死了,谁知道具体原因呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-23 14:46 |只看该作者 |倒序浏览
postgres为什么不能用超户启动,我看代码都写死了,谁知道具体原因呢?

论坛徽章:
0
2 [报告]
发表于 2011-12-23 21:03 |只看该作者
根本原因是安全问题吧

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-08 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-09-18 06:20:00数据库技术版块每周发帖之星
日期:2015-11-06 19:56:51数据库技术版块每日发帖之星
日期:2016-01-22 06:20:00数据库技术版块每日发帖之星
日期:2016-02-05 06:20:00
3 [报告]
发表于 2011-12-24 00:35 |只看该作者
额,用源码安装,把检查用户的部分注掉

论坛徽章:
3
数据库技术版块每日发帖之星
日期:2015-06-18 22:20:00数据库技术版块每日发帖之星
日期:2015-06-21 22:20:00数据库技术版块每日发帖之星
日期:2015-08-27 06:20:00
4 [报告]
发表于 2011-12-29 21:14 |只看该作者
是安全原因的,在root下运行对系统不是很安全。不建议通过改源码让PostgreSQL运行在root下。

论坛徽章:
0
5 [报告]
发表于 2012-01-30 10:23 |只看该作者
很多软件都用系统用户,不用超级用户。

论坛徽章:
0
6 [报告]
发表于 2012-04-02 18:17 |只看该作者
安全原因,pg不能用root启动

论坛徽章:
0
7 [报告]
发表于 2012-04-08 12:19 |只看该作者
回复 1# qj_zhai

如果您是在Linux下的话可以通过su进行用户调用进行启动,通常我们会编写启动脚本如下,并放到/etc/init.d目录下
  1. #!/bin/bash
  2. #
  3. # chkconfig: 2345 85 15
  4. # description: Starts and stops the Postgres Plus Advanced Server 9.1 database server

  5. # Postgres Plus Advanced Server Service script for Linux

  6. start()
  7. {
  8.         startserver=0
  9.         if [ -e "/opt/PostgresPlus/9.1AS/data/postmaster.pid" ]
  10.         then
  11.                 pidofpro=`head -n 1 /opt/PostgresPlus/9.1AS/data/postmaster.pid`
  12.                 alive=`ps -p $pidofpro | grep $pidofpro`

  13.                 if [ "x$alive" != "x" ]
  14.                 then
  15.                         exit
  16.                 else
  17.                         startserver=1
  18.                 fi
  19.         else
  20.                 startserver=1
  21.         fi
  22.         if [ $startserver != 0 ]
  23.         then
  24.                 echo $"Starting Postgres Plus Advanced Server 9.1: "
  25.                 su - enterprisedb -c "LD_LIBRARY_PATH=/opt/PostgresPlus/9.1AS/lib:$LD_LIBRARY_PATH /opt/PostgresPlus/9.1AS/bin/pg_ctl -w start -D \"/opt/PostgresPlus/9.1AS/data\" -l \"/opt/PostgresPlus/9.1AS/data/pg_log/startup.log\""
  26.        
  27.         if [ $? -eq 0 ];
  28.                 then
  29.                         echo "Postgres Plus Advanced Server 9.1 started successfully"
  30.             exit 0
  31.                 else
  32.                         echo "Postgres Plus Advanced Server 9.1 did not start in a timely fashion, please see /opt/PostgresPlus/9.1AS/data/pg_log/startup.log for details"
  33.             exit 1
  34.                 fi
  35.         fi
  36. }

  37. stop()
  38. {
  39.         if [ -e "/opt/PostgresPlus/9.1AS/data/postmaster.pid" ]
  40.         then
  41.                 pidofproc=`head -n 1 /opt/PostgresPlus/9.1AS/data/postmaster.pid`
  42.                 pidalive=`ps -p $pidofproc | grep $pidofproc`
  43.                
  44.                 if [ "x$pidalive" != "x" ]
  45.                 then
  46.                         echo $"Stopping Postgres Plus Advanced Server 9.1: "
  47.                         su - enterprisedb -c "LD_LIBRARY_PATH=/opt/PostgresPlus/9.1AS/lib:$LD_LIBRARY_PATH /opt/PostgresPlus/9.1AS/bin/pg_ctl stop -m fast -w -D \"/opt/PostgresPlus/9.1AS/data\""
  48.                 fi
  49.         fi
  50. }

  51. reload()
  52. {
  53.         echo $"Reloading Postgres Plus Advanced Server 9.1: "
  54.         su - enterprisedb -c "LD_LIBRARY_PATH=/opt/PostgresPlus/9.1AS/lib:$LD_LIBRARY_PATH /opt/PostgresPlus/9.1AS/bin/pg_ctl reload -D \"/opt/PostgresPlus/9.1AS/data\""
  55. }

  56. # See how we were called.
  57. case "$1" in
  58.   start)
  59.         start
  60.         ;;
  61.   stop)
  62.         stop
  63.         ;;
  64.   reload)
  65.         reload
  66.         ;;
  67.   condrestart|restart)
  68.             stop
  69.             sleep 3
  70.             start
  71.         ;;
  72.   status)
  73.         su - enterprisedb -s /bin/bash -m -c "LD_LIBRARY_PATH=/opt/PostgresPlus/9.1AS/lib:$LD_LIBRARY_PATH /opt/PostgresPlus/9.1AS/bin/pg_ctl status -D \"/opt/PostgresPlus/9.1AS/data\""
  74.         ;;
  75.   *)
  76.         echo $"Usage: $0 {start|stop|restart|condrestart|reload|status}"
  77.         exit 1
  78. esac
复制代码

论坛徽章:
13
15-16赛季CBA联赛之同曦
日期:2016-01-28 19:52:032015亚冠之北京国安
日期:2015-10-07 14:28:19NBA常规赛纪念章
日期:2015-05-04 22:32:03处女座
日期:2015-01-15 19:45:44卯兔
日期:2014-10-28 16:17:14白羊座
日期:2014-05-24 15:10:46寅虎
日期:2014-05-10 09:50:35白羊座
日期:2014-03-12 20:52:17午马
日期:2014-03-01 08:37:27射手座
日期:2014-02-19 19:26:54子鼠
日期:2013-11-30 09:03:56狮子座
日期:2013-09-08 08:37:52
8 [报告]
发表于 2012-04-21 20:41 |只看该作者
学习了,都是高手!

论坛徽章:
29
技术图书徽章
日期:2013-09-02 19:59:502015元宵节徽章
日期:2015-03-06 15:51:332015小元宵徽章
日期:2015-03-06 15:57:20操作系统版块每日发帖之星
日期:2015-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17操作系统版块每日发帖之星
日期:2015-09-21 06:20:002015亚冠之水原三星
日期:2015-10-30 00:06:07数据库技术版块每日发帖之星
日期:2015-12-24 06:20:0015-16赛季CBA联赛之上海
日期:2016-01-07 10:32:07操作系统版块每日发帖之星
日期:2016-01-08 06:20:00操作系统版块每日发帖之星
日期:2016-05-18 06:20:00IT运维版块每日发帖之星
日期:2016-07-23 06:20:00
9 [报告]
发表于 2012-05-06 04:56 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP