isc_dhcp_server启动错误:`dhcpd:无法创建PID文件/run/dhcp-server/dhcpd.pid:权限被拒绝。

菲利普·加乔德(Philippe Gachoud)

dhcpd: Can't create PID file /run/dhcp-server/dhcpd.pid: Permission denied.service isc-dhcp-server startUbuntu 15.10上启动isc_dhcp_server时,在/ var / log / syslog中的错误报告此处,软件包的版本为4.3.1-5ubuntu3

进程命令dhcpd -user dhcpd -group dhcpd -f -4 -pf /run/dhcp-server/dhcpd.pid -cf /etc/dhcp/dhcpd.conf eth0来自/etc/init.d/isc-dhcp-server文件

user@host: /$ cat /etc/init.d/isc-dhcp-server                
#!/bin/sh
#
#

### BEGIN INIT INFO
# Provides:          isc-dhcp-server
# Required-Start:    $remote_fs $network $syslog
# Required-Stop:     $remote_fs $network $syslog
# Should-Start:      $local_fs slapd $named
# Should-Stop:       $local_fs slapd
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: DHCP server
# Description:       Dynamic Host Configuration Protocol Server
### END INIT INFO

PATH=/sbin:/bin:/usr/sbin:/usr/bin

test -f /usr/sbin/dhcpd || exit 0

DHCPD_DEFAULT="${DHCPD_DEFAULT:-/etc/default/isc-dhcp-server}"

# It is not safe to start if we don't have a default configuration...
if [ ! -f "$DHCPD_DEFAULT" ]; then
        echo "$DHCPD_DEFAULT does not exist! - Aborting..."
        if [ "$DHCPD_DEFAULT" = "/etc/default/isc-dhcp-server" ]; then
                echo "Run 'dpkg-reconfigure isc-dhcp-server' to fix the problem."
        fi
        exit 0
fi

. /lib/lsb/init-functions

# Read init script configuration
[ -f "$DHCPD_DEFAULT" ] && . "$DHCPD_DEFAULT"

NAME=dhcpd
DESC="ISC DHCP server"
# fallback to default config file
DHCPD_CONF=${DHCPD_CONF:-/etc/dhcp/dhcpd.conf}
# try to read pid file name from config file, with fallback to /var/run/dhcpd.pid
if [ -z "$DHCPD_PID" ]; then
        DHCPD_PID=$(sed -n -e 's/^[ \t]*pid-file-name[ \t]*"(.*)"[ \t]*;.*$/\1/p' < "$DHCPD_CONF" 2>/dev/null | head -n 1)
fi
DHCPD_PID="${DHCPD_PID:-/var/run/dhcpd.pid}"

test_config()
{
        if ! /usr/sbin/dhcpd -t $OPTIONS -q -cf "$DHCPD_CONF" > /dev/null 2>&1; then
                echo "dhcpd self-test failed. Please fix $DHCPD_CONF."
                echo "The error was: "
                /usr/sbin/dhcpd -t $OPTIONS -cf "$DHCPD_CONF"
                exit 1
        fi
        touch /var/lib/dhcp/dhcpd.leases
}

# single arg is -v for messages, -q for none
check_status()
{
    if [ ! -r "$DHCPD_PID" ]; then
        test "$1" != -v || echo "$NAME is not running."
        return 3
    fi
    if read pid < "$DHCPD_PID" && ps -p "$pid" > /dev/null 2>&1; then
        test "$1" != -v || echo "$NAME is running."
        return 0
    else
        test "$1" != -v || echo "$NAME is not running but $DHCPD_PID exists."
        return 1
    fi
}

case "$1" in
        start)
                test_config
                log_daemon_msg "Starting $DESC" "$NAME"
                start-stop-daemon --start --quiet --pidfile "$DHCPD_PID" \
                        --exec /usr/sbin/dhcpd -- \
                        -q $OPTIONS -cf "$DHCPD_CONF" -pf "$DHCPD_PID" $INTERFACES
                sleep 2

                if check_status -q; then
                        log_end_msg 0
                else
                        log_failure_msg "check syslog for diagnostics."
                        log_end_msg 1
                        exit 1
                fi
                ;;
        stop)
                log_daemon_msg "Stopping $DESC" "$NAME"
                start-stop-daemon --stop --quiet --pidfile "$DHCPD_PID"
                log_end_msg $?
                rm -f "$DHCPD_PID"
                ;;
        restart | force-reload)
                test_config
                $0 stop
                sleep 2
                $0 start
                if [ "$?" != "0" ]; then
                        exit 1
                fi
                ;;
        status)
                echo -n "Status of $DESC: "
                check_status -v
                exit "$?"
                ;;
        *)
                echo "Usage: $0 {start|stop|restart|force-reload|status}"
                exit 1 
esac

exit 0
史提芬

我也用实际的票来回答,但在15.10中...

看起来像/lib/systemd/system/isc-dhcp-server.service中的行:

exec dhcpd -user dhcpd -group dhcpd -f -4 -pf /run/dhcp-server/dhcpd.pid -cf $CONFIG_FILE $INTERFACES'

进行了硬编码,并忽略了/ etc / default / isc-dhcp-server中的DHCPD_PID变量。

我认为应该是:

exec dhcpd -user dhcpd -group dhcpd -f -4 -pf $DHCPD_PID -cf $CONFIG_FILE $INTERFACES'

更改之后,您必须运行

systemctl daemon-reload

然后,您必须在/ etc / default / isc-dhcp-server中设置该值,因为如果没有设置,则不会提供默认值,并且该服务将无法启动。

DHCPD_PID=/var/run/dhcp-server/dhcpd.pid

然后文件还有其他问题,就像它总是尝试运行一样:

ExecStartPre=/bin/chown dhcpd:dhcpd /run/dhcp-server

无论指定的路径如何。我不确定预期的行为是什么,但是那两个更改为我解决了。

但是之后

AppArmor正在阻止文件写入。我不是很熟悉,但是我添加了

capability dac_override,

到/etc/apparmor.d/usr.sbin.dhcpd附近的其他功能,重新启动服务,现在我有了一个PID文件。

看来这个软件包有几个问题。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

MySQL无法创建pid文件:权限被拒绝

来自分类Dev

为什么我会收到“无法创建 pid 文件...权限被拒绝”错误?

来自分类Dev

无法触摸`/var/run/myfile/myfile.pid':权限被拒绝

