Администратор Linux - Управление файлами / папками

Чтобы представить разрешения, которые применяются как к каталогам, так и к файлам в CentOS Linux, давайте посмотрим на следующий вывод команды.

[centos@centosLocal etc]$ ls -ld /etc/yum* 
drwxr-xr-x. 6 root root 100 Dec  5 06:59 /etc/yum 
-rw-r--r--. 1 root root 970 Nov 15 08:30 /etc/yum.conf 
drwxr-xr-x. 2 root root 187 Nov 15 08:30 /etc/yum.repos.d

Note - Вы увидите три основных типа объектов:

  • "-" - черточка для простого файла

  • "d" - для справочника

  • "l" - для символьной ссылки

Мы сосредоточимся на трех блоках вывода для каждого каталога и файла -

  • drwxr-xr-x: корень: корень
  • -rw-r - r--: корень: корень
  • drwxr-xr-x: корень: корень

Теперь давайте разберемся с этим, чтобы лучше понять эти строки -

d Означает, что тип объекта - это каталог
rwx Указывает права доступа к каталогу, примененные к владельцу
rx Указывает разрешения каталога, примененные к группе
rx Указывает права доступа к каталогу, примененные к миру
корень Первый экземпляр указывает владельца каталога.
корень Второй экземпляр указывает группу, к которой применяются разрешения группы.

Важно понимать разницу между владельцем , группой и миром . Непонимание этого может иметь большие последствия для серверов, на которых размещаются службы в Интернете.

Прежде чем привести реальный пример, давайте сначала разберемся с разрешениями, которые применяются к каталогам и файлам .

Взгляните на следующую таблицу и продолжайте выполнение инструкций.

Восьмеричный Символический Пермь. Каталог
1 Икс Выполнить Войдите в каталог и получите доступ к файлам
2 ш Написать Удалить или изменить файлы в каталоге
4 р Читать Перечислить файлы в каталоге

Note- Когда файлы должны быть доступны для чтения в каталоге, обычно применяются разрешения на чтение и выполнение . В противном случае у пользователей возникнут трудности с работой с файлами. Отключение записи гарантирует, что файлы нельзя: переименовать, удалить, скопировать или изменить разрешения.

Применение разрешений к каталогам и файлам

При применении разрешений необходимо понимать две концепции:

  • Символические разрешения
  • Восьмеричные разрешения

По сути, все они одинаковы, но по-разному относятся к файлам и назначают права доступа к ним. Чтобы получить краткое руководство, изучите и обратитесь к следующей таблице -

Читать Написать Выполнить
Octal 4 2 1
Symbolic р ш Икс

При назначении разрешений с помощью octalиспользуйте 3-байтовое число, например: 760. Число 760 переводится как: Владелец: rwx; Группа: rw; Других (или мировых) разрешений нет.

Другой сценарий: 733 переводится как: Владелец: rwx; Группа: wx; Другое: wx.

Есть один недостаток разрешений с использованием метода Octal. Существующие наборы разрешений изменить нельзя. Возможно только переназначить весь набор разрешений объекта.

Теперь вы можете задаться вопросом, а что плохого в том, чтобы всегда повторно назначать разрешения? Представьте себе большую структуру каталогов, например / var / www / на рабочем веб-сервере. Мы хотим рекурсивно убрать бит w или записи во всех каталогах для Other. Таким образом, вынуждая его активно добавлять только тогда, когда это необходимо для мер безопасности. Если мы повторно назначим весь набор разрешений, мы отнимем все другие настраиваемые разрешения, назначенные каждому подкаталогу.

Следовательно, это вызовет проблемы как для администратора, так и для пользователя системы. В какой-то момент человеку (или лицам) потребуется повторно назначить все настраиваемые разрешения, которые были уничтожены путем повторного назначения всего набора разрешений для каждого каталога и объекта.

В этом случае мы хотели бы использовать символический метод для изменения разрешений -

chmod -R o-w /var/www/

Приведенная выше команда не будет «перезаписывать разрешения», но изменяет текущие наборы разрешений. Так что привыкайте использовать лучшие практики

  • Octal только для назначения разрешений
  • Символический для изменения наборов разрешений

Важно, чтобы администратор CentOS обладал как восьмеричными, так и символьными разрешениями, поскольку разрешения важны для целостности данных и всей операционной системы. Если разрешения неверны, конечным результатом будут как конфиденциальные данные, так и вся операционная система будет скомпрометирована.

После этого давайте рассмотрим несколько команд для изменения разрешений и владельцев / участников объекта:

  • chmod
  • chown
  • chgrp
  • umask

chmod: изменить биты разрешения файлового режима

Команда Действие
-c Как подробный, но будет сообщать только о внесенных изменениях
-v Подробно, выводит диагностику по каждому сделанному запросу
Рекурсивно применяет операцию к файлам и каталогам

chmod позволит нам изменять права доступа к каталогам и файлам, используя восьмеричные или символьные наборы разрешений. Мы будем использовать это, чтобы изменить наши назначения и каталоги загрузки.

chown: изменить владельца файла и группу

Команда Действие
-c Как подробный, но будет сообщать только о внесенных изменениях
-v Подробно, выводит диагностику по каждому сделанному запросу
Рекурсивно применяет операцию к файлам и каталогам

chown может изменять как владельца, так и группу объектов. Однако, если нет необходимости изменять оба одновременно, использование chgrp обычно используется для групп.

chgrp: изменить групповое владение файлом или каталогом

Команда Действие
-c Как подробный, но будет сообщать только об изменениях
-v Подробно, выводит диагностику для каждого сделанного запроса
Рекурсивно применяет операции к файлам и каталогам

