能问个homebridge的问题么?

讨论使用Domoticz过程中遇到的问题。
版面规则
讨论使用Domoticz过程中遇到的问题。
有问题请说明详细情况,有图的截图!
别只说一句安装不上,执行不了!
截图请截大图,别就截一行。。。
回复
none8629
帖子: 2
注册时间: 周四 6月 08, 2017 12:14

能问个homebridge的问题么?

帖子 none8629 »

请问homebridge在安装并设定好之后,如何实现开机启动及后台运行?
我使用的是树莓派
谢谢
头像
DT27
帖子: 345
注册时间: 周四 3月 30, 2017 08:54
Gender:

Re: 能问个homebridge的问题么?

帖子 DT27 »

这里讲了三种开机启动homebridge的方式:Running Homebridge on Bootup

建议用第二种方法[Running Homebridge on Bootup (init.d)],树莓派里的domoticz就是这么自动启动的:设置Domoticz开机自启动

简单说下第二种方法的步骤
①新建homebridge守护进程文件

代码: 全选

sudo nano /etc/init.d/homebridge
文件内容如下:

代码: 全选

#!/bin/sh
### BEGIN INIT INFO
# Provides:
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Start daemon at boot time
# Description:       Enable service provided by daemon.
### END INIT INFO

dir="/home/pi" #!!!系统用户路径改成自己的!!!
cmd="DEBUG=* /usr/bin/homebridge"
user="pi"  #!!!系统用户名改成自己的!!!

name=`basename $0`
pid_file="/var/run/$name.pid"
stdout_log="/var/log/$name.log"
stderr_log="/var/log/$name.err"

get_pid() {
    cat "$pid_file"
}

is_running() {
    [ -f "$pid_file" ] && ps -p `get_pid` > /dev/null 2>&1
}

case "$1" in
    start)
    if is_running; then
        echo "Already started"
    else
        echo "Starting $name"
        cd "$dir"
        if [ -z "$user" ]; then
            sudo $cmd >> "$stdout_log" 2>> "$stderr_log" &
        else
            sudo -u "$user" $cmd >> "$stdout_log" 2>> "$stderr_log" &
        fi
        echo $! > "$pid_file"
        if ! is_running; then
            echo "Unable to start, see $stdout_log and $stderr_log"
            exit 1
        fi
    fi
    ;;
    stop)
    if is_running; then
        echo -n "Stopping $name.."
        kill `get_pid`
        for i in 1 2 3 4 5 6 7 8 9 10
        # for i in `seq 10`
        do
            if ! is_running; then
                break
            fi

            echo -n "."
            sleep 1
        done
        echo

        if is_running; then
            echo "Not stopped; may still be shutting down or shutdown may have failed"
            exit 1
        else
            echo "Stopped"
            if [ -f "$pid_file" ]; then
                rm "$pid_file"
            fi
        fi
    else
        echo "Not running"
    fi
    ;;
    restart)
    $0 stop
    if is_running; then
        echo "Unable to stop, will not attempt to start"
        exit 1
    fi
    $0 start
    ;;
    status)
    if is_running; then
        echo "Running"
    else
        echo "Stopped"
        exit 1
    fi
    ;;
    *)
    echo "Usage: $0 {start|stop|restart|status}"
    exit 1
    ;;
esac

exit 0
②更改文件权限

代码: 全选

sudo chmod 755 /etc/init.d/homebridge
③使文件生效

代码: 全选

sudo update-rc.d homebridge defaults
④这时,homebridge就会在系统重启后自动启动了,如果要现在手动启动,执行

代码: 全选

sudo /etc/init.d/homebridge start
⑤如果要查看运行日志,可以检查log或者error文件

代码: 全选

tail -f /var/log/homebridge.log
tail -f /var/log/homebridge.err
none8629
帖子: 2
注册时间: 周四 6月 08, 2017 12:14

Re: 能问个homebridge的问题么?

帖子 none8629 »

万分感谢指教!
ylfzl
帖子: 10
注册时间: 周日 7月 30, 2017 14:38

Re: 能问个homebridge的问题么?

帖子 ylfzl »

DT27 写了: 周四 6月 08, 2017 13:35 这里讲了三种开机启动homebridge的方式:Running Homebridge on Bootup

