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

Содержание

Журнал

Суббота (01/21/06)

/dev/pts/3
09:52:02
#vim 1.txt
прошло 69 минут
11:01:46
#which vim
/usr/bin/vim
11:01:50
#ldd `which vim`
        not a dynamic executable
прошло 34 минуты
11:35:53
#qt
qt20fix      qtdoc        qtinfo       qtrename140  qtyuv4toyuv
qtdechunk    qtdump       qtrechunk    qtstreamize
11:35:53
#mkfs
mkfs           mkfs.ext2      mkfs.jfs       mkfs.reiserfs  mkfs.xfs
mkfs.cramfs    mkfs.ext3      mkfs.msdos     mkfs.vfat
11:35:53
#mfdisk -l /dev/hda

11:43:32
#fdisk -l /dev/hdb
Disk /dev/hdb: 40.0 GB, 40016019456 bytes
16 heads, 63 sectors/track, 77536 cylinders
Units = cylinders of 1008 * 512 = 516096 bytes
   Device Boot      Start         End      Blocks   Id  System
/dev/hdb1               1        2032     1024096+  83  Linux
Partition 1 does not end on cylinder boundary.
/dev/hdb2   *        2033        4063     1023624    c  W95 FAT32 (LBA)
Partition 2 does not end on cylinder boundary.
/dev/hdb3            4064       36573    16385040    5  Extended
/dev/hdb5            4064        6095     1024096+  82  Linux swap
/dev/hdb6            6096        8127     1024096+  83  Linux
/dev/hdb7            8128       12191     2048224+  83  Linux
/dev/hdb8           12192       16255     2048224+  83  Linux
/dev/hdb9           16256       36573    10240240+  83  Linux
11:46:14
#mc
11:48:45
#set -o vi

11:51:36
#set -o emacs

11:52:15
#TERM=vt100

11:53:37
#TERM=dumb

11:53:43
#TERM=xterm

11:59:54
#djfjk dfghdkg sdfjkgsdhgkhdsjkfh
bash: djfjk: command not found
12:01:53
#djfjk dfghdkg sdfjkgsdhgkhdsjkfh
bash: djfjk: command not found
12:01:57
#djfjk dfghdkg sdfjkgsdhgkhdsjkfh
bash: djfjk: command not found
12:02:14
#djfjk dfghdkg sdfjkgsdhgkhdsjkfh
bash: djfjk: command not found
12:02:19
#man readline
12:08:22
#history
  639  grep ^a /usr/share/dict/words | head
  640  grep -v '\'' /usr/share/dict/words | head
  641  grep -v "'" /usr/share/dict/words | head
  642  grep -v "['&-]" /usr/share/dict/words | head
  643  grep -v "['&-]" /usr/share/dict/words | head -50
  644  grep -v "['&/.-]" /usr/share/dict/words | head -50
  645  grep -v "['&/.-]" /usr/share/dict/words | head -50
  646  grep -v "['&/.-]" /usr/share/dict/words | head -50 | xargs ln hello
  647  grep -v "['&/.-]" /usr/share/dict/words | head -50 | while read name; do ln hello $name ; done
  648  ls -l
...
  778  set -o emacs
  779  TERM=vt100
  780  TERM=dumb
  781  TERM=xterm
  782  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  783  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  784  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  785  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  786  man readline
  787  history
12:08:48
#history | less
12:10:38
#!98
cd
12:10:40
#history -20
bash: history: -2: invalid option
history: usage: history [-c] [-d offset] [n] or history -awrn [filename] or history -ps arg [arg...]
12:11:05
#history 20
  772  which vim
  773  ldd `which vim`
  774  fdisk -l /dev/hda
  775  fdisk -l /dev/hdb
  776  mc
  777  set -o vi
  778  set -o emacs
  779  TERM=vt100
  780  TERM=dumb
  781  TERM=xterm
  782  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  783  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  784  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  785  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  786  man readline
  787  history
  788  history | less
  789  cd
  790  history -20
  791  history 20
