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

Содержание

Журнал

Пятница (06/26/09)

/dev/ttyv0
18:58:57
#cd ..

18:58:59
#ls
doc     pics    source
18:59:02
#vim a
19:03:25
#vi a
19:04:29
#cd doc/

19:04:33
#ls
scripting
19:04:35
#cd ..

19:04:40
#top
last pid:  6130;  load averages:  0.00,  0.00,  0.00    up 0+02:35:49  17:05:20
26 processes 0.0 running 0.0 sleepin 0.0           0.0              100
      3
CPU states:     % user,     % nice,     % system,     % interrupt,     % idle
Mem: 32M Active, 25M Inact, 46M Wired, 16K Cache, 48M Buf, 277M Free
                                                              1
Swap: 2015M Total, 2015M Free
  PID USERNAME    THR PRI NICE   SIZE    RES STATE    TIME   WCPU COMMAND
 1958 root          1   8    0 12496K 11052K nanslp   0:16  0.00% perl5.8.8
 4580 root          1   8    0  8884K  7536K nanslp   0:08  0.00% perl5.8.8
...
  789 root          1   8    0  1396K   896K nanslp   0:00  0.00% cron
  273 root          1  96    0  1472K   880K select   0:00  0.00% dhclient
 4570 root          1   8    0  1780K  1488K wait     0:00  0.00% login
  320 _dhcp         1  96    0  1472K   920K select   0:00  0.00% dhclient
  671 root          1  96    0  1296K   692K select   0:00  0.00% usbd
  783 smmsp         1  20    0  3408K  1932K pause    0:00  0.00% sendmail
  837 root          1   5    0  1352K   788K ttyin    0:00  0.00% getty
 6066 root          1   8    0 12076K  4580K nanslp   0:00  0.00% gdm-binary
  832 root          1   5    0  1352K   788K ttyin    0:00  0.00% getty
  836 root          1   5    0  1352K   788K ttyin    0:00  0.00% getty
19:05:32
#clean
bash: clean: ËÏÍÁÎÄÁ ÎÅ ÎÁÊÄÅÎÁ
19:05:36
#a
bash: a: ËÏÍÁÎÄÁ ÎÅ ÎÁÊÄÅÎÁ
19:05:40
#cp a
usage: cp [-R [-H | -L | -P]] [-f | -i | -n] [-lpv] source_file target_file
       cp [-R [-H | -L | -P]] [-f | -i | -n] [-lpv] source_file ... target_directory
19:05:52
#cat a
cat: a: No such file or directory
/dev/ttyp1
19:06:21
#sysctl -a | less
19:06:59
#sysctl -a | grep CPU
hw.model: Intel(R) Core(TM)2 Quad CPU    Q6600  @ 2.40GHz
dev.cpu.0.%desc: ACPI CPU
/dev/ttyv0
19:07:09
#touch a

19:07:44
#ls
a       doc     pics    source
19:07:46
#touch b c

19:08:07
#ls
a       b       c       doc     pics    source
19:08:09
#rm a b c

19:08:24
#ls
doc     pics    source
19:08:26
#rm -p pics
rm: illegal option -- p
usage: rm [-f | -i] [-dIPRrvW] file ...
       unlink file
19:08:50
#rm -p doc
rm: illegal option -- p
usage: rm [-f | -i] [-dIPRrvW] file ...
       unlink file
19:09:01
#rm -p source
rm: illegal option -- p
usage: rm [-f | -i] [-dIPRrvW] file ...
       unlink file
19:09:19
#ls
doc     pics    source
19:09:21
#rmdir -p doc
rmdir: doc: Directory not empty
19:10:00
#rm -r doc

19:10:27
#ls
pics    source
19:10:29
#rm -r pics source

19:10:42
#ls

19:10:44
#cd ~/proj
bash: cd: /root/proj: No such file or directory
19:11:15
#cd ..

