编辑:出于某种原因,我的帖子有一半被截断了,不知道发生了什么。我会尽快更新,并在顶部发布更新信息。
编辑:我再次更新了帖子,对于问题不完整感到抱歉。
编辑(东部时间 2011 年 10 月 10 日晚上 8:55):我按照 Steven 的建议更新了 /srv/rhodecode/start.sh,但仍然没有成功。它继续挂起,如下所示:
[lpeabody@vcs rhodecode]$ sudo /etc/init.d/rhodecode-server start
Starting rhodecode-server:
我已更新下面的脚本来显示更改。
我这辈子从来没有写过 shell 或 bash 脚本。我试图在 CentOS 上安装 RhodeCode,Debian 和 Gentoo 有 init 脚本,但没有 RedHat/CentOS 的 init 脚本,这对我来说太疯狂了。所以我需要写一个,因为我们的服务器环境仅限于运行 CentOS 5。该项目的源代码可以在 Bitbucket 上找到这里。
这个想法是使用 Celery 和 RabbitMQ 运行 RhodeCode。它全部用 Python 编写,我使用 virtualenv 将环境放在它自己的单独虚拟容器中。我有了 shell 脚本的想法这里。
我创建了一个名为 rhodecode 的系统用户,并创建了目录 /var/run/rhodecode,该目录归 rhodecode 所有。我还创建了 production.ini 所在的 /var/www/rhodecode 以及 /srv/rhodecode/start.sh,所有这些都归 rhodecode 所有。
权限:
[lpeabody@vcs run]$ ll -a /var/run/rhodecode
total 12
drwxr-xr-x 2 rhodecode rhodecode 4096 Oct 10 15:57 .
drwxr-xr-x 21 root root 4096 Oct 10 16:07 ..
[lpeabody@vcs run]$ ll -a /var/www/rhodecode
total 76
drwxr-xr-x 4 rhodecode rhodecode 4096 Oct 10 16:47 .
drwxr-xr-x 11 root root 4096 Oct 5 14:54 ..
drwxrwxr-x 3 rhodecode rhodecode 4096 Oct 5 19:40 data
-rw-r--r-- 1 rhodecode rhodecode 0 Oct 10 16:41 debug.log
-rw-r--r-- 1 rhodecode rhodecode 1466 Oct 10 16:41 error.log
-rw-rw-r-- 1 rhodecode rhodecode 6000 Oct 6 15:27 production.ini
drwxrwxr-x 2 rhodecode rhodecode 4096 Oct 5 18:37 repos
-rw-r--r-- 1 rhodecode rhodecode 44032 Oct 5 19:16 rhodecode.db
[lpeabody@vcs run]$ ll -a /srv/rhodecode/
total 16
drwxr-xr-x 2 rhodecode rhodecode 4096 Oct 10 16:40 .
drwxr-xr-x 4 root root 4096 Oct 7 14:40 ..
-rwxr-xr-x 1 rhodecode rhodecode 277 Oct 10 16:40 start.sh
我有以下 bash 和 shell 脚本。
/srv/rhodecode/start.sh
#!/bin/bash
# run this as the rhodecode user!
WDIR=/var/www/rhodecode
VIRTUALENV_DIR=/opt/python_virtualenvironments/rhodecode-venv
export PYTHON_EGG_CACHE=/tmp/.python-eggs
source $VIRTUALENV_DIR/bin/activate
cd $WDIR
exec paster serve production.ini 1> debug.log 2> error.log
/etc/init.d/rhodecode服务器
#!/bin/sh
#
# rhodecode-server RhodeCode server instance
#
#
# PATH=/sbin:/usr/sbin:/bin:/usr/bin
NAME=rhodecode-server
DESC=rhodecode-server
USER=rhodecode
PID_FILE=/var/run/rhodecode/pid
CMD=/srv/rhodecode/start.sh
LOCK_FILE=/var/lock/subsys/$NAME
. /etc/init.d/functions
RETVAL=0
remove_pid () {
rm -f ${PID_FILE}
}
start_rhodecode () {
daemon --user $USER --pidfile $PID_FILE $CMD
RETVAL=$?
[ $RETVAL -eq 0 ] && touch $LOCK_FILE
return $RETVAL
}
stop_rhodecode () {
killproc -p $PID_FILE
RETVAL=&?
rm -f $LOCK_FILE
rm -f $PID_FILE
return $RETVAL
}
restart_rhodecode () {
stop_rhodecode
start_rhodecode
RETVAL=$?
}
case "$1" in
start)
echo -n $"Starting $DESC: "
start_rhodecode
echo
;;
stop)
echo -n $"Stopping $DESC: "
stop_rhodecode
echo
;;
restart)
echo -n $"Restarting $DESC: "
restart_rhodecode
echo
;;
*)
echo $"Usage: $0 {start|stop|restart}"
RETVAL=1
;;
esac
exit $RETVAL
当我运行sudo /etc/init.d/rhodecode-server start
然后运行时ps -aux | grep paster
,我可以看到paster serve production.ini
来自 /srv/rhodecode/start.sh 的命令已经通过并且正在使用 rhodecode 的用户 ID (102) 运行。
102 5222 0.7 7.8 144300 80988 ? Sl 16:08 0:00 /opt/python_virtualenvironments/rhodecode-venv/bin/python /opt/python_virtualenvironments/rhodecode-venv/bin/paster serve production.ini
但是,没有创建 pid 文件,因此我无法从 init 脚本停止服务器。我不确定守护进程为什么没有创建 pid 文件。pid 文件的路径有效,权限正确。有什么想法吗?
答案1
我认为您的问题出在/srv/rhodecode/start.sh
。它当前paster
作为单独的后台进程启动,然后立即退出。这对您的 init 脚本造成了问题,因为该脚本start.sh
本身就是需要管理的长期运行的守护进程。
因此,尝试将最后一行改为/srv/rhodecode/start.sh
如下形式:
exec paster serve production.ini 1> debug.log 2> error.log
使用exec
makesstart.sh
变得 paster
,然后由daemon
init 脚本中的命令对其进行守护进程化。
答案2
您必须指定位置吗?您可以使用 --name 选项为其命名吗?这将为您创建 PID,并在完成后清理它。所以它看起来像:
$NAME="rhodecode"
start_rhodecode () {
daemon --user $USER --name $NAME $CMD
RETVAL=$?
return $RETVAL
}
stop_rhodecode () {
daemon --name $NAME --stop
RETVAL=&?
return $RETVAL
}