12:11:07
#!h
history 20
  773  ldd `which vim`
  774  fdisk -l /dev/hda
  775  fdisk -l /dev/hdb
  776  mc
  777  set -o vi
  778  set -o emacs
  779  TERM=vt100
  780  TERM=dumb
  781  TERM=xterm
  782  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  783  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  784  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  785  djfjk dfghdkg sdfjkgsdhgkhdsjkfh
  786  man readline
  787  history
  788  history | less
  789  cd
  790  history -20
  791  history 20
  792  history 20
12:11:29
#alias exit='echo Press Ctrl-A D to detach screen'

12:16:35
#vi super-script
0a1,2
> echo script is running
> 
12:17:03
#chmod +x super-script

12:17:25
#./super-script
script is running
12:17:28
#history 4
  794  vi super-script
  795  chmod +x super-script
  796  ./super-script
  797  history 4
12:17:49
#ls -l ~/.bash_history
-rw-r--r--  1 root root 13042 Янв 21 12:10 /root/.bash_history
12:18:50
#> ~/.bash_history

12:20:26
#echo $H
$HISTCMD       $HISTFILESIZE  $HOME          $HOSTTYPE
$HISTFILE      $HISTSIZE      $HOSTNAME
12:20:26
#echo $HISTFILESIZE
1000
12:24:28
#HISTFILESIZE=10000

12:24:53
#tail ~/.bash_profile
# LabMaker:START
/usr/local/bin/l3-agent > /dev/null 2>&1 /dev/null
# LabMaker:END
# Get the aliases and functions
if [ -f ~/.bashrc ]; then
        . ~/.bashrc
fi
12:24:59
#tail ~/.bash_history
TERM=vt100
TERM=dumb
TERM=xterm
djfjk dfghdkg sdfjkgsdhgkhdsjkfh
djfjk dfghdkg sdfjkgsdhgkhdsjkfh
djfjk dfghdkg sdfjkgsdhgkhdsjkfh
djfjk dfghdkg sdfjkgsdhgkhdsjkfh
man readline
history
history | less
12:25:02
#i=0

12:25:11
#while [ $i -lt 20000 ]
> do
> echo man bash >> ~/.bash_history
> i=$((i+1))
> done
12:25:53
#bash

12:26:09
#history
  853  man bash
  854  man bash
  855  man bash
  856  man bash
  857  man bash
  858  man bash
  859  man bash
  860  man bash
  861  man bash
  862  man bash
...
  992  man bash
  993  man bash
  994  man bash
  995  man bash
  996  man bash
  997  man bash
  998  man bash
  999  man bash
 1000  man bash
 1001  history
12:26:12
#echo $HISTFILESIZE
1000
12:26:24
#echo $HISTSIZE
1000
12:26:31
#exit
exit
12:26:41
#echo $HISTFILESIZE
10000
12:26:54
#history
  659  exit
  660  w
  661  screen -x
  662  screen -x
  663  screen -x
  664  umount /media/cdrom/
  665  cat /dev/cdrom > /home/user/frenzy.iso
  666  umount /media/cdrom/
  667  ls dev
  668  dmesg
...
  798  ls -l ~/.bash_history
  799  echo $HISTFILESIZE
  800  HISTFILESIZE=10000
  801  tail ~/.bash_profile
  802  tail ~/.bash_history
  803  i=0
  804  while [ $i -lt 20000 ]; do echo man bash >> ~/.bash_history ; i=$((i+1)); done
  805  bash
  806  echo $HISTFILESIZE
  807  history
12:26:56
#while [ $i -lt 100000 ]; do echo man bash >> ~/.bash_history ;

12:26:56
#i=0 ; while [ $i -lt 100000 ]; do echo man bash >> ~/.bash_his
ory ; i=$((i+1)); done
12:28:33
#export HISTSIZE=100000

12:29:04
#bash

