Оперциаонные системы ASP Linux и Windows

Знакомство с графическим интерфейсом ASP Linux, его основные преимущества и недостатки, разработка навыков работы с сервисным и прикладным программным обеспечением этой системы. сравнительный анализ функциональных возможностях изученной среды и Windows.

Рубрика Программирование, компьютеры и кибернетика
Вид методичка
Язык русский
Дата добавления 12.09.2008
Размер файла 1,6 M

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.

команда --help

Например: exit --help - выведет справку по команде exit.

cd имя_директории- смена текущего каталога. В качестве имени директории можно указывать элементы "." и "..".

mkdir имя_директории - создание каталога. Вновь созданный каталог не содержит элементов, за исключением "." (ссылка на текущий каталог) и ".." (ссылка на вышележащий каталог).

rmdir имя_директории - удаление каталога.

ls [-alrstu] [namedir] - вывод содержимого каталога; если в качестве namedir указано имя файла, то выдается вся информация об этом файле. Если аргумент не указан, выдается содержимое текущего каталога.

Значения некоторых аргументов:

- l - список включает всю информацию о файлах;

- F - добавление к имени каталога символа / и символа * к имени файла, для которых разрешено выполнение;

- a - в список включаются все файлы, в том числе и те, которые начинаются с точки;

- i - указать идентификационный номер каждого файла;

- R - рекурсивный вывод содержимого подкаталогов заданного каталога.

find список_каталогов условия_поиска -определение полных имен файлов в поддереве каталогов, удовлетворяющих заданным условиям поиска.

В команде может быть задано до 18 условий_поиска. Необходимые комбинации условий объединяются в булевское выражение с помощью элементарных логических операций ('элементарных логических функций). Таким образом формируется логическая функция, принимающая истинное значение если значения всех её составляющих истины.

На экран выводятся полные маршрутные имена файлов, свойства которых обеспечивают истинность этой функции.

Элементарные логические функции:

! <условие> отрицание условия;

<пробел> соответствует операции "И";

-o операция "ИЛИ";

\( выражение \) булевское выражение в скобках.

При описании команды используются обозначения:

n положительное десятичное число;

-n любое положительное десятичное число, строго меньшее n;

+n любое положительное десятичное число, строго большее n.

Условия задаются следующими опциями:

-name'имя_файла' истинно для файлов с указанным именем.

-perm <8-ричный_код> истинно для файлов с указанным кодом прав доступа.

-type {f|d|b|c|p} истинно для файлов указанного типа.

-links n истинно для файлов с числом ссылок n.

-user <имя_пользователя> истинно для файлов, принадлежащих данному пользователю.

-size n[c] истинно для файлов с длиной n (число блоков) или с - в символах (байтах).

-exec <команда> {} \; истинно, если команда возвращает нулевой код завершения (true), т.е. опция выполняет <команда> для каждого найденного файла.

Все аргументы команды find разделяются пробелами.

Примеры использования команды find:

1) команда выводит на экран список файлов с именами fil или файлов у которых имя владельца petr:

find / --name “fil.*” -o -user petr -exec cat {} \;

2) поиск файлов, не являющихся директориями в текущем каталоге и его подкаталогах:

find * !-type d

3) команда осуществит поиск в корневом каталоге всех директорий, на которые существуют более трех жестких ссылок:

find / -type d -links +3

grep [-ключи] 'шаблон' <список_файлов> - поиск в файлах из списка_файлов строк, содержащих указанный шаблон (подстрока символов).

Ключи определяют режимы поиска и вывода:

-c выводятся имена всех просмотренных файлов и количество найденных строк, содержащих шаблон;

-n перед каждой строкой выводится ее относительный номер в файле и сама строка;

-i игнорируются регистры;

-l выводятся только имена файлов, содержащие найденные строки и др.

Например:

grep -c 'aaa' *

””””””””

f.1: 10

f.2: 3

f.3: 1

””””””””

В рассмотренном примере выводятся все имена файлов текущего каталога, содержащих подстроку aaa и количество таких строк в каждом из них.

В нижеследующем примере выводятся только имена файлов, содержащих строки с шаблоном aaa.

$ grep -n bbb * <NewLine>

””””””””””””””””””””””””””””

f.1: 5: aaaaaabbbbaaacc

f.2: 2: bbbbbbbbbbbbbbbbbbbb

f.6: 1: bbb

””””””””””””””””””””””””””””

Практическая работа №2(1) Основные команды работы с каталогами

Цель работы:
1. Изучить архитектуру и принципы функционирования многопользовательской многозадачной операционной системы Linux
2. Изучить основные команды работы с каталогами ОС Linux
Порядок выполнения работы
Изучаются команды:
mkdir - создание каталога;
rmdir - удаление каталога;
cd - перемещение по дереву каталогов;
pwd - определение текущего каталога;
ls - просмотр содержимого каталога;
more - постраничный вывод информации;
man - вызов руководства по команде.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Изучить команды работы с каталогами, для этого выведите на экран Терминала справку по следующим командам: pwd, mkdir, rmdir, cd, ls. Назначение и формат команд приведите в отчете.
3) Определите Ваш текущей каталог. Просмотрите его содержимое и приведите его в отчете.
4) Перейдите в каталог Вашей группы и создайте в нем личный каталог.
5) Определите уникальное имя (номер индексного указателя) Вашего личного каталога. Объясните структуру полного маршрутного имени каталога.
6) Создайте два поддерева из одного и из двух каталогов в каталоге Вашей группы. Используя команду ls, проверьте факт построения дерева подкаталогов.
7) Просмотрите содержимое пустых подкаталогов, т.е. новых подкаталогов, не содержащих файлов. Объясните их содержание.
8) Сделайте текущим последний каталог меньшего поддерева. Определите его полное маршрутное имя.
9) Уничтожьте все подкаталоги большего поддерева каталогов. Получите подтверждение выполнения команд.
10) Выведите на экран содержимое корневого каталога. Приведите его в отчете. Какие каталоги расположены в корневой директории, каково их назначение?
11) Завершите сеанс работы с системой.

