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

Содержание

Журнал

Четверг (08/31/06)

/dev/ttyp7
15:30:14
#cd

15:30:19
#cp /usr/share/examples/cvsup/
README            gnats-supfile     refuse.README     www-supfile
cvs-supfile       ports-supfile     stable-supfile
doc-supfile       refuse            standard-supfile
15:30:19
#cp /usr/share/examples/cvsup/cvs-supfile .

15:30:52
#vi cvs-supfile
15:31:13
#cp /usr/share/examples/cvsup/
README            gnats-supfile     refuse.README     www-supfile
cvs-supfile       ports-supfile     stable-supfile
doc-supfile       refuse            standard-supfile
15:31:13
#cp /usr/share/examples/cvsup/standard-supfile .

15:31:23
#vi standard-supfile
54c54
< *default release=cvs tag=RELENG_6_1
---
> *default release=cvs tag=.
15:31:58
#vi standard-supfile
51c51
< *default host=CHANGE_THIS.FreeBSD.org
---
> *default host=ftp2.ua.FreeBSD.org
15:32:12
#sudo cvsup -g -L2 standard-supfile
 Edit src/contrib/ipfilter/test/dotest
  Add delta 1.1.1.4 2005.12.30.11.34.53 guido
 Edit src/contrib/ipfilter/test/expected/bpf1
  Add delta 1.1.1.2 2005.12.30.11.34.53 guido
 Edit src/contrib/ipfilter/test/expected/f13
  Add delta 1.1.1.3 2005.12.30.11.34.53 guido
 Edit src/contrib/ipfilter/test/expected/f17
  Add delta 1.1.1.3 2005.12.30.11.34.53 guido
 Checkout src/contrib/ipfilter/test/expected/f18
 Checkout src/contrib/ipfilter/test/expected/f19
...
 Checkout src/contrib/ipfilter/test/regress/i21
 Edit src/contrib/ipfilter/test/regress/i4
  Add delta 1.1.1.3 2005.12.30.11.34.53 guido
 Edit src/contrib/ipfilter/test/regress/i5
  Add delta 1.1.1.2 2006.08.16.11.51.31 guido
 Edit src/contrib/ipfilter/test/regress/i6
  Add delta 1.1.1.3 2005.12.30.11.34.53 guido
 Edit src/contrib/ipfilter/test/regress/i7
  Add delta 1.1.1.3 2005.12.30.11.34.53 guido
 Edit src/contrib/ipfilter/test/regress/i8
прошло 25 минут
15:57:13
#less standard-supfile
прошло 13 минут
16:10:32
#cd /usr/src

16:10:36
#make buildworld
echo tbl: /usr/lib/libstdc++.a >> .depend
===> gnu/usr.bin/groff/src/roff (depend)
===> gnu/usr.bin/groff/src/roff/groff (depend)
rm -f .depend
mkdep -f .depend -a    -DHAVE_CONFIG_H -I/usr/src/gnu/usr.bin/groff/src/roff/groff/../../../../../../contrib/groff/src/include -I/usr/src/gnu/usr.bin/groff/src/roff/groff/../../../src/include -I/usr/obj/usr/src/tmp/legacy/usr/include /usr/src/gnu/usr.bin/groff/src/roff/groff/../../../../../../contrib/groff/src/roff/groff/pipeline.c
mkdep -f .depend -a    -DHAVE_CONFIG_H -I/usr/src/gnu/usr.bin/groff/src/roff/groff/../../../../../../contrib/groff/src/include -I/usr/src/gnu/usr.bin/groff/src/roff/groff/../../../src/include -I/usr/obj/usr/src/tmp/legacy/usr/include    /usr/src/gnu/usr.bin/groff/src/roff/groff/../../../../../../contrib/groff/src/roff/groff/groff.cpp
echo groff: /usr/lib/libc.a /usr/obj/usr/src/tmp/usr/src/gnu/usr.bin/groff/src/roff/groff/../../../src/libs/libgroff/libgroff.a /usr/lib/libm.a /usr/obj/usr/src/tmp/legacy/usr/lib/libegacy.a >> .depend
echo groff: /usr/lib/libstdc++.a >> .depend
===> gnu/usr.bin/groff/src/roff/grog (depend)
===> gnu/usr.bin/groff/src/roff/nroff (depend)
...
Making B
Making BI
Making S
Making L
Making CW
Making DESC
===> gnu/usr.bin/groff/man (all)
===> gnu/usr.bin/groff/src (all)
===> gnu/usr.bin/groff/src/libs (all)
===> gnu/usr.bin/groff/src/libs/libgroff (all)
прошло >3 часов
19:11:34
#date
]ÐÑÔÎÉÃÁ,  1 ÓÅÎÔÑÂÒÑ 2006 Ç. 12:21:24 (EEST)

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

12:25:20
#pkg_add w3w
pkg_add: can't stat package file 'w3w'
12:30:13
#pkg_add w3m
pkg_add: can't stat package file 'w3m'
12:31:08
#pkg_add -r w3m
Fetching ftp://ftp.freebsd.org/pub/FreeBSD/ports/i386/packages-6.1-release/Latest/w3m.tbz... Done.
Fetching ftp://ftp.freebsd.org/pub/FreeBSD/ports/i386/packages-6.1-release/All/boehm-gc-6.6_3.tbz... Done.
12:31:27
#w3m
w3m version w3m/0.5.1, options lang=en,color,ansi-color,mouse,sysmouse,menu,cookie,ssl,ssl-verify,external-uri-loader,w3mmailer,nntp,ipv6,alarm,mark
usage: w3m [options] [URL or filename]
options:
    -t tab           set tab width
    -r               ignore backspace effect
    -l line          # of preserved line (default 10000)
    -B               load bookmark
    -bookmark file   specify bookmark file
    -T type          specify content-type
    -m               internet message mode
