umask является значением, которое является в основном дополнением значения разрешения по умолчанию. Так, если umask показывает 002, который означает, что разрешение по умолчанию 775. Другие примеры для лучшего понимания включают umask=000 => perms=777 или umask=777 => perms=000.
Если вам нужна команда, которую нужно выполнить на ранней стадии процесса загрузки (все еще в режиме одиночного пользователя), добавьте ее в скрипт оболочки /etc/rc. early
что-то вроде fsck -fy /
, добавленного в этот файл, заставит его выполнить сканирование и ответить "да" на все подсказки.
Не забудьте удалить его из rc.early
, когда закончите, иначе он будет выполняться при каждом запуске
Начиная с FreeBSD 10.3, вы можете добиться этого, временно изменив /etc/rc.d/root
для запуска / sbin / fsck -fy /
.
Вот текущий сценарий, измененный, чтобы включить эту команду в закомментированную форму; раскомментируйте, чтобы выполнить fsck.
#!/bin/sh
#
# $FreeBSD: stable/10/etc/rc.d/root 177062 2008-03-11 17:21:14Z delphij $
#
# PROVIDE: root
# REQUIRE: fsck
# KEYWORD: nojail
. /etc/rc.subr
name="root"
start_cmd="root_start"
stop_cmd=":"
root_start()
{
# root normally must be read/write, but if this is a BOOTP NFS
# diskless boot it does not have to be.
#
case ${root_rw_mount} in
[Nn][Oo] | '')
;;
*)
# Uncomment the below line to run fsck on root during boot:
#/sbin/fsck -fy /
if ! mount -uw /; then
echo 'Mounting root filesystem rw failed, startup aborted'
stop_boot true
fi
;;
esac
umount -a >/dev/null 2>&1
# If we booted a special kernel remove the record
# so we will boot the default kernel next time.
if [ -x /sbin/nextboot ]; then
/sbin/nextboot -D > /dev/null 2>&1
fi
}
load_rc_config $name
run_rc_command "$1"
Во FreeBSD правильно работает принудительное размонтирование, так что вам не нужно делать это при загрузке. Просто войдите в систему (удаленно ), перемонтируйте rootfs как для чтения -только (mount -fur /
), выполните fsck вручную(fsck -y /
)и затем перезагрузите машину.
/etc/rc.initial.reboot
использует команду nextboot
для перезагрузки цикла fsck
5 раз:
/sbin/nextboot -e "pfsense.fsck.force=5"
Вы можете запустить это вручную или добавить в любой скрипт, чтобы срабатывать fsck
при следующей загрузке.
Я тестировал это в версии 2.5.0.