Практическая работа №2(2) Поиск файлов в системе каталогов

Цель работы:
1. Изучить архитектуру и принципы функционирования многопользовательской многозадачной операционной системы Linux
2. Научиться осуществлять поиск файлов в системе каталогов
Порядок выполнения работы
Изучаются команды:
find - поиск файлов в системе каталогов
more - постраничный вывод информации;
man - вызов руководства по команде;
grep - поиск в файлах указанный шаблон;
еxit - выход из терминала;
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Изучить команды работы с каталогами, для этого выведите на экран Терминала справку по следующим командам: find, grep. Назначение и формат команд приведите в отчете.
3) Установите в качестве текущего HOME-каталог.
4) Найдите обычные файлы с определением их полных маршрутных имен.
5) Осуществите поиск файлов типа директория в Вашем личном каталоге.
6) Найдите в текущем каталоге все файлы, на которые имеются жесткие ссылки.
7) Найдите файлы блок-ориентированного типа из каталога /dev и его подкаталогов.
8) Осуществите поиск обычных файлов на диске, размер которых не превышает 2 Кб.
9) Задайте различные комбинации известных Вам условий поиска файлов и каталогов.
10) Выведите на экран принадлежащую Вам регистрационную запись с использованием команды grep.
11) Завершите сеанс работы с системой.

2.1.4. Команды работы с файлами: управление файлами, генерация имен файлов

Управление файлами

Ниже приведены форматы команд, использующихся для управления файлами:

>маршрутное-имя-файла - создание пустого файла.

cat имя-файла  - вывод содержимого файла на экран.

cat>имя-файла  - перенаправление информации, вводимой с клавиатуры с заменой содержимого файла.

cat [входной файл 1] [входной_файл2] […входной файл N] > [выходной_файл] - слияние файлов

grep [-ключи] 'шаблон' <список_файлов> -поиск в файлах из списка_файлов строк, содержащих указанный шаблон (подстрока символов).

Ключи определяюobt режимы поиска и вывода:

-c выводятся имена всех просмотренных файлов и количество

найденных строк, содержащих шаблон;

-n перед каждой строкой выводится ее относительный номер в

файле и сама строка;

-i игнорируются регистры;

-l выводятся только имена файлов, содержащие найденные строки и др.

touch [-k] имя-файла - замена времени модификации на текущее, если файл не существует, то создается новый пустой файл. Команда может использоваться для создания новых пустых файлов, если указать имя несуществующего файла.

wc [-lwc] список_файлов - подсчет количества строк (-l), слов (-w), или символов (-c) в указанных файлах.

cp [-k] вх_файл_1 [вх_файл_2 [... вх_файл_n]] вых_файл - копирование файлов.

В самом формате команды заложено два режима ее использования:

1-й: Если вых_файл - обычный файл, то вх_файл может быть только один; в этом случае содержимое вх_файла копируется в вых_файл. Если вых_файл существовал, то его содержимое полностью заменяется на новое, атрибуты защиты сохраняются. Если создается новый вых_файл, то ему присваиваются атрибуты копируемого.

2-й: Если вых_файл - каталог, то в него последовательно копируются все указанные вх_файлы со своими атрибутами и именами, но каталог при этом автоматически не создается.

Примеры использования команды cp:

Создается новый файл FIL.c в том же текущем головном каталоге. Для копирования в другой каталог необходимо указать маршрутное имя выходного файла:

cd

cp fil.c FIL.c

Входной файл fil.c сохраняется в исходном текущем каталоге:

mkdir petr

mkdir lev1

cp fil.c lev1/prog.c

Групповые операции над файлами при копировании:

cp f.? fildir

cp f.[1-3] fildir

cp f.[123] fildir

mv [-k] вх_ф йл_1 [вх_ф йл_2 [... вх_ф йл_n]] вых_файл - перемещение или переименование файлов

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

Генерация имен файлов и каталогов (Pathname Expansion)

Подстановки имен путей и файлов (Pathname expansion) используются для того, чтобы с помощью краткого образца или шаблона указать несколько имен файлов (или каталогов), соответствующих данному шаблону.

Специальные символы шаблонов имеют следующее значение.

Таблица 2.1.4. Символы шаблонов

Символ

Правила замены

*

Соответствует произвольной строке символов, включая пустую строку. Например, my*.txt будет заменено на myday.txt, myweek.txt и mymonth.txt (если такие файлы существуют), а *.jpg соответствует всем файлам с расширением jpg в указанном каталоге

?

Соответствует любому одиночному символу. Например, вместо шаблона file?.txt будут подставлены имена file1.txt и filex.txt, но не file10.txt

[...]

Соответствует любому символу из числа символов, указанных в скобках. Пары символов, разделенные знаком минуса, обозначают интервал; любой символ стоящий лексически между этими двумя символами, включая и символы, задающие интервал, соответствует шаблону. Если первым символом внутри скобок является ! или ^, то считается, что шаблону (в данной позиции) соответствуют все символы, не указанные в скобках

Шаблоны имен файлов очень часто применяются в командных строках, содержащих команду ls. Представьте себе, что вы хотите просмотреть информацию о содержимом каталога, в котором находится огромное количество разных файлов различных форматов, например, файлов с изображениями форматов gif, jpeg, avi и т. д.. Чтобы получить только список файлов формата jpeg, вы можете использовать команду

[user]$ ls *.jpg

Если в каталоге имеется множество файлов, имена которых представлены четырехзначными номерами, то следующей командой можно вывести только список файлов с номерами от 0200 до 0499:

[user]$ ls -l 0[2-4]??.*

Практическая работа №3(1). Команды управления фалами

Цель работы:
1. Изучить основные команды работы с файлами ОС Linux
2. Научиться создавать, объединять, удалять, переименовывать файлы.
Порядок выполнения работы
Изучаются команды:
cat - слияние и вывод файлов на стандартное устройство вывода(конкатенация файлов);
rm - удаление файла;
mv - переименование файла;
сp - копирование файлов;
wc - подсчет количества строк и слов в файле.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Изучите команды работы с файлами, для этого выведите на экран Терминала справку по следующим командам: cat, rm, mv, cp, wc. Назначение и формат команд приведите в отчете.
3) Перейдите в Ваш личный каталог и выведете на экран его содержимое.
4) Создайте 3-4 текстовых файла с частично совпадающими именами. Проанализируйте значения атрибутов Ваших файлов.
5) Создайте еще один файл методом слияния из существующих. Как изменились атрибуты нового файла?
6) Создайте два новых параллельных подкаталога.
7) В один подкаталог скопируйте имеющиеся файлы HOME-каталога с изменением имен, а в другой - переместите. Проанализируйте как изменилось содержание всех трех каталогов и каковы атрибуты всех полученных файлов.
8) Удалите созданные текстовые файлы и каталоги. Выйдите из программы Терминал.

Практическая работа №3(2) Использование шаблонов в именовании файлов

Цель работы:
1. Изучить понятие шаблона, способы задания шаблонов файлов
2. Научиться осуществлять просмотр директорий, копирование, удаление, и поиск файлов, используя шаблоны файлов.
Порядок выполнения работы
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Осуществите поиск всех файлов в домашнем каталоге, которые имеют расширение txt.
3) Осуществите поиск директорий, в составе имени которых, имеется любой однозначное число.
4) Осуществите в корневом каталоге поиск всех файлов, содержащих в составе имени слово linux.
5) Создайте в Вашем личном каталоге структуру каталогов, содержащих совпадающие имена.
6) Просмотрите содержимое файлов домашнего каталога с частично совпадающими именами с использованием механизма генерации имен файлов.
7) Просмотрите содержимое файлов каталога /dev с частично совпадающими именами с использованием механизма генерации имен файлов.
8) С использованием механизма генерации имен файлов слейте содержимое всех файлов в один и поместите его в HOME-каталог. Проанализируйте содержание файла.
9) С использованием механизма генерации имен файлов слейте содержимое всех файлов в один и поместите его в HOME-каталог. Проанализируйте содержание файла.
10) С использованием механизма генерации имен скопируйте из Вашего личного каталога все файлы с частично совпадающими именами в домашний каталог.
11) С использованием механизма генерации имен удалите в Вашем личном каталоге все файлы с частично совпадающими именами.
12) С использованием механизма генерации имен удалите в Вашем личном каталоге все каталоги с частично совпадающими именами.
13) Удалите из домашнего каталога скопированные ранее файлы и завершите работу с программой Терминал.

2.1.7. Команды работы с файлами: ссылки, сортировка файлов

ln [-ключ] вх_файл_1 [вх_файл_2 [... вх_файл_n]] вых_файл - организация новых ссылок на файл.

В формате команды заложено 2 режима ее использования:

1-й: Если вых_файл - обычный файл, то допускается только один вх_файл_1; в этом случае на н равным именам: вх_файл_1 и вых_файл.

Количество ссылок на файл в его описателе увеличивается на 1.

2-й: Если вых_файл - каталог, то в нем создаются элементы, включающие имена перечисленных в команде входных файлов и ссылки на них, после чего в каталоге вых_файл можно работать с этими файлами, как с файлами этого каталога.

Возможно создание символьных и жестких ссылок.

При создании жесткой ссылки ключ в команде не указывается. Символьная ссылка создается командой ln с ключом s. Символьная ссылка ссылается на полное имя файла, жесткая - на его инод (числовой номер, присеваемый файлу при его создании).

Обобщение свойств команды ln при создании жесткой ссылки:

каждая ссылка на входной файл добавляет +1 к числу ссылок входного файла, после чего к упомянутому файлу можно обращаться по двум именам;

все связанные файлы имеют совпадающие описатели в каталогах;

если изменяется содержимое одного из связанных файлов, то меняется содержимое всех связанных файлов, т.к. связанные файлы разделяют одни и те же данные на диске;

если удалить один из связанных файлов, то сокращается число взаимных ссылок на -1.

ls [-alrstu] [namedir]  - вывод содержимого каталога; если в качестве namedir указано имя файла, то выдается вся информация об этом файле. Если аргумент не указан, выдается содержимое текущего каталога.

Значения некоторых аргументов:

- t - сортировка по времени модификации файлов;

- v - сортировка файлов по времени последнего доступа;

- с - использовать время создания файла при сортировке;

- s - размеры файлов указываются в блоках;

sort [-k номер-поля-в-строке] [список-файлов] - алфавитная и числовая сортировка файлов или строк файлов; режим сортировки определяется ключами. Команда многофункциональная, предусматривает много режимов сортировки. Некоторые ключи команды:

-d - сортировка по алфавиту (или по умолчанию);

-n - числовая;

-u - исключает повторяющиеся строки и т.д.

Практическая работа №3(3) Создание ссылок на файлы.

Цель работы:
1. Изучить понятие ссылки на файл.
2. Научиться создавать жесткие и символьные ссылки на файлы.
Порядок выполнения работы
Изучаются команды:
ln - создание ссылки на файл;
ls - просмотр атрибутов файла.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Выведите на экран Терминала справку по следующим командам: ln, ls. Назначение и формат команд приведите в отчете.
3) Перейдите в Ваш личный каталог и создайте в нем текстовый файл и любой подкаталог.
4) Создайте жесткую ссылку с другим именем в созданном подкаталоге на созданный файл. Проанализируйте и сравните все атрибуты связанных файлов. Объясните отличия.
5) Уничтожьте один из связанных файлов. Проанализируйте и сравните все атрибуты связанных с ним файлов. Объясните изменения.
6) Просмотрите содержание связанных файлов. Каков был результат просмотра?
7) Создайте символьную ссылку с другим именем в созданном ранее подкаталоге. Проанализируйте и сравните все атрибуты связанных файлов. Объясните отличия.
8) Создайте новый подкаталог в Вашем личном каталоге.
9) Создайте ссылки на несколько файлов, принадлежащих одному из каталогов домашней директории, в созданном ранее каталоге одной командной строкой. Проанализируйте и сравните все атрибуты связанных файлов. Объясните отличия.
10) Завершите работу с программой Терминал.