19:11:23
#ls
.ICEauthority           .gnome2                 .metacity
.bash_history           .gnome2_private         .nautilus
.bash_profile           .gstreamer-0.10         .profile
.bashrc                 .gtkrc-1.2-gnome2       .recently-used.xbel
.cshrc                  .l3rc                   .rhosts
.dmrc                   .lilalo                 .shrc
.fontconfig             .login                  .xsession-errors
.gconf                  .login_conf             Desktop
.gconfd                 .mail_aliases           scripting
.gnome                  .mailrc
19:11:26
#cd /

19:11:37
#ls
.cshrc          boot            etc             mnt             sys
.mozilla        cdrom           home            moused.core     tmp
.profile        compat          lib             proc            usr
.snap           dev             libexec         rescue          var
COPYRIGHT       dist            log             root
bin             entropy         media           sbin
19:11:38
#cd home

19:12:07
#ls
user
19:12:08
#cd user

19:12:14
#ls
.ICEauthority           .gnome2                 .metacity
.bash_history           .gnome2_private         .nautilus
.bash_profile           .gstreamer-0.10         .profile
.bashrc                 .gtkrc-1.2-gnome2       .recently-used.xbel
.cshrc                  .l3rc                   .rhosts
.dmrc                   .lilalo                 .shrc
.fontconfig             .login                  .xsession-errors
.gconf                  .login_conf             Desktop
.gconfd                 .mail_aliases           scripting
.gnome                  .mailrc
19:12:15
#cd Desktop

19:12:25
#mkdir -p proj/x-project/x

19:13:29
#ls
proj
19:13:31
#mkdir -p proj/y-project/y

/dev/ttyp1
19:14:39
#touch s d f

/dev/ttyv0
19:14:41
#cd proj/

19:14:57
#ls
x-project       y-project
19:15:05
#cd x-project/

19:15:10
#cd

19:15:13
#ls
.bash_history           .lesshst                f
.bash_profile           .lilalo                 install
.bashrc                 .login                  lynx-2.8.6.5_1,1.tbz
.cshrc                  .profile                mbox
.history                .ssh                    s
.k5login                .vnc
.l3rc                   d
/dev/ttyp1
19:15:19
#mkdir x c v

/dev/ttyv0
19:15:21
#pwd
/root
19:15:28
#cd /home/Desktop/
bash: cd: /home/Desktop/: No such file or directory
/dev/ttyp1
19:15:31
#ls -l
total 1646
-rw-------  1 root  wheel     2179 26 ÉÀÎ 16:35 .bash_history
-rw-r--r--  1 root  wheel       19 22 ÉÀÎ 09:13 .bash_profile
-rw-r--r--  1 root  wheel       38 22 ÉÀÎ 09:13 .bashrc
-rw-r--r--  2 root  wheel      801 16 ÑÎ×  2008 .cshrc
-rw-------  1 root  wheel      164 15 ÍÁÒ  2008 .history
-rw-r--r--  1 root  wheel      143 16 ÑÎ×  2008 .k5login
-rw-r--r--  1 root  wheel       51 22 ÉÀÎ 09:14 .l3rc
-rw-------  1 root  wheel       54 26 ÉÀÎ 17:06 .lesshst
drwxr-xr-x  2 root  wheel     1536 26 ÉÀÎ 17:15 .lilalo
...
drwxr-xr-x  2 root  wheel      512 28 ÍÁÒ  2008 .vnc
drwxr-xr-x  2 root  wheel      512 26 ÉÀÎ 17:15 c
-rw-r--r--  1 root  wheel        0 26 ÉÀÎ 17:15 d
-rw-r--r--  1 root  wheel        0 26 ÉÀÎ 17:15 f
-rw-r--r--  1 root  wheel     5160 28 ÍÁÒ  2008 install
-rw-r--r--  1 root  wheel  1564645 22 ÉÀÎ 16:54 lynx-2.8.6.5_1,1.tbz
-rw-------  1 root  wheel    53312 28 ÍÁÒ  2008 mbox
-rw-r--r--  1 root  wheel        0 26 ÉÀÎ 17:15 s
drwxr-xr-x  2 root  wheel      512 26 ÉÀÎ 17:15 v
drwxr-xr-x  2 root  wheel      512 26 ÉÀÎ 17:15 x
/dev/ttyv0
19:15:39
#cd /home/

