Журнал лабораторных работ

Содержание

Журнал

Понедельник (12/21/15)

/dev/pts/0
09:23:02
#ls
install
09:23:46
#ls -a
.  ..  .aptitude  .bash_history  .bash_profile  .bashrc  install  .l3rc  .lilalo  .profile  .vim  .viminfo
09:23:49
#more .lilalo
09:24:01
#ls -al .lilalo
итого 88
drwxr-xr-x 2 root root  4096 Дек 21 10:24 .
drwx------ 5 root root  4096 Окт 15  2014 ..
-rw-r--r-- 1 root root  3146 Окт 15  2014 133518653134476610-1413379473.info
-rw-r--r-- 1 root root  1847 Окт 15  2014 133518653134476610-1413379473.script
-rw-r--r-- 1 root root  2759 Окт 13  2014 143184190977814884-1413212456.info
-rw-r--r-- 1 root root   505 Окт 13  2014 143184190977814884-1413212456.script
-rw-r--r-- 1 root root  2774 Окт 13  2014 1901738991017822016-1413212497.info
-rw-r--r-- 1 root root   407 Окт 13  2014 1901738991017822016-1413212497.script
-rw-r--r-- 1 root root     0 Июн 27  2014 23119324163069212524-1403867377_1403867394_root_.lilalo_l3bashrc.diff
-rw-r--r-- 1 root root     0 Июн 27  2014 23119324163069212524-1403867377_1403867447_root_.l3rc.diff
-rw-r--r-- 1 root root  1138 Июн 27  2014 23119324163069212524-1403867377.info
-rw-r--r-- 1 root root 14417 Июн 27  2014 23119324163069212524-1403867377.script
-rw-r--r-- 1 root root   692 Июн 27  2014 2525264871024819419-1403867138.info
-rw-r--r-- 1 root root   205 Июн 27  2014 2525264871024819419-1403867138.script
-rw-r--r-- 1 root root   529 Дек 21 10:24 836731037158749818-1450686182.info
-rw-r--r-- 1 root root   810 Дек 21 10:24 836731037158749818-1450686182.script
-rw-r--r-- 1 root root     4 Дек 18 17:53 l3-agent.pid
-rw-r--r-- 1 root root  7857 Окт 15  2014 l3bashrc
-rwxr-xr-x 1 root root   234 Окт 15  2014 l3prompt
-rw-r--r-- 1 root root   362 Дек 21 10:24 .report.dat
09:24:56
#who
root     pts/0        2015-12-21 10:14 (192.168.15.106)
прошло 18 минут
09:43:16
#whoim
l3script: whoim: команда не найдена
09:43:21
#who
root     pts/0        2015-12-21 10:14 (192.168.15.106)
09:43:24
#useradd ivan

09:44:51
#echo $?
0
09:45:47
#echo $?
0
09:46:41
#echo privet
privet
09:46:52
#echo $?
0
09:46:54
#useradd ivan
useradd: пользователь «ivan» уже существует
09:47:39
#echo $?
9
09:47:46
#man useradd
09:54:07
#more /etclpasswd
09:54:10
#cd /etcl/
l3script: cd: /etcl/: Нет такого файла или каталога
09:54:36
#cd /etcl
l3script: cd: /etcl: Нет такого файла или каталога
09:54:38
#cd ./etcl/
l3script: cd: ./etcl/: Нет такого файла или каталога
09:54:43
#ls-a
l3script: ls-a: команда не найдена
09:54:48
#la -a
l3script: la: команда не найдена
09:54:51
#ls
install
09:54:54
#cd

09:54:57
#ls
install
09:54:59
#cd /etc/passwd
l3script: cd: /etc/passwd: Это не каталог
09:55:14
#more /etc/passwd
09:55:19
#more /etc/passwd | grep ivan
ivan:x:1001:1001::/home/ivan:/bin/sh
09:55:45
#ls/home
l3script: ls/home: Нет такого файла или каталога
09:55:56
#ls /home
user
09:56:00
#userdel ivan

09:56:50
#more /etc/passwd | grep ivan

09:57:17
#useradd -m ivan

09:59:48
#ls /home
ivan  user
10:00:23
#ls -a /home
.  ..  ivan  user
10:00:43
#ls -^Chome

10:00:51
#^C

10:00:51
#^C

10:00:51
#ls --color /home
ivan  user
10:01:04
#ls
install
10:01:08
#ls -a /home
.  ..  ivan  user
10:01:13
#ls -f /home
..  ivan  .  user
10:01:41
#ls -F /home
ivan/  user/
10:01:49
#passwd ivan
Введите новый пароль UNIX:
Повторите ввод нового пароля UNIX:
passwd: пароль успешно обновлён
10:05:38
#more /etc/passwd | grep ivan
ivan:x:1001:1001::/home/ivan:/bin/sh
10:08:41
#more /etc/passwd | grep ivan
ivan:x:1001:1001::/home/ivan:/bin/sh
10:09:11
#more /etc/passwd | grep root
root:x:0:0:root:/root:/bin/bash
10:09:43
#cnsh -s /bin/bash ivan
l3script: cnsh: команда не найдена
10:11:38
#chsh -s /bin/bash ivan