Практическая работа №3(4) Сортировка файлов

Цель работы:
1. Научиться сортировать отображаемую информацию при просмотре директории.
2. Научиться осуществлять сортировку данных в файле.
Порядок выполнения работы
Изучаются команды:
sort - сортировка файлов;
ls - просмотр содержимого каталога;
touch - замена времени модификации файла на текущее.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Выведите на экран Терминала справку по следующим командам: sort, touch. Назначение и формат команд приведите в отчете.
3) Просмотрите содержимое корневого каталога с выводом размеров файлов, содержащихся в директории, в блоках.
4) Упорядочите по алфавиту строки суммарного файла HOME-каталога.
5) Просмотрите содержимое любой директории отсортировав отображаемую информацию по времени последнего доступа к файлу.
6) Обновите временные характеристики одного из существующих файлов. Проанализируйте результат.
7) Просмотрите содержимое директории, содержащей файл с обновленными временными характеристиками отсортировав его по времени модификации файлов
8) Обновите временные характеристики несуществующего файла. Проанализируйте результат работы команды.
9) Просмотрите содержимое директории, содержащей созданный файл, используя сортировку по времени создания файла
10) Проанализируйте с использованием команды history содержание лабораторной работы, продумайте ответы на нижеприведенные контрольные вопросы и сдайте выполненную работу преподавателю.

Контрольные вопросы:

Какие системные имена каталогов Вам известны?

Каким образом можно построить отдельный каталог или цепочку каталогов?

Для чего и каким образом переопределяются текущие каталоги?

Как обратиться к файлам параллельных ветвей дерева

каталогов? К вышележащему каталогу?

Какие условия поиска файлов Вы знаете? Как комбинируются условия поиска? Как осуществить поиск по дереву каталогов?

Какова последовательность действий при удалении одного каталога? Цепочки каталогов?

Объясните назначение и содержание каждого поля каталога.

Как отличить по содержимому каталога типы файлов, содержащихся в Ваших каталогах.

Какую информацию содержит «пустой» вновь созданный каталог?

Как осуществить поиск файлов в системе каталогов по фрагментам текста файлов?

Назовите известные Вам способы создания пустых файлов.

Как создать текстовый файл?

Какие возможности сокращения записи имен файлов Вы знаете с использованием механизма генерации имен файлов?

Какие три команды этой лабораторной работы можно использовать для переименования файлов? Как в этом случае надо использовать команды?

Какими способами можно объединить несколько текстовых файлов в один?

В чем разница работы команд cp и mv?

Сколько ссылок можно создать на единственный файл из разных каталогов?

Как создать несколько ссылок с совпадающими именами на несколько файлов в другом каталоге?

Какое соответствие атрибутов имеют связанные между собой файлы?

На какой атрибут и как влияет удаление одного из связанных файлов?

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

Какими возможностями обладает команда sort?

Тема 2.2. Управление процессами

2.2.1. Управление процессами

Отображение информации о процессах

В Linux (как и во всех UNIX-системах) имеется команда ps, которая позволяет определить, какие процессы в системе запущены. Если ее запустить без всяких параметров, то она выдает список процессов, запущенных в текущей сессии.

ps [-опции] - определение запущенных в системе процессов

Краткая характеристика наиболее важных опций:

- ax - список всех процессов, запущенных в системе;

-u - отображение % ЦПУ и памяти занимаемых запущенными процессами;

-l - длинный формат отображения информации о процессах (с выводом приоритета процесса и значениния nice)

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

· USER -- имя владельца процесса;

· PID -- идентификатор процесса в системе;

· PPID -- идентификатор родительского процесса;

· %CPU -- доля времени центрального процессора (в процентах), выделенного данному процессу;

· %MEM -- доля реальной памяти (в процентах), используемая данным процессом;

· VSZ -- виртуальный размер процесса (в килобайтах);

· RSS -- размер резидентного набора (количество 1K-страниц в памяти);

· STIME -- время старта процесса;

· TTY -- указание на терминал, с которого запущен процесс;

· S или STAT -- статус процесса;

· PRI -- приоритет планирования;

· NI -- значение nice (см. описание команды nice ниже);

· TIME -- сколько времени центрального процессора занял данный процесс;

· CMD или COMMAND -- командная строка запуска программы, выполняемой данным процессом;

а также и другие поля, полный список которых приведен на man-странице, посвященной команде ps.

В поле Статус процесса могут стоять следующие значения:

· R -- выполнимый процесс, ожидающий только момента, когда планировщик задач выделит ему очередной квант времени;

· S -- процесс "спит";

· D -- процесс находится в состоянии подкачки на диске;

· T -- остановленный процесс;

· Z -- процесс-зомби.

Рядом с указателем статуса могут стоять дополнительные символы из следующего набора:

· W -- процесс не имеет резидентных страниц;

· < -- высоко-приоритетеный процесс;

· N -- низко-приоритетный процесс;

· L -- процесс имеет страницы, заблокированные в памяти.

Например, результат выполнения нижеприведенной команды показал, что в системе работали на момент снятия данных два процесса sh (с идентификатором 927, идентификатор процесса предка - 1) и ps (с идентификатором 1001, идентификатор процесса предка - 927, т.е. sh порождает процесс ps). Терминалы с которых запущены процессы - tty5.

ps -flu lev

PID PPID TTY PRI TIME CMD

927 1 tty5 0:04 sh

1001 927 tty5 0:02 ps

Для вывода листинга процессов, принадлежащих пользователю можно воспользоваться конструкцией:

ps -f|grep <имя_пользователя>.

Команда top

Команда ps позволяет сделать как бы "моментальный снимок" процессов, запущенных в системе. В отличие от ps команда top отображает состояние процессов и их активность "в реальном режиме времени". На рисунке 2.2.1. изображено окно терминала, в котором запущена программа top.

