chmod 711 /sbin/nu
Листинг 3.2. Сценарий nu
# !/bin/bash
# nu (New User) — Сценарий добавления пользователей.
# Группа по умолчанию
GROUP=100
# Оболочка по умолчанию
SHELL=/bin/bash
# Префикс для домашнего каталога
HOME=/home
# Время окончания действия пароля (дни)
EXPIRE=30
# Минимальное количество дней до смены пароля
DAYS=0
# За 5 дней предупреждаем пользователя
WARN=5
WHOAMI=`/usr/bin/whoami`
if [ $WHOAMI!="root" ]; then
echo "Access violation."
exit 1
fi
echo –n "Enter new name: "
read USERNAME
echo –n "Enter full name: "
read FULLNAME
adduser –c "$FULLNAME" –d $HOME/$USERNAME –e $EXPIRE
–g $GROUP –S $SHELL $USERNAME
passwd –n $DAYS –w $WARN $USERNAME
passwd $USERNAME
4.1. Файлы и каталоги. Дерево каталогов
В свое время, при использовании DOS вводилось определение файла как поименованной области данных на диске — на то DOS и дисковая операционная система. В Linux понятие файла значительно расширено. Практически все, с чем вы имеете дело в Linux, является файлом. Команды, которые вы вводите с клавиатуры, — это файлы, которые содержат программы. Устройства вашего компьютера – это тоже файлы. Грубо говоря, файл — это последовательность битов, а жесткий диск — просто смесь нулей и единиц. Linux представляет биты так, как вам понятно, и в этом заключается одна из ее основных функций — управление файловой системой. Файловая система — способ организации и представления битов на жестком диске.
Большинство файловых систем Unix-подобных операционных систем сходны между собой. Файловая система Linux — ext2 (ext3) — очень похожа на файловую систему ufs. К основным понятиям файловых систем в мире unix относятся:
1. Блок загрузки (boot block).
2. Суперблок (superblock).
3. Индексный (информационный) узел (inode).
4. Блок данных (data block).
5. Блок каталога (directory block).
6. Косвенный блок (indirection block).
Блок загрузки содержит программу для первоначального запуска Unix.
В суперблоке содержится общая информация о файловой системе. В суперблоке также содержится информация о количестве свободных блоков и информационных узлов. Для повышения устойчивости создается несколько копий суперблока, но при монтировании используется только одна. Если первая копия суперблока повреждена, то используется его резервная копия.
В индексном (информационном) узле хранится вся информация о файле, кроме его имени. Имя файла и его дескриптор (номер информационного узла — inode) хранятся в блоке каталога. В информационном узле есть место только для хранения нескольких блоков данных. Если же нужно обеспечить большее количество, то в этом случае динамически выделяется необходимое пространство для указателей на новые блоки данных. Такие блоки называются косвенными. Для того, чтобы найти блок данных, нужно найти его номер в косвенном блоке.
Файловая система ext2 имеет следующую структуру (см. рис. 4.1):
1. Суперблок.
2. Описатель группы.
3. Карта блоков.
4. Карта информационных узлов.
5. Таблица информационных узлов.
6. Блоки данных.
Рис. 4.1. Структура файловой системы
Суперблок, как уже отмечалось выше, содержит информацию обо всей файловой системе. Он имеется в каждой группе блоков, но это всего лишь копия суперблока первой группы блоков: так достигается избыточность файловой системы.
Описатель (дескриптор) группы содержит информацию о группе блоков. Каждая группа имеет свой дескриптор группы. Карты блоков и информационных узлов — это массивы битов, которые указывают на блоки или информационные узлы соответственно. Таблица информационных узлов содержит информацию о выделенных для данной группы блоков в информационных узлах.
Блоки данных — это блоки, содержащие реальные данные.
Что касается файлов, то в операционной системе Linux существует четыре типа файлов:
1. Файлы устройств.
2. Каталоги.
3. Обычные файлы.
4. Ссылки.
Файлы устройств представляют собой устройства вашего компьютера. Файлы устройств находятся в каталоге /dev. Например, /dev/ttyS0 — первый последовательный порт (СОМ1). Обычные файлы, в свою очередь, делятся на нормальные (текстовые) и двоичные.
Каталоги — это специальные файлы, содержащие информацию о других файлах (файлах устройств (/dev), обычных файлов и ссылок). Конечно, это довольно грубое определение, скорее интуитивное, чем точное.
Ссылки позволяют хранить один и тот же файл, но под разными именами. Немного позже мы поговорим более подробно о ссылках, а сейчас рассмотрим команды для работы с файлами и каталогами. Максимальная длина имени файла составляет 254 символа. Имя может содержать практически любые символы, кроме: / ? > < | " *
В своей работе я не рекомендую использовать слишком длинные, а также русскоязычные имена файлов. Linux чувствительна к регистру символов, поэтому file.txt, FILE.TXT и File.txt — совершенно разные имена файлов, и данные файлы могут находиться в одном каталоге. Понятие «расширение файла» в Linux отсутствует. Напомню, что в DOS имена файлов строились по схеме 8+3: 8 символов — для имени и 3 — для расширения. Расширением (или типом в терминологии Windows) называется последовательность символов после точки.
Свойства файловой системы ext2:
Максимальный размер файловой системы 4 Тбайт Максимальный размер файла 2 Гбайт Максимальная длина имени файла 255 символов Минимальный размер блока 1024 байт Количество выделяемых индексных дескрипторов 1 на 4096 байт раздела
4.2. Команды для работы с файлами и каталогами
4.2.1. Команды для работы с файлами
Прежде чем приступить к описанию команд для работы с файлами, необходимо отметить, что для выполнения операций над файлами вы должны иметь права доступа к этим файлам. О правах доступа будет написано ниже, а здесь предполагается, что пользователь имеет права доступа к используемым файлам.
Создание и просмотр файла
Для просмотра файла обычно используется команда cat. Например:
$ cat file.txt
При этом на стандартный вывод, то есть на ваш терминал, будет выведен файл file.txt. Однако более удобными командами для просмотра файлов являются команды more или less:
$ less file.txt
Создать файл можно так:
$ cat > file.txt
Здесь используется перенаправление ввода/вывода, о котором подробно сказано в гл. 5. Данные со стандартного ввода (клавиатуры) перенаправляются в файл file.txt. Проще говоря все, что вы после этой команды введете с клавиатуры, будет записано в файл file.txt. Чтобы закончить ввод нажмите Ctrl+D. Помните, что вы не сможете создать файл в каталоге, к которому у вас нет доступа. Вы даже не сможете просмотреть файл, если пользователь, которому этот файл принадлежит, запретил чтение этого файла.
Копирование файла
Для копирования файлов в ОС Linux используется команда cp, которая имеет следующий формат вызова:
$ cp [параметры] источник назначение
Рассмотрим несколько примеров:
$ cp file.txt file2.txt
$ cp file.txt /home/user/text/
В первом случае выполняется копирование файла file.txt в файл file2.txt. Оба файла находятся в текущем каталоге. Во втором случае — копирование файла file.txt в каталог /home/user/text/.
Напомню, что вы можете использовать точку ( . ) в качестве ссылки на текущий каталог, символ тильды ( ~ ) — на домашний каталог. Родительский каталог обозначается двумя точками ( .. ). Корневой каталог обозначается символом косой черты ( / ). Параметры команды cp указаны в табл. 4.1.
Параметры команды cp Таблица 4.1
Параметр Описание -а При копировании сохраняются атрибуты файлов -b Создание копии вместо перезаписи существующего файла -d Поддержка символических ссылок. При этом копироваться будут сами символические ссылки без файлов, на которые они указывают -i Перед перезаписью существующего файла от пользователя потребуется подтверждение этого -l Создание жестких ссылок вместо копирования (при копировании в каталог) -r Копирование каталога вместе с подкаталогами -s Создание символических ссылок вместо копирования (при копировании в каталог) -u Не перезаписывать, если перезаписываемый файл имеет более позднюю дату модификации -v Вывод сведений обо всех выполняемых действиях (verbose). Выводит имена всех копируемых файлов -x Игнорировать каталоги, расположенные в других файловых системах, по отношению к системе, откуда выполняется копирование Переименование и перемещение файлов
Команда mv перемещает или переименовывает файлы. Например: