システム起動後にmonetdbデータベースを自動的に起動するサービスをrootでセットアップしようとしています。なぜなら、monetdbはそのようなメカニズムを提供していないからです。私が作った /etc/init.d/monetdb
スクリプトファイル
#!/bin/sh
#
# /etc/init.d/monetdb
# Subsystem file for "MonetDB" starter
#
# chkconfig: 2345 95 05
#
# processname: MonetDB
# pidfile: /var/run/MonetDB.pid
. /etc/init.d/functions
case "$1" in
start)
su - monetka -c ". start.sh"
touch /var/lock/subsys/monetdb
;;
stop)
su - monetka -c ". stop.sh"
rm -f /var/lock/subsys/monetdb
;;
status)
status monetdb
;;
restart|reload|condrestart)
/etc/init.d/monetdb stop
/etc/init.d/monetdb start
;;
*)
echo $"Usage: $0 {start|stop|restart|reload|status}"
esac
exit 2
自作しています start.sh
そして stop.sh
にあるスクリプト monetka
毎回正常に実行しているユーザー。しかし、私が自分のサービスを開始したいとき、私はエラーと次の情報を得ています。
monetdb.service - SYSV: MonetDB starter
Loaded: loaded (/etc/rc.d/init.d/monetdb)
Active: failed (Result: exit-code) since śro 2015-04-29 14:36:30 CEST; 16min ago
Process: 5390 ExecStart=/etc/rc.d/init.d/monetdb start (code=exited, status=2)
kwi 29 14:36:30 yamny.centOS systemd[1]: Starting SYSV: MonetDB starter...
kwi 29 14:36:30 yamny.centOS su[5391]: (to monetka) root on none
kwi 29 14:36:30 yamny.centOS monetdb[5390]: [śro, 29 kwi 2015, 14:36:30 CEST] MonetDB: dbfarm jest już ur...miona
kwi 29 14:36:30 yamny.centOS monetdb[5390]: [śro, 29 kwi 2015, 14:36:30 CEST] MonetDB: baza demo jest już...miona
kwi 29 14:36:30 yamny.centOS systemd[1]: monetdb.service: control process exited, code=exited status=2
kwi 29 14:36:30 yamny.centOS systemd[1]: Failed to start SYSV: MonetDB starter.
kwi 29 14:36:30 yamny.centOS systemd[1]: Unit monetdb.service entered failed state.
また、上記のレポートによると、 start.sh
スクリプトは(私が前に述べたように)うまくやっています。
私がこれまでにやったこと:
- 作成した
/etc/init.d/monetdb
ルート上のスクリプト - とサービスを追加しました
chkconfig --add monetdb
- でサービスを開始
systemctl start monetdb.service