Рис. 2.2.1. Вывод команды top

В верхней части окна отображается астрономическое время, время, прошедшее с момента запуска системы, число пользователей в системе, число запущенных процессов и число процессов, находящихся в разных состояниях, данные об использовании ЦПУ, памяти и свопа. А далее идет таблица, характеризующая отдельные процессы. Число строк, отображаемых в этой таблице, определяется размером окна: сколько строк помещается, столько и выводится. Графы таблицы обозначены так же, как поля вывода команды ps. Содержимое окна обновляется каждые 5 секунд.

Приоритеты, значение nice и команда renice

Приоритет для каждого процесса устанавливается в тот момент, когда процесс порождается. Приоритет процесса определяется так называемым "значением nice", которое лежит в пределах от +20 (наименьший приоритет, процесс выполняется только тогда, когда ничто другое не занимает процессор), до -20 (наивысший приоритет).

Значение nice устанавливается для каждого процесса в момент порождения этого процесса и при обычном запуске команд или программ принимается равным приоритету родительского процесса. Но существует специальная команда nice, которая позволяет изменять значение nice при запуске программы. Формат использования этой программы:

nice [- adnice] command [args]

где adnice -- значение (от -20 до +19), добавляемое к значению nice процесса-родителя. Полученная сумма и будет значением nice для запускаемого процесса. Отрицательные значения может устанавливать только суперпользователь. Если опция -- adnice не задана, то по умолчанию для процесса-потомка устанавливается значение nice, увеличенное на 10 по сравнению со значением nice родительского процесса. Очевидно, что если вы не суперпользователь, то применять эту команду имеет смысл только тогда, когда вы хотите запустить некий процесс с низким значением приоритета.

Другая команда, renice, служит для изменения значения nice для уже выполняющихся процессов. Ее формат таков:

renice priority [[-p] PID] [[-g] grp] [[-u] user]

Например, команда

renice -1 987 -u daemon -p 32

увеличивает на 1 приоритет процессов с PID 987 и 32, а также всех процессов пользователя daemon.

Суперпользователь может изменить приоритет любого процесса в системе. Другие пользователи могут изменять значение приоритета только для тех процессов, для которых данный пользователь является владельцем. При этом обычный пользователь может только уменьшить значение приоритета (увеличить значение nice), но не может увеличить приоритет, даже для возврата значения nice к значению, устанавливаемому по умолчанию. Поэтому процессы с низким приоритетом не могут породить "высокоприоритетных детей".

Сигналы и команда kill

Сигналы -- это средство, с помощью которого процессам можно передать сообщения о некоторых событиях в системе.

Сами процессы тоже могут генерировать сигналы, с помощью которых они передают определенные сообщения ядру и другим процессам. С помощью сигналов можно осуществлять такие акции управления процессами, как приостановка процесса, запуск приостановленного процесса, завершение работы процесса. Всего в Linux существует 63 разных сигнала, их перечень можно посмотреть по команде

kill -l

Сигналы принято обозначать номерами или символическими именами. Все имена начинаются на SIG, но эту приставку иногда опускают: например, сигнал с номером 1 обозначают или как SIGHUP, или просто как HUP.

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

Можно заставить процесс игнорировать или блокировать некоторые сигналы. Игнорируемый сигнал просто отбрасывается процессом и не оказывает на него никакого влияния. Блокированный сигнал ставится в очередь на выдачу, но ядро не требует от процесса никаких действий до разблокирования сигнала. После разблокирования сигнала программа его обработки вызывается только один раз, даже если в течение периода блокировки данный сигнал поступал несколько раз.

В табл. 2.2.1. приведены некоторые из часто встречающихся сигналов.

Таблица 2.2.1. Сигналы

Имя

Описание

Можно перехватывать

Можно блокировать

Комбинация клавиш

1

HUP

Hangup. Отбой

Да

Да

2

INT

Interrupt. В случае выполнения простых команд вызывает прекращение выполнения, в интерактивных программах -- прекращение активного процесса

Да

Да

<Ctrl>+<C> или <Del>

3

QUIT

Как правило, сильнее сигнала Interru

Да

Да

<Ctrl>+<\>

4

ILL

Illegal Instruction. Центральный процессор столкнулся с незнакомой командой (в большинстве случаев это означает, что допущена программная ошибка). Сигнал отправляется программе, в которой возникла проблема

Да

Да

8

FPE

Floating Point Exception. Вычислительная ошибка, например, деление на ноль

Да

Да

9

KILL

Всегда прекращает выполнение процесса

Нет

Нет

11

SEGV

Segmentation Violation. Доступ к недозволенной области памяти

Да

Да

13

PIPE

Была предпринята попытка передачи данных с помощью конвейера или очереди FIFO, однако не существует процесса, способного принять эти данные

Да

Да

15

TERM

Software Termination. Требование закончить процесс (программное завершение)

Да

Да

17

CHLD

Изменение статуса порожденного процесса

Да

Да

18

CONT

Продолжение выполнения приостановленного процесса

Да

Да

20

TSTR

Сигнал останова, генерируемый клавиатурой. Переводит процесс в фоновый

Да

Да

<Ctrl>+<Z>

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

Для посылки сигнала процессу (или группе процессов) можно воспользоваться командой kill в следующем формате:

kill [-сигн] PID [PID..]

где сигн -- это номер сигнала, причем если указание сигнала опущено, то посылается сигнал 15 (TERM -- программное завершение процесса). Чаще всего используется сигнал 9 (KILL), с помощью которого суперпользователь может завершить любой процесс. Но сигнал этот очень "грубый", если можно так выразиться, поэтому его использование может привести к нарушению порядка в системе. Поэтому в большинстве случаев рекомендуется использовать сигналы TERM или QUIT, которые завершают процесс более "мягко".

Наиболее часто команду kill вынужден применять суперпользователь. Он должен использовать ее для уничтожения процессов-зомби, зависших процессов (они показываются в листинге команды ps как <exiting>), процессов, которые занимают слишком много процессорного времени или слишком большой объем памяти и т. д. Особый случай -- процессы, запущенные злоумышленником.