...
    -S               squeeze multiple blank lines
    -W               toggle wrap search mode
    -X               don't use termcap init/deinit
    -title[=TERM]    set buffer name to terminal title string
    -o opt=value     assign value to config option
    -show-option     print all config options
    -config file     specify config file
    -help            print this usage message
    -version         print w3m version
    -debug           DO NOT USE
12:31:43
#w3m www.ua-tuning.com

12:32:22
#clear

12:32:26
#make buildkernel kernconf=MYKERNEL
rm -f .depend GPATH GRTAGS GSYMS GTAGS
===> hfa (cleandir)
===> hfa/hfa (cleandir)
rm -f export_syms hfa.ko hfa.kld hfa_freebsd.o fore_buffer.o fore_init.o fore_receive.o fore_vcm.o fore_command.o fore_intr.o fore_stats.o fore_globals.o fore_timer.o fore_if.o fore_output.o fore_transmit.o @ machine hfa.ko.debug hfa.ko.symbols bus_if.h device_if.h
rm -f .depend GPATH GRTAGS GSYMS GTAGS
===> hfa/pci (cleandir)
rm -f export_syms hfa_pci.ko hfa_pci.kld hfa_pci.o @ machine hfa_pci.ko.debug hfa_pci.ko.symbols pci_if.h bus_if.h device_if.h
rm -f .depend GPATH GRTAGS GSYMS GTAGS
===> hifn (cleandir)
rm -f export_syms hifn.ko hifn.kld hifn7751.o @ machine hifn.ko.debug hifn.ko.symbols opt_hifn.h opt_bus.h pci_if.h bus_if.h device_if.h crypto_if.h
...
===> ip_mroute_mod (cleandir)
rm -f export_syms ip_mroute.ko ip_mroute.kld ip_mroute.o @ machine ip_mroute.ko.debug ip_mroute.ko.symbols opt_mac.h opt_mrouting.h
rm -f .depend GPATH GRTAGS GSYMS GTAGS
===> ipmi (cleandir)
rm -f export_syms ipmi.ko ipmi.kld ipmi.o ipmi_pci.o ipmi_smbios.o @ machine ipmi.ko.debug ipmi.ko.symbols pci_if.h bus_if.h device_if.h vnode_if.h vnode_if_newproto.h vnode_if_typedef.h
rm -f .depend GPATH GRTAGS GSYMS GTAGS
===> ips (cleandir)
rm -f export_syms ips.ko ips.kld ips.o ips_pci.o ips_disk.o ips_commands.o ips_ioctl.o @ machine ips.ko.debug ips.ko.symbols pci_if.h bus_if.h device_if.h
rm -f .depend GPATH GRTAGS GSYMS GTAGS
===> ipw (cleandir)
12:41:18
#cd
COPYRIGHT          UPDATING           include/           secure/
LOCKS              bin/               kerberos5/         share/
MAINTAINERS        contrib/           lib/               sys/
Makefile           crypto/            libexec/           tools/
Makefile.inc1      etc/               release/           usr.bin/
ObsoleteFiles.inc  games/             rescue/            usr.sbin/
README             gnu/               sbin/
12:41:18
#cd sys/i386/conf/

12:42:12
#ls
.cvsignore      GENERIC         MAC             Makefile        PAE
DEFAULTS        GENERIC.hints   MYKERNEL        NOTES           XBOX
12:42:12
#config MYKERNEL
config: MYKERNEL:21: only one machine directive is allowed
12:42:15
#vi MYKERNEL
12:42:37
#config MYKERNEL
config: MYKERNEL:21: only one machine directive is allowed
12:42:38
#vi MYKERNEL
21c21
< machine		i386
---
> #machine		i386
12:42:52
#config MYKERNEL
MYKERNEL: unknown option "BRIDGE"
12:42:53
#vi MYKERNEL
12:43:10
#vi MYKERNEL
70c70
< options		BRIDGE
---
> #options		BRIDGE
12:43:20
#config MYKERNEL
ERROR: version of config(8) does not match kernel!
config version = 600003, version required = 600004
Make sure that /usr/src/usr.sbin/config is in sync
with your /usr/src/sys and install a new config binary
before trying this again.
If running the new config fails check your config
file against the GENERIC or LINT config files for
changes in config syntax, or option/device naming
conventions
12:43:22
#/usr/src/usr.sbin/config MYKERNEL
bash: /usr/src/usr.sbin/config: is a directory
12:43:49
#cd /usr/src/usr.sbin/config/

12:44:00
#ls
Makefile        config.8        configvers.h    mkheaders.c
SMM.doc         config.h        lang.l          mkmakefile.c
config.5        config.y        main.c          mkoptions.c

Статистика

Время первой команды журнала15:30:14 2006- 8-31
Время последней команды журнала12:44:00 2006- 9- 1
Количество командных строк в журнале34
Процент команд с ненулевым кодом завершения, %23.53
Процент синтаксически неверно набранных команд, % 0.00
Суммарное время работы с терминалом *, час 0.98
Количество командных строк в единицу времени, команда/мин 0.58
Частота использования команд
vi7|====================| 20.00%
config5|==============| 14.29%
cd5|==============| 14.29%
cp4|===========| 11.43%
pkg_add3|========| 8.57%
w3m2|=====| 5.71%
ls2|=====| 5.71%
make2|=====| 5.71%
sudo1|==| 2.86%
less1|==| 2.86%
cvsup1|==| 2.86%
clear1|==| 2.86%
date1|==| 2.86%
____
*) Интервалы неактивности длительностью 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$