建议用第二种方法[Running Homebridge on Bootup (init.d)],树莓派里的domoticz就是这么自动启动的:设置Domoticz开机自启动

简单说下第二种方法的步骤
①新建homebridge守护进程文件

代码: 全选

sudo nano /etc/init.d/homebridge
文件内容如下:

代码: 全选

#!/bin/sh
### BEGIN INIT INFO
# Provides:
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Start daemon at boot time
# Description:       Enable service provided by daemon.
### END INIT INFO

dir="/home/pi"
cmd="DEBUG=* /usr/local/bin/homebridge"
user="pi"

name=`basename $0`
pid_file="/var/run/$name.pid"
stdout_log="/var/log/$name.log"
stderr_log="/var/log/$name.err"

get_pid() {
    cat "$pid_file"
}

is_running() {
    [ -f "$pid_file" ] && ps -p `get_pid` > /dev/null 2>&1
}

case "$1" in
    start)
    if is_running; then
        echo "Already started"
    else
        echo "Starting $name"
        cd "$dir"
        if [ -z "$user" ]; then
            sudo $cmd >> "$stdout_log" 2>> "$stderr_log" &
        else
            sudo -u "$user" $cmd >> "$stdout_log" 2>> "$stderr_log" &
        fi
        echo $! > "$pid_file"
        if ! is_running; then
            echo "Unable to start, see $stdout_log and $stderr_log"
            exit 1
        fi
    fi
    ;;
    stop)
    if is_running; then
        echo -n "Stopping $name.."
        kill `get_pid`
        for i in 1 2 3 4 5 6 7 8 9 10
        # for i in `seq 10`
        do
            if ! is_running; then
                break
            fi

            echo -n "."
            sleep 1
        done
        echo

        if is_running; then
            echo "Not stopped; may still be shutting down or shutdown may have failed"
            exit 1
        else
            echo "Stopped"
            if [ -f "$pid_file" ]; then
                rm "$pid_file"
            fi
        fi
    else
        echo "Not running"
    fi
    ;;
    restart)
    $0 stop
    if is_running; then
        echo "Unable to stop, will not attempt to start"
        exit 1
    fi
    $0 start
    ;;
    status)
    if is_running; then
        echo "Running"
    else
        echo "Stopped"
        exit 1
    fi
    ;;
    *)
    echo "Usage: $0 {start|stop|restart|status}"
    exit 1
    ;;
esac

exit 0
②更改文件权限

代码: 全选

sudo chmod 755 /etc/init.d/homebridge
③使文件生效

代码: 全选

sudo update-rc.d homebridge defaults
④这时,homebridge就会在系统重启后自动启动了,如果要现在手动启动,执行

代码: 全选

sudo /etc/init.d/homebridge start
⑤如果要查看运行日志,可以检查log或者error文件

代码: 全选

tail -f /var/log/homebridge.log
tail -f /var/log/homebridge.err

我的运行环境是,ubuntu 16.04 server 在线默认装的domoticz和homebridge

domoticz目录是:/home/ylf/domoticz/

我把domoticz自启动用sudo service domoticz restart 放在了/etc/rc.local 内了,可以成功自启动。

但在设置homebridge时不能正常启动。只有在任意路径下手动输homebridge可以正常启动

dir="/home/pi"
cmd="DEBUG=* /usr/local/bin/homebridge"
user="pi"

cmd="DEBUG=* /usr/local/bin/homebridge"这个路径下我有没有 homebridge,dir="/home/pi"这个路径是否是domoticz的?想请教是否这段有关系?正确的路径我要如何写,感谢
头像
DT27
帖子: 345
注册时间: 周四 3月 30, 2017 08:54
Gender:

Re: 能问个homebridge的问题么?

帖子 DT27 »

ylfzl 写了: 周五 8月 11, 2017 12:33
DT27 写了: 周四 6月 08, 2017 13:35 这里讲了三种开机启动homebridge的方式:Running Homebridge on Bootup

建议用第二种方法[Running Homebridge on Bootup (init.d)],树莓派里的domoticz就是这么自动启动的:设置Domoticz开机自启动

简单说下第二种方法的步骤
①新建homebridge守护进程文件

代码: 全选