Перевод процесса в фоновый режим

Если вы запускаете какой-то процесс путем запуска программы из командной строки, то обычно процесс запускается, как говорят, "на переднем плане". Это значит, что процесс "привязывается" к терминалу, с которого он запущен, воспринимая ввод с этого терминала и осуществляя на него вывод. Но можно запустить процесс в фоновом режиме, когда он не связан с терминалом. Для запуска процесса в фоновом режиме в конце командной строки запуска программы добавляют символ & (амперсанд).

Например, в фоновом режиме запускается процесс cc prog.c:

$ cc prog.c &

2388

$

Shell выводит номер этого процесса (PID) и разрешает ввод следующей команды.

Фоновые процессы обладают некоторыми недостатками:

- не допускают ввода с клавиатуры;

- обспечивают вывод на экран, но при этом нарушают целостность вывода диалогового процесса.

Общепринятый прием исключения влияния фонового вывода на интерактивную работу:

ком_строка>имя_файла.out &

- ком_строка планирует задание для фонового режима

- перенаправляет вывод вместо экрана в указанный файл головного каталога пользователя.

Пример: Запуск программы, осуществляющей поиск файлов по шаблону «ааа*», в фоновом режиме, результаты поиска перенаправляются в файл grep.out:

$grep ааа* > grep.out &

194

$ps

PID TTY TIME CMD

194 tty5 0:02 grep

200 tty5 0:01 ps

В оболочке bash имеются две встроенные команды, которые служат для перевода процессов на передний план или возврата их в фоновый режим. Но прежде, чем рассказывать об этих командах, надо рассказать о команде jobs. Она всегда вызывается без аргументов и показывает задания, запущенные из текущего экземпляра shell. В начале каждой строки вывода этой команды указывается порядковый номер задания в виде числа в квадратных скобках. После номера указывается состояние процесса: stopped (остановлен), running (выполняется) или suspended (приостановлен). В конце строки указывается команда, которая исполняется данным процессом. Один из номеров выполняющихся заданий помечен знаком +, а еще один -- знаком -. Процесс, помеченный знаком +, будет по умолчанию считаться аргументом команд fg или bg, если они вызываются без параметров. Процесс, помеченный знаком -, получит знак +, если только завершится по какой-либо причине процесс, который был помечен знаком +.

Команды fg и bg служат для перевода процессов на передний план или возврата их в фоновый режим. В качестве аргумента обеим этим командам передаются номера тех заданий, которые присутствуют в выводе команды jobs. Если аргументы отсутствуют, то подразумевается задание, помеченное знаком +. Команда fg переводит указанный в аргументе процесс на передний план, а команда bg -- переводит процесс в фоновый режим. Одной командой bg можно перевести в фоновый режим сразу несколько процессов, а вот возвращать их на передний план необходимо по одному.

Практическая работа №4(1) Команды управления процессами. Создание фоновых процессов

Цель работы:
1. Закрепить представление о возможностях командного языка UNIX по управлению процессами, которым выделяются все необходимые ресурсы вычислительной системы
2. Научиться запускать на выполнение фоновые процессы и процессы переднего плана, получать моментальный снимок процессов в системе.
Порядок выполнения работы
Изучаются команды:
ps - запрос информации о процессах текущего терминала;
top получение информации о "состоянии процессов в режиме реального времени;
& - запуск фонового процесса;
jobs - запрос листинга списка заданий;
bg - перевод оперативного в фоновый режим;
fg перевод фонового процесса в оперативный.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Выведите на экран Терминала справку по следующим командам: ps, top, jobs, bg, fg. Назначение и формат команд приведите в отчете.
3) Выведите на экран листинг характеристик (в длинном и коротком форматах) процессов, инициализированных с Вашего терминала. Проанализируйте и объясните содержание каждого поля сообщения
4) Запустите утилиту получения информации о процессах в режиме реального времени. Проанализируйте и объясните содержание каждого поля сообщения
5) Запустите простейшую процедуру в фоновом режиме с бесконечным циклом выполнения, предусматривающую, например процесс, выводящий на экран бесконечный поток символов «y»:
уes &
6) Выведите на экран листинг характеристик (в длинном и коротком форматах) процессов, инициализированных с Вашего терминала. Объясните изменения в листинге характеристик процессов. Объясните содержание PID и PPID. Какой процесс является родительским для запущенной процедуры.
7) Выйдите из системы и войдите заново. Проанализируйте листинг процессов. Объясните изменения в системе.
8) Запустите процесс уes в оперативном режиме с перенаправлением вывода в устройство /dev/null («черная дыра»).
9) Переведите процесс в оперативный режим и проанализируйте сообщение на экране.
10) Приостановите выполнение процесса и переведите его в фоновый режим. Проанализируйте сообщение на экране.
11) Завершите работу всех запущенных вами процессов, переведя их на передний план и нажав клавиши Ctrl+C.
12) Завершите работу с Терминалом.

Практическая работа №4(2) Управление приоритетами процессов. Завершение работы процессов

Цель работы:
1. Закрепить представление о возможностях командного языка UNIX по управлению процессами, которым выделяются все необходимые ресурсы вычислительной системы
2. Научиться осуществлять управление существующими в системе процессами, изменяя их приоритеты и посылая им сигналы управления.
Порядок выполнения работы
Изучаются команды:
nice - понижение приоритета процесса;
kill - посылка сигнала процессу.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Выведите на экран Терминала справку по следующим командам: nice, kill. Назначение и формат команд приведите в отчете.
3) Запустите процесс уes в оперативном режиме с перенаправлением вывода в устройство /dev/null («черная дыра»).
4) Приостановите выполнение процесса, используя команду kill.
5) Переведите процесс в фоновый режим. Проанализируйте сообщение на экране.
6) Убейте процесс, послав командой kill сигнал завершения процесса.
7) Запустите процесс поиска директорий в корневом каталоге в фоновом режиме (выводимые данные перенаправьте в файл или «черную дыру»).
8) Выведите на экран листинг характеристик (в длинном формате) процессов, инициализированных с Вашего терминала. Каково значение приоритета запущенного процесса? Какой процесс является родительским для запущенной процедуры.
9) Понизьте значение приоритета процедуры поиска. На что и как повлияет эта операция при управлением вычислительным процессом системы? Как отразятся её результаты в описателях процессов?
10) Убейте все созданные ранее процессы и завершите работу с Терминалом.

