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

Содержание

Журнал

Суббота (03/12/11)

/dev/pts/3
16:13:10
#cd /usr/

16:13:29
#ls
bin  games  include  lib  lib64  local  lost+found  sbin  share  src  X11R6
16:13:31
#cd src

16:13:45
#ls
linux-2.6.37.3  linux-2.6.37.3.tar.bz2
16:13:47
#cd linux-2.6.37.3/

16:13:53
#ls
arch           drivers   Kbuild       mm              samples     usr
block          firmware  Kconfig      modules.order   scripts     virt
COPYING        fs        kernel       Module.symvers  security    vmlinux
CREDITS        include   lib          net             sound       vmlinux.o
crypto         init      MAINTAINERS  README          System.map
Documentation  ipc       Makefile     REPORTING-BUGS  tools
16:13:55
#cd sound

/dev/pts/0
16:14:13
#kpartx
usage : kpartx [-a|-d|-l] [-v] wholedisk
        -a add partition devmappings
        -d del partition devmappings
        -l list partitions devmappings that would be added by -a
        -p set device name-partition number delimiter
        -g force GUID partition table (GPT)
        -v verbose
16:14:22
#kpartx -a
usage : kpartx [-a|-d|-l] [-v] wholedisk
        -a add partition devmappings
        -d del partition devmappings
        -l list partitions devmappings that would be added by -a
        -p set device name-partition number delimiter
        -g force GUID partition table (GPT)
        -v verbose
16:14:24
#kpartx -a /dev/x
xconsole  xen/      xvda1     xvda2
16:14:24
#kpartx -a /dev/xvda2

/dev/pts/3
16:14:27
#ls
ac97_bus.c  built-in.o  Kconfig   parisc  soc               sound_firmware.o
ac97_bus.o  core        last.c    pci     sound_core.c      sparc
aoa         drivers     Makefile  pcmcia  sound_core.o      spi
arm         i2c         mips      ppc     soundcore.o       synth
atmel       isa         oss       sh      sound_firmware.c  usb
/dev/pts/0
16:14:34
#ls /dev/xvda2
/dev/xvda2
16:14:40
#ls /dev/xvda
xvda1  xvda2
16:14:40
#ls /dev/xvda
xvda1  xvda2
16:14:40
#ls /dev/mapper/
control  xvda2p1  xvda2p2  xvda2p5  xvda2p6
16:14:59
#mkfs
Usage: mkfs [-V] [-t fstype] [fs-options] device [size]
16:15:32
#mkfs -t ext4 /dev/mapper/xdva2p1
mke2fs 1.41.12 (17-May-2010)
Could not stat /dev/mapper/xdva2p1 --- Нет такого файла или каталога
The device apparently does not exist; did you specify it correctly?
16:15:53
#mkfs -t ext4 /dev/mapper/xvda2p1
mke2fs 1.41.12 (17-May-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
66384 inodes, 265064 blocks
13253 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=272629760
9 block groups
32768 blocks per group, 32768 fragments per group
7376 inodes per group
Superblock backups stored on blocks:
        32768, 98304, 163840, 229376
Writing inode tables: done
Creating journal (8192 blocks): done
Writing superblocks and filesystem accounting information: done
This filesystem will be automatically checked every 24 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.
16:16:10
#mkfs -t ext4 /dev/mapper/xvda2p2
mke2fs 1.41.12 (17-May-2010)
/dev/mapper/xvda2p2 is apparently in use by the system; will not make a filesystem here!
16:16:47
#mkfs -t ext4 /dev/mapper/xvda2p2
mke2fs 1.41.12 (17-May-2010)
/dev/mapper/xvda2p2 is apparently in use by the system; will not make a filesystem here!
16:17:06
#mkfs
mkfs          mkfs.bfs      mkfs.cramfs   mkfs.ext2     mkfs.ext3     mkfs.ext4     mkfs.ext4dev  mkfs.minix
16:17:06
#mkfs.ext4 /dev/mapper/xvda2p2
mke2fs 1.41.12 (17-May-2010)
/dev/mapper/xvda2p2 is apparently in use by the system; will not make a filesystem here!
16:18:50
#mkfs -t ext4 /dev/mapper/xvda2p6
mke2fs 1.41.12 (17-May-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
260608 inodes, 1042209 blocks
52110 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=1069547520
32 block groups
32768 blocks per group, 32768 fragments per group
8144 inodes per group
Superblock backups stored on blocks:
        32768, 98304, 163840, 229376, 294912, 819200, 884736
Writing inode tables: done
Creating journal (16384 blocks): done
Writing superblocks and filesystem accounting information:
done
This filesystem will be automatically checked every 35 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.
16:18:58
#ls

16:19:06
#ls

16:19:11
#cd /

16:19:14
#ls
bin  boot  dev  etc  home  lib  log  lost+found  media  mnt  opt  proc  root  sbin  selinux  srv  sys  tmp  usr  var
16:19:16
#mount /dev/mapper/xvda2p1 /mnt

16:19:39
#mount
/dev/xvda1 on / type ext4 (rw,errors=remount-ro)
tmpfs on /lib/init/rw type tmpfs (rw,nosuid,mode=0755)
proc on /proc type proc (rw,noexec,nosuid,nodev)
sysfs on /sys type sysfs (rw,noexec,nosuid,nodev)
udev on /dev type tmpfs (rw,mode=0755)
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev)
devpts on /dev/pts type devpts (rw,noexec,nosuid,gid=5,mode=620)
none on /selinux type selinuxfs (rw,relatime)
/dev/mapper/xvda2p1 on /mnt type ext4 (rw)
16:19:50
#umount /mnt

16:23:50
#mount
/dev/xvda1 on / type ext4 (rw,errors=remount-ro)
tmpfs on /lib/init/rw type tmpfs (rw,nosuid,mode=0755)
proc on /proc type proc (rw,noexec,nosuid,nodev)
sysfs on /sys type sysfs (rw,noexec,nosuid,nodev)
udev on /dev type tmpfs (rw,mode=0755)
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev)
devpts on /dev/pts type devpts (rw,noexec,nosuid,gid=5,mode=620)
none on /selinux type selinuxfs (rw,relatime)
16:23:53
#kpartx -d /dev/xvda2