10:11:54
#more /etc/passwd | grep ivan^C

10:19:37
#^C

10:19:37
#^C

10:19:37
#useradd -m ivan
useradd: пользователь «ivan» уже существует
10:19:50
#useradd -m -s /bin/bash peter

10:20:17
#passwd peter
Введите новый пароль UNIX:
Повторите ввод нового пароля UNIX:
passwd: пароль успешно обновлён
прошло 19 минут
/dev/pts/0
10:39:42
#cd

10:40:20
#df -h
Файловая система                                       Размер Использовано  Дост Использовано% Cмонтировано в
rootfs                                                    16G        1015M   14G            7% /
udev                                                      10M            0   10M            0% /dev
tmpfs                                                     50M         152K   50M            1% /run
/dev/disk/by-uuid/92b79496-a6c3-450d-a438-766caa8504d8    16G        1015M   14G            7% /
tmpfs                                                    5,0M            0  5,0M            0% /run/lock
tmpfs                                                    100M            0  100M            0% /run/shm
прошло 28 минут
11:08:23
#fdisl -l
l3script: fdisl: команда не найдена
11:09:08
#fdisk -l
Disk /dev/xvda: 17.2 GB, 17179869184 bytes
255 heads, 63 sectors/track, 2088 cylinders, total 33554432 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x000e4875
    Device Boot      Start         End      Blocks   Id  System
/dev/xvda1            2048    32088063    16043008   83  Linux
Disk /dev/xvdb: 5368 MB, 5368709120 bytes
255 heads, 63 sectors/track, 652 cylinders, total 10485760 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000
Disk /dev/xvdb doesn't contain a valid partition table
11:09:22
#cd /usr/share/m
man/    man-db/ menu/   misc/
11:09:22
#cd /usr/share/man

11:17:11
#ll
l3script: ll: команда не найдена
11:17:15
#ls -a
.   cs  de  fi  gl  id  ja  man1  man3  man5  man7  nl  pt     ru  sv  zh_CN
..  da  es  fr  hu  it  ko  man2  man4  man6  man8  pl  pt_BR  sl  tr  zh_TW
11:17:22
#cd

11:19:07
#ls
install
11:20:01
#ls -a
.  ..  .aptitude  .bash_history  .bash_profile  .bashrc  install  .l3rc  .lesshst  .lilalo  .profile  .vim  .viminfo
11:20:11
#cd -
/usr/share/man
11:25:00
#cd

11:27:56
#pwd
/root
11:27:58
#mkdir d1

11:28:10
#ll
l3script: ll: команда не найдена
11:28:11
#ls
d1  install
11:28:14
#mkdir d1/d2

11:28:25
#mkdir - d3/d4/d5
mkdir: невозможно создать каталог «d3/d4/d5»: Нет такого файла или каталога
11:29:04
#mkdir -p d3/d4/d5

11:29:09
#ll
l3script: ll: команда не найдена
11:29:11
#ls
-  d1  d3  install
11:29:13
#rm -
rm: невозможно удалить «-»: Это каталог
11:29:31
#rm -R -

11:29:40
#ls
d1  d3  install
11:29:43
#apt-get install tree
Чтение списков пакетов… Готово
Построение дерева зависимостей
Чтение информации о состоянии… Готово
НОВЫЕ пакеты, которые будут установлены:
  tree
обновлено 0, установлено 1 новых пакетов, для удаления отмечено 0 пакетов, и 0 пакетов не обновлено.
Необходимо скачать 43,3 kБ архивов.
После данной операции, объём занятого дискового пространства возрастёт на 112 kB.
Получено:1 http://ftp.ua.debian.org/debian/ wheezy/main tree amd64 1.6.0-1 [43,3 kB]
Получено 43,3 kБ за 0с (542 kБ/c)
Выбор ранее не выбранного пакета tree.
(Чтение базы данных … на данный момент установлено 28835 файлов и каталогов.)
Распаковывается пакет tree (из файла …/tree_1.6.0-1_amd64.deb) …
Обрабатываются триггеры для man-db …
Настраивается пакет tree (1.6.0-1) …
11:34:16
#tree
.
├── d1
│   └── d2
├── d3
│   └── d4
│       └── d5
└── install
5 directories, 1 file
11:34:18
#touch d1/f1