Контрольные вопросы:

Объясните понятия процесса и ресурса. Какое их значение в организации вычислительного процесса в ОС UNIX?

Какая информация содержится в описателях процессов? Как просмотреть их содержание в процессе работы с системой?

Какими способами можно организовать выполнение программ в фоновом режиме?

Какие особенности выполнения программ в фоновом режиме? Как избежать вывода фоновых сообщений на экран и прерывания выполнения фоновых программ при прекращении сеанса работы с системой?

Как пользователь может повлиять на распределение ресурсов между активными процессами?

Как можно прервать выполнение активных процессов? Какая информация для этого необходима и откуда она извлекается?

Тема 2.3. Права доступа к файлам и каталогам

2.3.1. Команды управления правами доступа

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

Права процессов пользователей при доступе к файлу кодируются в атрибутах защиты файла. Атрибуты сопровождают каждый файл, хранятся в описателях файлов, на которые в каталоге имеются ссылки, и доступны для анализа и изменения посредством специальных команд ОС UNIX. Атрибуты защиты файла определяют права доступа трем видам процессов: процессам пользов ателя - владельца файла (u - user), процессам группы владельца файла (g - group) и процессам остальных пользователей (o - other), не попавших ни в одну из двух предыдущих категорий. Код атрибутов прав доступа пользователей трех перечисленных категорий для каждого файла отображается в полном листинге каталога символьным кодом в виде комбинации следующих символов:

r - разрешение на чтение или на выполнение файла, для каталога - просмотр содержимого каталога (список всех файлов);

w - разрешение модификации или удаления файла, для каталога - включение или удаление файлов;

x - разрешение выполнения файла (совместно с - r), для каталога - поиск по каталогу конкретных отдельных файлов или сделать каталог текущим.

Например, полный листинг каталога /udd/user1/lev может иметь следующий вид:

-rwxr-xr-x 1 lev user1 171 Mar 4 14:20 fil1.c

drwxr-xr-x 2 lev user1 32 Mar 4 14:51 hh

Здесь файл fil1.c, владельцем которого является пользователь со входным именем lev, является обычным, содержит исходный текст программы на языке Си длиной 171 байт, доступен владельцу для чтения, записи и выполнения, членам группы и прочим пользователям - только для чтения и выполнения. Директория hh защищена для включения новых и удаления существующих файлов.

Для изменения значений кодов защиты только указанных в команде файлов служит команда:

chmod <коды защиты> <список_файлов>

Коды защиты (r, w, x) могут быть заданы только владельцем файла в символьном или числовом виде. Атрибуты задаются для владельца (u), его группы (g) и остальных пользователей (o) или для всех категорий пользователей одновременно (a).

Над символьными атрибутами защиты можно выполнять три следующие операции отдельно для владельца, для группы-владельца и для всех остальных пользователей:

= - присвоить значения кодов доступа (замена существующих);

+ - добавить значения кодов доступа;

- - отобрать права доступа.

Необходимо отметить, что новый файл обычно создается по умолчанию как невыполняемый, со стандартным набором прав доступа:

rw-rw-rw- - для файла;

rwxrwxrwx - для каталога.

Например, необходимо сделать некоторый файл shproc1 выполняемым, если он был создан как обычный. Для этого можно использовать следующую команду:

$ chmod u+x shproc1

$ shproc1

< Выполнение программы из файла shproc1 >

$

Эти действия необходимы и при формировании и выполнении shell-процедуры.

chmod a+x f1 - в данном случае файл f1 становится доступным для исполнения всем пользователям;

chmod a=rwx f2 - предоставляются все права всем категориям пользователей.

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

Например:

Символьное представление: rwx r-x r--

Двоичное представление: 111 101 100

Восьмеричное представление: 7 5 4

Поэтому следующая команда:

chmod 0754 f3

- эквивалентна команде:

chmod u=rwx,g=rx,o=r f3

В результате выполнения команд в любой из приведенных форм коды доступа файла f3 приобретут следующий вид:

ls -l f3

”””””””””””””””””””””””””””””

-rwxr-xr-- ....................... f3

”””””””””””””””””””””””””””””

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

С целью защиты файла от удаления надо отобрать право (w) как у файла, так и у каталога, в котором находится файл.

Стандартные значения кодов прав доступа устанавливает администратор системы. Однако пользователь в rsh может изменить временно (до конца сеанса работы) значение кода для всех своих новых файлов с помощью команды:

$umask [-r] <режим-доступа>

Собственно маска - это двоичный код, с этим кодом и двоичным кодом установленным ране выполняются некоторые логические операции - в результате операции вычисляются новые коды защиты. В ksh - возможно символьное представление кодов защиты в umask, а собственно числовое значение маски просчитывается системой автоматически и используется для вычисления результирующих заданных в команде кодов доступа; ключ -S -выводит на экран текущие символьные значения кодов; без ключа - команда выводит числовое значение маски.

Имеются и другие возможности управления правами доступа. Приведенные ниже функции может выполнять только владелец файла или администратор.

chown нов_владелец имя_файла - владелец передает права владения данным файлом другому пользователю или группе.

chgrp нов_группа имя_файла - передача прав другой группе (сменить группу).

Практическая работа №5(1) Управление правами доступа к файлам