来自分类Dev

E / CameraService:权限被拒绝:无法使用相机pid = 9410,uid = 10230 CameraFragment

来自分类Dev

nginx:[emerg] open()“ /var/run/nginx.pid”失败(13:权限被拒绝)

来自分类Dev

文件创建权限被拒绝

来自分类Dev

权限被拒绝的错误与phantomjs

来自分类Dev

Firebase权限被拒绝错误

来自分类Dev

获取权限被拒绝错误

来自分类Dev

执行错误-权限被拒绝

来自分类Dev

权限被拒绝的错误与phantomjs

来自分类Dev

传输“权限被拒绝”错误

来自分类Dev

sudo错误权限被拒绝

来自分类Dev

回形针:权限被拒绝错误

来自分类Dev

Ubuntu:权限被拒绝错误

来自分类Dev

权限被拒绝错误laravel

来自分类Dev

rsync错误权限被拒绝

来自分类Dev

无法登录-权限被拒绝

来自分类Dev

权限被拒绝删除文件

来自分类Dev

权限被拒绝删除文件

来自分类Dev

cp:无法创建常规文件:权限被拒绝

来自分类Dev

无法更改/ usr / bin权限-权限被拒绝

来自分类Dev

Git stash pop 错误:无法创建文件权限被拒绝

来自分类Dev

服务启动和权限被拒绝

来自分类Dev

错误:拒绝访问属性“ $”的权限

来自分类Dev

Firebase错误->代码=权限被拒绝

来自分类Dev

Nutch Crawler错误:权限被拒绝

来自分类Dev

错误:拒绝访问属性“ $”的权限

来自分类Dev

Windows 7权限被拒绝错误