11:35:52
#tree
.
├── d1
│   ├── d2
│   └── f1
├── d3
│   └── d4
│       └── d5
└── install
5 directories, 2 files
11:35:55
#who > d3/d4/d5
l3script: d3/d4/d5: Это каталог
11:37:01
#who > d3/d4/user

11:37:09
#tree -s
.
├── [       4096]  d1
│   ├── [       4096]  d2
│   └── [          0]  f1
├── [       4096]  d3
│   └── [       4096]  d4
│       ├── [       4096]  d5
│       └── [        168]  user
└── [       5268]  install
5 directories, 3 files
11:37:16
#ll
l3script: ll: команда не найдена
11:38:23
#history
    1  ifconfig
    2  vim /etc/network/interfaces
    3  nano /etc/network/interfaces
    4  /etc/init.d/networking restart
    5  ifconfig
    6  route
    7  ping 192.168.13.253
    8  shutdown -r now
    9  exit
   10  ping ya.ru
...
  140  ls
  141  apt-get install tree
  142  tree
  143  touch d1/f1
  144  tree
  145  who > d3/d4/d5
  146  who > d3/d4/user
  147  tree -s
  148  ll
  149  history
11:38:29
#ls
d1  d3  install
11:39:12
#cd

11:39:14
#ls
d1  d3  install
11:39:16
#cp
cp: пропущен операнд, задающий файл
Попробуйте «cp --help» для получения более подробного описания.
11:39:43
#cp -v d3/d4/user d1
«d3/d4/user» -> «d1/user»
11:40:16
#tree -s
.
├── [       4096]  d1
│   ├── [       4096]  d2
│   ├── [          0]  f1
│   └── [        168]  user
├── [       4096]  d3
│   └── [       4096]  d4
│       ├── [       4096]  d5
│       └── [        168]  user
└── [       5268]  install
5 directories, 4 files
11:40:50
#ls
d1  d3  install
11:44:05
#cp -rv d1/d2 d3/
«d1/d2» -> «d3/d2»
11:44:28
#tree
.
├── d1
│   ├── d2
│   ├── f1
│   └── user
├── d3
│   ├── d2
│   └── d4
│       ├── d5
│       └── user
└── install
6 directories, 4 files
11:44:35
#mv d1/user d1/user1

11:45:08
#tree
.
├── d1
│   ├── d2
│   ├── f1
│   └── user1
├── d3
│   ├── d2
│   └── d4
│       ├── d5
│       └── user
└── install
6 directories, 4 files
11:45:10
#rm d1/f1

Статистика

Время первой команды журнала09:23:02 2015-12-21
Время последней команды журнала11:45:10 2015-12-21
Количество командных строк в журнале100
Процент команд с ненулевым кодом завершения, %10.00
Процент синтаксически неверно набранных команд, %10.00
Суммарное время работы с терминалом *, час 2.37
Количество командных строк в единицу времени, команда/мин 0.70
Частота использования команд
ls23|=====================| 21.30%
cd12|===========| 11.11%
more9|========| 8.33%
grep6|=====| 5.56%
tree6|=====| 5.56%
useradd5|====| 4.63%
echo5|====| 4.63%
mkdir4|===| 3.70%
ll4|===| 3.70%
who4|===| 3.70%
^C4|===| 3.70%
cp3|==| 2.78%
rm3|==| 2.78%
passwd2|=| 1.85%
touch1|| 0.93%
fdisk1|| 0.93%
pwd1|| 0.93%
man1|| 0.93%
chsh1|| 0.93%
ls-a1|| 0.93%
fdisl1|| 0.93%
userdel1|| 0.93%
d51|| 0.93%
history1|| 0.93%
home1|| 0.93%
user1|| 0.93%
df1|| 0.93%
cnsh1|| 0.93%
la1|| 0.93%
apt-get1|| 0.93%
whoim1|| 0.93%
mv1|| 0.93%
____
*) Интервалы неактивности длительностью 30 минут и более не учитываются