Цель работы:
1. Изучить принципы защиты файлов от несанкционированного доступа
2. Изучить влияние задаваемых прав доступа к файлу на выполнение различных команд по обработке этих файлов .
Порядок выполнения работы
Изучаются команды:
chmod - изменить права доступа к указанному файлу.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Выведите на экран Терминала справку по следующим командам: chmod. Назначение и формат команд приведите в отчете.
3) Создайте в Вашем HOME-каталоге один текстовый файл, например с именем f1. Выведите на экран полный листинг каталога.
4) Проанализируйте и умейте объяснить какие права доступа к f1 имеет владелец файла, его группа и остальные пользователи.
5) Выведите на экран содержимое файла f1. Объясните почему операция выполнилась успешно.
6) Запретите права на чтение f1 владельцу и группе. Попытайтесь вывести на экран текст файла. Объясните почему операция не выполняется.
7) Удалите права на запись в файл. Попытайтесь добавить к файлу текст и удалить его. Объясните результат.
8) Завершите работу с Терминалом

Практическая работа №5(2) Управление правами доступа к каталогам

Цель работы:
1. Изучить принципы защиты каталогов от несанкционированного доступа
2. Изучить влияние задаваемых прав доступа к каталогу на выполнение различных команд по обработке этих каталогов.
Порядок выполнения работы
Изучаются команды:
chmod - изменить права доступа к указанному каталогу.
1) Зарегистрируйтесь в ОС Linux. Запустите на выполнение программу Терминал.
2) Выведите на экран Терминала справку по следующим командам: chmod. Назначение и формат команд приведите в отчете.
3) Проанализируйте права доступа к Вашему личному каталогу. Есть ли ограничения на работу с файлами в этом каталоге?
4) Удалите право на модификацию каталога. Выполните операцию удаления файла f1, созданного в ходе выполнения работы 5(1). Объясните результат.
5) Создайте подкаталог. Разместите в нем текстовый файл. Проанализируйте права доступа к подкаталогу и объясните возможности по использованию подкаталога.
6) Удалите право владельца на «выполнение» подкаталога.
7) Попытайтесь сделать подкаталог текущим. Объясните результат.
8) Просмотрите содержимое подкаталога. Объясните результат.
9) Попытайтесь вывести длинный листинг подкаталога только для одного из файлов (поиск файла по подкаталогу). Объясните результат.
10) Попытайтесь вывести на экран содержимое файла. Объясните результат.
11) Верните право для подкаталога на «выполнение», удалите право на «чтение» и сохраните право на «модификацию».
12) Выполните п.п. 7, 8, 9, 10. Проанализируйте и объясните результаты
13) Верните право для подкаталога на «выполнение», удалите право на «чтение» и сохраните право на «модификацию»
14) Выполните п.п. 7, 8, 9, 10. Проанализируйте и объясните результаты
15) Завершите работу с Терминалом

Контрольные вопросы:

1. Как кодируются в атрибутах файла и каталога права доступа?

2. Кто может пользоваться и изменять права доступа к файлам?

3. Какие команды для изменения символьных кодов прав доступа Вы знаете? Перечислите и расскажите о назначении каждой из команд.

4. В чем разница в применении команд chmod и umask?

5. Какие команды обработки файлов разрешают (или запрещают) права на чтение, модификацию и исполнение?


Подобные документы

  • Характеристика и принцип работы подсистемы-инсталлятора Windows Installer, ее структура и назначение. Порядок и варианты установки программ в ОС Linux, их преимущества и недостатки. Методика и основные этапы составления базы данных программ-аналогов.

    курсовая работа [369,2 K], добавлен 24.08.2009

  • Основные моменты истории операционных систем, связывающих аппаратное обеспечение и прикладные программы. Характеристика операционной системы Microsoft Windows Seven, анализ операционной системы Linux. Преимущества и недостатки каждой операционной системы.

    курсовая работа [63,0 K], добавлен 07.05.2011

  • Основные сходства и отличия операционных систем Microsoft Windows и GNU/Linux: конфигурации, цена и широта технической поддержки; оценка стоимости владения и статистика использования на настольных компьютерах; простота инсталляции и наличие драйверов.

    курсовая работа [294,9 K], добавлен 12.05.2011

  • Первая версия Windows, постепенный рост системных требований. Важное отличие Windows 98 от Windows 95. История эволюции персональных компьютеров Apple Macintosh. Операционная система Linux, ее характерные черты и особенности, графические интерфейсы.

    реферат [1,5 M], добавлен 15.01.2015

  • Назначение и функции операционных систем компьютера. Аппаратные и программные ресурсы ЭВМ. Пакетные ОС. Системы с разделением времени: Multics, Unix. Многозадачные ОС для ПК с графическим интерфейсом: Windows, Linux, Macintosh. ОС для мобильных устройств.

    курсовая работа [53,4 K], добавлен 05.12.2014

  • Назначение серверных операционных систем. Сравнительный анализ серверных операционных систем Windows и Linux и сравнение их по важным показателям таким как: пользовательский графический интерфейс, безопасность, стабильность работы, возможность и цена.

    курсовая работа [50,1 K], добавлен 03.07.2012

  • Понятие и внутренняя структура операционных систем, их классификация и разновидности, предъявляемые требования, этапы становления и развития, функциональные особенности. Описание и назначение базовых компьютерных систем: DOS, Windows, Linux, Mac.

    курсовая работа [44,9 K], добавлен 14.12.2013

  • История создания и общая характеристика операционных систем Windows Server 2003 и Red Hat Linux Enterprise 4. Особенности установки, файловых систем и сетевых инфраструктур данных операционных систем. Использование протокола Kerberos в Windows и Linux.

    дипломная работа [142,7 K], добавлен 23.06.2012

  • История создания. Windows 9x/NT. Операционная система Microsoft Windows. Преимущества и недостатки Windows. Некоторые клавиатурные комбинации Windows 9x и NT. Windows XP Professional. Наиболее совершенная защита.

    реферат [19,3 K], добавлен 18.07.2004

  • Основы работы с многооконным графическим пользовательским интерфейсом операционной системы Windows95/NT. Основы работы с прикладными программами Windows и DOS. Разработка простого приложения для Windows при помощи средства разработки приложений DELPHI.

    контрольная работа [281,0 K], добавлен 15.01.2009

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.