16:24:04
#ls /dev/mapper/
control
16:24:25
#cfdisk
16:24:53
#cfdisk /dev/xvda2
16:26:53
#ls /dev/mapper/
control
16:26:57
#ls /dev/x
xconsole  xen/      xvda1     xvda2
16:26:57
#ls /dev/xvda2
/dev/xvda2
16:27:15
#ls /dev/xvda2/
ls: невозможно получить доступ к /dev/xvda2/: Это не каталог
16:27:18
#kpartx
usage : kpartx [-a|-d|-l] [-v] wholedisk
        -a add partition devmappings
        -d del partition devmappings
        -l list partitions devmappings that would be added by -a
        -p set device name-partition number delimiter
        -g force GUID partition table (GPT)
        -v verbose
16:27:48
#kpartx -a /dev/xvda2

16:27:56
#ls /dev/mapper/
control  xvda2p1  xvda2p2  xvda2p3

Статистика

Время первой команды журнала16:13:10 2011- 3-12
Время последней команды журнала16:27:56 2011- 3-12
Количество командных строк в журнале43
Процент команд с ненулевым кодом завершения, %27.91
Процент синтаксически неверно набранных команд, % 0.00
Суммарное время работы с терминалом *, час 0.25
Количество командных строк в единицу времени, команда/мин 2.91
Частота использования команд
ls17|=======================================| 39.53%
mkfs7|================| 16.28%
kpartx7|================| 16.28%
cd5|===========| 11.63%
mount3|======| 6.98%
cfdisk2|====| 4.65%
mkfs.ext41|==| 2.33%
umount1|==| 2.33%
____
*) Интервалы неактивности длительностью 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$