19:15:42
#cd /home/Desktop
bash: cd: /home/Desktop: No such file or directory
19:15:54
#pw
usage:
  pw [user|group|lock|unlock] [add|del|mod|show|next] [help|switches/values]
19:15:59
#pwd
/home
19:16:02
#ls
user
19:16:07
#cd user

19:16:10
#cd Desktop

19:16:16
#ls
proj
19:16:18
#cd proj/

19:16:22
#cd x-project/

19:16:28
#touch x

19:16:36
#cd ..

19:16:39
#cd y-project/touch y
bash: cd: y-project/touch: No such file or directory
19:16:51
#ls
x-project       y-project
19:16:54
#cd y-project/

19:16:58
#touch y

19:17:03
#ls
y
19:17:07
#cd ..

19:17:17
#ls
x-project       y-project
19:18:19
#cd x-project/

19:18:23
#touch y

19:18:29
#touch z

19:18:40
#cd ..

19:18:50
#cd x-project/

19:18:54
#ls
x       y       z
19:18:59
#cd x

19:19:03
#cd ..

19:19:11
#cd y
bash: cd: y: Not a directory
19:19:13
#cd ..

19:19:24
#rm x
rm: x: No such file or directory
19:19:28
#ls
x-project       y-project
19:19:31
#cd x-project/

19:19:35
#la
bash: la: ËÏÍÁÎÄÁ ÎÅ ÎÁÊÄÅÎÁ
19:19:37
#ls
x       y       z
19:19:39
#rm x
rm: x: is a directory
19:19:44
#rm -r x

19:19:52
#touch x

19:19:58
#ls
x       y       z
19:20:00
#cd x
bash: cd: x: Not a directory
19:20:03
#cd ..

19:20:17
#~/proj/x-project/x ~/proj/x-project/y ~/proj/x-project/z ~/b
in
bash: /root/proj/x-project/x: No such file or directory
19:21:30
#vim
прошло 20 минут
19:41:56
#=1S

19:41:56
#vim
19:41:56
#vi
прошло 15 минут
19:57:06
#jjjklkjklklkjjkkl
bash: /root/.vim/vimrc: No such file or directory
прошло 10 минут
20:08:03
#cd /

20:08:29
#cd usr

20:08:35
#ls
.snap   bin     games   include libdata local   ports   share
X11R6   compat  home    lib     libexec obj     sbin    src

Статистика

Время первой команды журнала18:58:57 2009- 6-26
Время последней команды журнала20:08:35 2009- 6-26
Количество командных строк в журнале101
Процент команд с ненулевым кодом завершения, %20.79
Процент синтаксически неверно набранных команд, % 4.95
Суммарное время работы с терминалом *, час 1.16
Количество командных строк в единицу времени, команда/мин 1.45
Частота использования команд
cd35|=================================| 33.98%
ls26|=========================| 25.24%
rm9|========| 8.74%
touch8|=======| 7.77%
mkdir3|==| 2.91%
vim3|==| 2.91%
sysctl2|=| 1.94%
pwd2|=| 1.94%
vi2|=| 1.94%
top1|| 0.97%
=1S1|| 0.97%
clean1|| 0.97%
cp1|| 0.97%
pw1|| 0.97%
jjjklkjklklkjjkkl1|| 0.97%
less1|| 0.97%
cat1|| 0.97%
rmdir1|| 0.97%
la1|| 0.97%
grep1|| 0.97%
x1|| 0.97%
a1|| 0.97%
____
*) Интервалы неактивности длительностью 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$