sudo nano /etc/init.d/homebridge
文件内容如下:

代码: 全选

#!/bin/sh
### BEGIN INIT INFO
# Provides:
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Start daemon at boot time
# Description:       Enable service provided by daemon.
### END INIT INFO

dir="/home/pi"
cmd="DEBUG=* /usr/local/bin/homebridge"
user="pi"

name=`basename $0`
pid_file="/var/run/$name.pid"
stdout_log="/var/log/$name.log"
stderr_log="/var/log/$name.err"

get_pid() {
    cat "$pid_file"
}

is_running() {
    [ -f "$pid_file" ] && ps -p `get_pid` > /dev/null 2>&1
}

case "$1" in
    start)
    if is_running; then
        echo "Already started"
    else
        echo "Starting $name"
        cd "$dir"
        if [ -z "$user" ]; then
            sudo $cmd >> "$stdout_log" 2>> "$stderr_log" &
        else
            sudo -u "$user" $cmd >> "$stdout_log" 2>> "$stderr_log" &
        fi
        echo $! > "$pid_file"
        if ! is_running; then
            echo "Unable to start, see $stdout_log and $stderr_log"
            exit 1
        fi
    fi
    ;;
    stop)
    if is_running; then
        echo -n "Stopping $name.."
        kill `get_pid`
        for i in 1 2 3 4 5 6 7 8 9 10
        # for i in `seq 10`
        do
            if ! is_running; then
                break
            fi

            echo -n "."
            sleep 1
        done
        echo

        if is_running; then
            echo "Not stopped; may still be shutting down or shutdown may have failed"
            exit 1
        else
            echo "Stopped"
            if [ -f "$pid_file" ]; then
                rm "$pid_file"
            fi
        fi
    else
        echo "Not running"
    fi
    ;;
    restart)
    $0 stop
    if is_running; then
        echo "Unable to stop, will not attempt to start"
        exit 1
    fi
    $0 start
    ;;
    status)
    if is_running; then
        echo "Running"
    else
        echo "Stopped"
        exit 1
    fi
    ;;
    *)
    echo "Usage: $0 {start|stop|restart|status}"
    exit 1
    ;;
esac

exit 0
②更改文件权限

代码: 全选

sudo chmod 755 /etc/init.d/homebridge
③使文件生效

代码: 全选

sudo update-rc.d homebridge defaults
④这时,homebridge就会在系统重启后自动启动了,如果要现在手动启动,执行

代码: 全选

sudo /etc/init.d/homebridge start
⑤如果要查看运行日志,可以检查log或者error文件

代码: 全选

tail -f /var/log/homebridge.log
tail -f /var/log/homebridge.err

我的运行环境是,ubuntu 16.04 server 在线默认装的domoticz和homebridge

domoticz目录是:/home/ylf/domoticz/

我把domoticz自启动用sudo service domoticz restart 放在了/etc/rc.local 内了,可以成功自启动。

但在设置homebridge时不能正常启动。只有在任意路径下手动输homebridge可以正常启动

dir="/home/pi"
cmd="DEBUG=* /usr/local/bin/homebridge"
user="pi"

cmd="DEBUG=* /usr/local/bin/homebridge"这个路径下我有没有 homebridge,dir="/home/pi"这个路径是否是domoticz的?想请教是否这段有关系?正确的路径我要如何写,感谢
第一行改为你的用户路径
第二行改为你的homebridge路径
homebridge路径查看执行“which homebridge”来输出。

代码: 全选

dir="/home/ylf"
cmd="DEBUG=* homebridge文件路径"
user="ylf"
以上修改仅基于理论,未实际验证过。 8-)
znjj1989
帖子: 1
注册时间: 周五 5月 11, 2018 06:56

Re: 能问个homebridge的问题么?

帖子 znjj1989 »

homebridge不能开机自启动 用了上边的方案也不行哦
头像
DT27
帖子: 345
注册时间: 周四 3月 30, 2017 08:54
Gender:

Re: 能问个homebridge的问题么?

帖子 DT27 »

znjj1989 写了: 周六 5月 12, 2018 16:42 homebridge不能开机自启动 用了上边的方案也不行哦
看楼上,代码里对应路径还有用户名改成自己的,homebridge路径用"which homebridge"命令获取。
回复