12:29:06
#history
 2794  man bash
 2795  man bash
 2796  man bash
 2797  man bash
 2798  man bash
 2799  man bash
 2800  man bash
 2801  man bash
 2802  man bash
 2803  man bash
...
 2933  man bash
 2934  man bash
 2935  man bash
 2936  man bash
 2937  man bash
 2938  man bash
 2939  man bash
 2940  man bash
 2941  man bash
 2942  man bash
12:31:09
#exit
exit
12:31:15
#> ~/.bash_history

12:31:28
#vi /usr/local/bin/l3
12:31:28
#vi /usr/local/bin/l3config.pm
12:32:29
#which echo
/bin/echo
12:32:36
#man bash
12:33:06
#vi /usr/local/bin/l3config.pm
12:33:13
#user
useradd      userhelper   userisdnctl  usermount    userpasswd
userdel      userinfo     usermod      usernetctl   users
12:33:13
#useradd
1.txt               .gstreamer-0.8/     mytgz/
.bash_history       .gtkrc              nohup.out
.bash_logout        hello               .rnd
.bash_profile       hhhh                sort
.bashrc             hi                  .ssh/
.cshrc              .inputrc            super-script
.default_contexts   .kde/               sym-hello
final_settings.err  .lilalo/            .tcshrc
.gconf/             logs.tgz            .viminfo
.gconfd/            .mc/                .vimrc
.gnome/             .mozilla/           .Xauthority
.gnome2/            mymotd              .Xresources
.gnome2_private/    mynologin
12:33:13
#useradd /
.autofsck   boot/       initrd/     misc/       root/       tmp/
.automount/ dev/        lib/        mnt/        sbin/       usr/
b/          etc/        lost+found/ opt/        selinux/    var/
bin/        home/       media/      proc/       sys/
12:33:13
#ls /etc/bash_completion
/etc/bash_completion
12:40:08
#. /etc/bash_completion

12:40:19
#passwd
adm        games      ident      nfsnobody  pcap       rpm        user
bin        gdm        lp         nobody     pvm        shutdown   uucp
daemon     gopher     mail       nscd       root       smmsp      vcsa
dbus       haldaemon  mailnull   ntp        rpc        sshd       xfs
ftp        halt       news       operator   rpcuser    sync

Статистика

Время первой команды журнала09:52:02 2006- 1-21
Время последней команды журнала12:40:19 2006- 1-21
Количество командных строк в журнале63
Процент команд с ненулевым кодом завершения, %12.70
Процент синтаксически неверно набранных команд, % 6.35
Суммарное время работы с терминалом *, час 1.07
Количество командных строк в единицу времени, команда/мин 0.98
Частота использования команд
history8|==========| 10.96%
echo5|======| 6.85%
>4|=====| 5.48%
vi4|=====| 5.48%
djfjk4|=====| 5.48%
while3|====| 4.11%
.bash_history3|====| 4.11%
man2|==| 2.74%
useradd2|==| 2.74%
set2|==| 2.74%
ls2|==| 2.74%
do2|==| 2.74%
i=02|==| 2.74%
tail2|==| 2.74%
bash2|==| 2.74%
exit2|==| 2.74%
which2|==| 2.74%
passwd1|=| 1.37%
chmod1|=| 1.37%
TERM=dumb1|=| 1.37%
mfdisk1|=| 1.37%
qt1|=| 1.37%
.1|=| 1.37%
super-script1|=| 1.37%
alias1|=| 1.37%
.bash_his1|=| 1.37%
HISTFILESIZE=100001|=| 1.37%
!981|=| 1.37%
!h1|=| 1.37%
fdisk1|=| 1.37%
ldd1|=| 1.37%
TERM=xterm1|=| 1.37%
vim1|=| 1.37%
export1|=| 1.37%
mkfs1|=| 1.37%
user1|=| 1.37%
TERM=vt1001|=| 1.37%
less1|=| 1.37%
mc1|=| 1.37%
____
*) Интервалы неактивности длительностью 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$