루트가 아닌 사용자로 실행되는 데몬에 대한 읽기/쓰기 권한

루트가 아닌 사용자로 실행되는 데몬에 대한 읽기/쓰기 권한

저는 데몬화하려고 하는 작은 Python 애플리케이션을 개발했습니다. 나는 사용했다이 가이드예제를 약간 수정했습니다. 다음 스크립트가 있습니다.

#!/bin/sh

### BEGIN INIT INFO
# Provides:          my-config-server
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: My configuration website
# Description:       Python Flask webserver with config views and API
### END INIT INFO

# Change the next 3 lines to suit where you install your script and what you want to call it
DIR=/home/pi/myserver/config-site
DAEMON=$DIR/run.py
DAEMON_NAME=my-config-server
LOGFILE=/var/log/myserver/config.log

# Add any command line options for your daemon here
DAEMON_OPTS="--public"

# This next line determines what user the script runs as.
# Root generally not recommended but necessary if you are using the Raspberry Pi GPIO from Python.
DAEMON_USER=pi

# The process ID of the script when it runs is stored here:
PIDFILE=/tmp/$DAEMON_NAME.pid

. /lib/lsb/init-functions

do_start () {
    log_daemon_msg "Starting system $DAEMON_NAME daemon"
    start-stop-daemon --start --background --pidfile $PIDFILE --make-pidfile --user $DAEMON_USER --chuid $DAEMON_USER --startas /bin/bash -- -c "exec $DAEMON $DAEMON_OPTS > $LOGFILE 2>&1"
    log_end_msg $?
}
do_stop () {
    log_daemon_msg "Stopping system $DAEMON_NAME daemon"
    start-stop-daemon --stop --pidfile $PIDFILE --retry 10
    log_end_msg $?
}

case "$1" in

    start|stop)
        do_${1}
        ;;

    restart|reload|force-reload)
        do_stop
        do_start
        ;;

    status)
        status_of_proc "$DAEMON_NAME" "$DAEMON" && exit 0 || exit $?
        ;;

    *)
        echo "Usage: /etc/init.d/$DAEMON_NAME {start|stop|restart|status}"
        exit 1
        ;;

esac
exit 0

애플리케이션은 구성 정보를 저장하기 위해 선반 파일을 읽고 씁니다. 정상적으로 명령줄에서 스크립트를 실행하면 모든 것이 정상입니다. 서비스를 시작하려고 하면 보류된 파일을 읽으려고 할 때 "권한 거부" 오류가 발생합니다.

Traceback (most recent call last):
  File "/home/pi/myserver/config-site/run.py", line 17, in <module>
    from config import app
  File "/home/pi/myserver/config-site/config/__init__.py", line 32, in <module>
    alarm_brightness=100
  File "/home/pi/myserver/config-site/config/persistent_config.py", line 52, in set_defaults
    if self.get(k) is None:
  File "/home/pi/myserver/config-site/config/persistent_config.py", line 14, in get
    with shelve.open(self.filename) as shelf:
  File "/usr/lib/python3.4/shelve.py", line 239, in open
    return DbfilenameShelf(filename, flag, protocol, writeback)
  File "/usr/lib/python3.4/shelve.py", line 223, in __init__
    Shelf.__init__(self, dbm.open(filename, flag), protocol, writeback)
  File "/usr/lib/python3.4/dbm/__init__.py", line 94, in open
    return mod.open(file, flag, mode)
_dbm.error: [Errno 13] Permission denied

선반 파일 권한과 상위 디렉터리는 현재 rwxr--r--입니다.

이 파일을 읽고 쓸 수 있도록 데몬을 올바르게 실행하고 권한을 설정하려면 어떻게 해야 합니까(일반적으로 읽기/쓰기 사용자 권한이 있는 모든 파일입니까?)

저는 Raspberry Pi Zero의 Raspbian 설치에서 이것을 실행하고 있습니다.

관련 정보