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

Содержание

Журнал

Пятница (03/17/06)

/dev/ttyp2
16:17:57
$hello

16:22:59
$hello

16:22:59
$hello

16:22:59
$hello

16:22:59
$hello

16:22:59
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:00
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:01
$hello

16:23:02
$hello

16:23:02
$hello

16:23:02
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

16:23:03
$hello

/dev/ttyp2
16:23:14
$sudo adduser roman
Password:
Username: roman
Full name: roman
Uid (Leave empty for default):
Login group [roman]:
Login group is roman. Invite roman into other groups? []:
Login class [default]:
Shell (sh csh tcsh bash nologin) [sh]:
Home directory [/home/roman]:
Use password-based authentication? [yes]:
...
Uid        : 1002
Class      :
Groups     : roman
Home       : /home/roman
Shell      : /bin/sh
Locked     : no
OK? (yes/no): yes
adduser: INFO: Successfully added (roman) to the user database.
Add another user? (yes/no): no
Goodbye!
/dev/ttyp1
16:27:38
$w
16:27  up  1:42, 2 users, load averages: 0,57 0,16 0,09
USER             TTY      FROM              LOGIN@  IDLE WHAT
root             v0       -                16:26       - script -t 0 -q /root/.
user             p1       :0.0             16:27       - script -t 0 -q /home/u
16:27:40
$deluser
bash: deluser: command not found
16:30:57
$del ser
bash: del: command not found
16:31:02
$[user@fbsd2:~]$ cd /sbin

16:33:48
$ls
adjkerntz       fsck_4.2bsd     ip6fw           mount_mfs       reboot
atacontrol      fsck_ffs        ipf             mount_msdosfs   restore
atm             fsck_msdosfs    ipfs            mount_nfs       rmd160
atmconfig       fsck_ufs        ipfstat         mount_nfs4      route
badsect         fsdb            ipftest         mount_ntfs      routed
bsdlabel        fsirand         ipfw            mount_nullfs    rrestore
camcontrol      gbde            ipmon           mount_procfs    rtquery
ccdconfig       gconcat         ipnat           mount_reiserfs  rtsol
clri            geli            ippool          mount_std       savecore
comcontrol      geom            ipresend        mount_udf       sconfig
...
dmesg           gpt             mdconfig        nfsiod          sunlabel
dump            graid3          mdmfs           nologin         swapctl
dumpfs          growfs          mknod           nos-tun         swapoff
dumpon          gshsec          mksnap_ffs      pfctl           swapon
fastboot        gstripe         mount           pflogd          sysctl
fasthalt        gvinum          mount_cd9660    ping            tunefs
fdisk           halt            mount_devfs     ping6           umount
ffsinfo         ifconfig        mount_ext2fs    quotacheck
fore_dnld       ilmid           mount_fdescfs   rcorder
fsck            init            mount_linprocfs rdump
16:33:49
$ps aux \ head
ps: illegal argument:  head
usage: ps [-aCcefHhjlmrSTuvwXxZ] [-O fmt | -o fmt] [-G gid[,gid...]]
          [-M core] [-N system]
          [-p pid[,pid...]] [-t tty[,tty...]] [-U user[,user...]]
       ps [-L]
16:34:06
$ps aux |head
USER    PID %CPU %MEM   VSZ   RSS  TT  STAT STARTED      TIME COMMAND
root     11 98,6  0,0     0     8  ??  RL   14:45    99:31,27 [idle]
root      0  0,0  0,0     0     0  ??  WLs  14:45     0:00,00 [swapper]
root      1  0,0  0,0   724   356  ??  ILs  14:45     0:00,01 /sbin/init --
root      2  0,0  0,0     0     8  ??  DL   14:45     0:00,26 [g_event]
root      3  0,0  0,0     0     8  ??  DL   14:45     0:00,36 [g_up]
root      4  0,0  0,0     0     8  ??  DL   14:45     0:00,42 [g_down]
root      5  0,0  0,0     0     8  ??  DL   14:45     0:00,00 [thread taskq]
root      6  0,0  0,0     0     8  ??  DL   14:45     0:00,00 [kqueue taskq]
root      7  0,0  0,0     0     8  ??  DL   14:45     0:00,02 [fdc0]
16:34:15
$cd /etc/

16:36:44
$ls
X11                     login.conf.db           pwd.db
aliases                 mac.conf                rc
amd.map                 mail                    rc.bsdextended
apmd.conf               mail.rc                 rc.conf
auth.conf               make.conf               rc.d
bluetooth               manpath.config          rc.firewall
crontab                 manpath.config.bak      rc.firewall6
csh.cshrc               master.passwd           rc.initdiskless
csh.login               motd                    rc.resume
csh.logout              mtree                   rc.sendmail
...
hosts                   pccard_ether            ssh
hosts.allow             periodic                ssl
hosts.equiv             pf.conf                 sysctl.conf
hosts.lpd               pf.os                   syslog.conf
inetd.conf              phones                  termcap
isdn                    portsnap.conf           ttys
localtime               ppp                     usbd.conf
locate.rc               printcap                wall_cmos_clock
login.access            profile
login.conf              protocols

Статистика

Время первой команды журнала16:17:57 2006- 3-17
Время последней команды журнала16:36:44 2006- 3-17
Количество командных строк в журнале101
Процент команд с ненулевым кодом завершения, %91.09
Процент синтаксически неверно набранных команд, % 1.98
Суммарное время работы с терминалом *, час 0.31
Количество командных строк в единицу времени, команда/мин 5.38
Частота использования команд
hello91|========================================================================================| 88.35%
ps2|=| 1.94%
ls2|=| 1.94%
sudo1|| 0.97%
deluser1|| 0.97%
del1|| 0.97%
cd1|| 0.97%
head1|| 0.97%
[user@fbsd2:~]$1|| 0.97%
w1|| 0.97%
adduser1|| 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$