chgrp изменит владельца группы на указанного.

Реальная практика

Давайте изменим все назначения подкаталогов в / var / www / student /, чтобы группа-владелец стала группой студентов . Затем назначьте корень студентов группе профессоров. Позже сделайте доктора Терри Томаса владельцем справочника студентов , так как ему поручено отвечать за все академические круги информатики в школе.

Как мы видим, при создании каталог остается довольно сырым.

[root@centosLocal ~]# ls -ld /var/www/students/ 
drwxr-xr-x. 4 root root 40 Jan  9 22:03 /var/www/students/

[root@centosLocal ~]# ls -l /var/www/students/ 
total 0 
drwxr-xr-x. 2 root root 6 Jan  9 22:03 assignments 
drwxr-xr-x. 2 root root 6 Jan  9 22:03 uploads 

[root@centosLocal ~]#

Как администраторы, мы никогда не хотим никому передавать наши корневые учетные данные. Но в то же время мы должны предоставить пользователям возможность выполнять свою работу. Итак, позвольте доктору Терри Томасу взять на себя больший контроль над файловой структурой и ограничить возможности учащихся.

[root@centosLocal ~]# chown -R drterryt:professors /var/www/students/ 
[root@centosLocal ~]# ls -ld /var/www/students/ 
drwxr-xr-x. 4 drterryt professors 40 Jan  9 22:03 /var/www/students/

[root@centosLocal ~]# ls -ls /var/www/students/ 
total 0 
0 drwxr-xr-x. 2 drterryt professors 6 Jan  9 22:03 assignments 
0 drwxr-xr-x. 2 drterryt professors 6 Jan  9 22:03 uploads

[root@centosLocal ~]#

Теперь у каждого каталога и подкаталога есть владелец drterryt, а группа-владелец - профессора . Поскольку каталог заданий предназначен для студентов, которые могут сдавать назначенные им работы, давайте уберем возможность перечислять и изменять файлы из группы студентов .

[root@centosLocal ~]# chgrp students /var/www/students/assignments/ && chmod 
736 /var/www/students/assignments/

[root@centosLocal assignments]# ls -ld /var/www/students/assignments/ 
drwx-wxrw-. 2 drterryt students 44 Jan  9 23:14 /var/www/students/assignments/

[root@centosLocal assignments]#

Студенты могут копировать задания в каталог заданий . Но они не могут отображать содержимое каталога, копировать текущие файлы или изменять файлы в каталоге назначений . Таким образом, он просто позволяет студентам отправлять выполненные задания. Файловая система CentOS предоставит отметку даты сдачи назначений.

Как владелец каталога заданий -

[drterryt@centosLocal assignments]$ whoami 
drterryt

[drterryt@centosLocal assignments]$ ls -ld /var/www/students/assignment 
drwx-wxrw-. 2 drterryt students 44 Jan  9 23:14 /var/www/students/assignments/

[drterryt@centosLocal assignments]$ ls -l /var/www/students/assignments/ 
total 4 
-rw-r--r--. 1 adama  students  0 Jan  9 23:14 myassign.txt 
-rw-r--r--. 1 tammyr students 16 Jan  9 23:18 terryt.txt

[drterryt@centosLocal assignments]$

Мы видим, что владелец каталога может отображать файлы, а также изменять и удалять файлы.

Команда umask: предоставляет режимы по умолчанию для прав доступа к файлам и каталогам по мере их создания

umask - важная команда, которая предоставляет режимы по умолчанию для разрешений для файлов и каталогов по мере их создания.

Разрешения umask используют унарную логику с отрицанием.

Разрешение Операция
0 Читать, писать, выполнять
1 Прочитайте и напишите
2 Прочтите и выполните
3 Только чтение
4 Прочтите и выполните
5 Только писать
6 Только выполнить
7 Нет разрешений
[adama@centosLocal umask_tests]$ ls -l ./ 
-rw-r--r--. 1 adama students 0 Jan 10 00:27 myDir 
-rw-r--r--. 1 adama students 0 Jan 10 00:27 myFile.txt

[adama@centosLocal umask_tests]$ whoami 
adama

[adama@centosLocal umask_tests]$ umask 
0022

[adama@centosLocal umask_tests]$

Теперь давайте изменим umask для нашего текущего пользователя и создадим новый файл и каталог.

[adama@centosLocal umask_tests]$ umask 077

[adama@centosLocal umask_tests]$ touch mynewfile.txt

[adama@centosLocal umask_tests]$ mkdir myNewDir

[adama@centosLocal umask_tests]$ ls -l 
total 0 
-rw-r--r--. 1 adama students 0 Jan 10 00:27 myDir 
-rw-r--r--. 1 adama students 0 Jan 10 00:27 myFile.txt 
drwx------. 2 adama students 6 Jan 10 00:35 myNewDir 
-rw-------. 1 adama students 0 Jan 10 00:35 mynewfile.txt

Как мы видим, вновь созданные файлы имеют немного более строгие ограничения, чем раньше.

umask для пользователей необходимо изменить либо в -

  • /etc/profile
  • ~/bashrc
[root@centosLocal centos]# su adama 
[adama@centosLocal centos]$ umask 
0022 
[adama@centosLocal centos]$

Как правило, маска umask по умолчанию в CentOS подойдет. Когда у нас возникают проблемы со значением по умолчанию 0022 , обычно это происходит тогда, когда разные отделы, принадлежащие к разным группам, должны сотрудничать над проектами.

Здесь появляется роль системного администратора, чтобы сбалансировать работу и дизайн операционной системы CentOS.