Справка

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

  2. Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду w. В поле WHAT, соответствующем текущему терминалу, должна быть указана программа script.

  3. Команды, при наборе которых были допущены синтаксические ошибки, выводятся перечёркнутым текстом:
    $ l s-l
    bash: l: command not found
    

  4. Если код завершения команды равен нулю, команда была выполнена без ошибок. Команды, код завершения которых отличен от нуля, выделяются цветом.
    $ test 5 -lt 4
    Обратите внимание на то, что код завершения команды может быть отличен от нуля не только в тех случаях, когда команда была выполнена с ошибкой. Многие команды используют код завершения, например, для того чтобы показать результаты проверки

  5. Команды, ход выполнения которых был прерван пользователем, выделяются цветом.
    $ find / -name abc
    find: /home/devi-orig/.gnome2: Keine Berechtigung
    find: /home/devi-orig/.gnome2_private: Keine Berechtigung
    find: /home/devi-orig/.nautilus/metafiles: Keine Berechtigung
    find: /home/devi-orig/.metacity: Keine Berechtigung
    find: /home/devi-orig/.inkscape: Keine Berechtigung
    ^C
    

  6. Команды, выполненные с привилегиями суперпользователя, выделяются слева красной чертой.
    # id
    uid=0(root) gid=0(root) Gruppen=0(root)
    

  7. Изменения, внесённые в текстовый файл с помощью редактора, запоминаются и показываются в журнале в формате ed. Строки, начинающиеся символом "<", удалены, а строки, начинающиеся символом ">" -- добавлены.
    $ vi ~/.bashrc
    2a3,5
    >    if [ -f /usr/local/etc/bash_completion ]; then
    >         . /usr/local/etc/bash_completion
    >        fi
    

  8. Для того чтобы изменить файл в соответствии с показанными в диффшоте изменениями, можно воспользоваться командой patch. Нужно скопировать изменения, запустить программу patch, указав в качестве её аргумента файл, к которому применяются изменения, и всавить скопированный текст:
    $ patch ~/.bashrc
    В данном случае изменения применяются к файлу ~/.bashrc

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

    Если справочная информация о команде есть, команда выделяется голубым фоном, например: vi. Если справочная информация отсутствует, команда выделяется розовым фоном, например: notepad.exe. Справочная информация может отсутствовать в том случае, если (1) команда введена неверно; (2) если распознавание команды LiLaLo выполнено неверно; (3) если информация о команде неизвестна LiLaLo. Последнее возможно для редких команд.

  10. Большие, в особенности многострочные, всплывающие подсказки лучше всего показываются браузерами KDE Konqueror, Apple Safari и Microsoft Internet Explorer. В браузерах Mozilla и Firefox они отображаются не полностью, а вместо перевода строки выводится специальный символ.

  11. Время ввода команды, показанное в журнале, соответствует времени начала ввода командной строки, которое равно тому моменту, когда на терминале появилось приглашение интерпретатора

  12. Имя терминала, на котором была введена команда, показано в специальном блоке. Этот блок показывается только в том случае, если терминал текущей команды отличается от терминала предыдущей.

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

  14. Небольшие комментарии к командам можно вставлять прямо из командной строки. Комментарий вводится прямо в командную строку, после символов #^ или #v. Символы ^ и v показывают направление выбора команды, к которой относится комментарий: ^ - к предыдущей, v - к следующей. Например, если в командной строке было введено:

    $ whoami
    
    user
    
    $ #^ Интересно, кто я?
    
    в журнале это будет выглядеть так:
    $ whoami
    
    user
    
    Интересно, кто я?

  15. Если комментарий содержит несколько строк, его можно вставить в журнал следующим образом:

    $ whoami
    
    user
    
    $ cat > /dev/null #^ Интересно, кто я?
    
    Программа whoami выводит имя пользователя, под которым 
    мы зарегистрировались в системе.
    -
    Она не может ответить на вопрос о нашем назначении 
    в этом мире.
    
    В журнале это будет выглядеть так:
    $ whoami
    user
    
    Интересно, кто я?
    Программа whoami выводит имя пользователя, под которым
    мы зарегистрировались в системе.

    Она не может ответить на вопрос о нашем назначении
    в этом мире.
    Для разделения нескольких абзацев между собой используйте символ "-", один в строке.

  16. Комментарии, не относящиеся непосредственно ни к какой из команд, добавляются точно таким же способом, только вместо симолов #^ или #v нужно использовать символы #=

  17. Содержимое файла может быть показано в журнале. Для этого его нужно вывести с помощью программы cat. Если вывод команды отметить симоволами #!, содержимое файла будет показано в журнале в специально отведённой для этого секции.
  18. Для того чтобы вставить скриншот интересующего вас окна в журнал, нужно воспользоваться командой l3shot. После того как команда вызвана, нужно с помощью мыши выбрать окно, которое должно быть в журнале.
  19. Команды в журнале расположены в хронологическом порядке. Если две команды давались одна за другой, но на разных терминалах, в журнале они будут рядом, даже если они не имеют друг к другу никакого отношения.
    1
        2
    3   
        4
    
    Группы команд, выполненных на разных терминалах, разделяются специальной линией. Под этой линией в правом углу показано имя терминала, на котором выполнялись команды. Для того чтобы посмотреть команды только одного сенса, нужно щёкнуть по этому названию.

О программе

LiLaLo (L3) расшифровывается как Live Lab Log.
Программа разработана для повышения эффективности обучения Unix/Linux-системам.
(c) Игорь Чубин, 2004-2008

$Id$