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

Содержание

Журнал

Вторник (08/29/06)

/dev/ttyp0
10:54:07
#ls
exit
Makefile        distinfo        files           pkg-descr
10:54:26
#make install
  $restore $backupdir/* `echo "./sed.info" | sed 's|[^/]*$||'`; \
fi; \
rm -rf $backupdir; exit $rc
gmake[2]: Leaving directory `/usr/ports/textproc/gsed/work/sed-4.1.4/doc'
Making all in testsuite
gmake[2]: Entering directory `/usr/ports/textproc/gsed/work/sed-4.1.4/testsuite'
gmake[2]: ãÅÌØ `all' ÎÅ ÔÒÅÂÕÅÔ ×ÙÐÏÌÎÅÎÉÑ ËÏÍÁÎÄ.
gmake[2]: Leaving directory `/usr/ports/textproc/gsed/work/sed-4.1.4/testsuite'
gmake[2]: Entering directory `/usr/ports/textproc/gsed/work/sed-4.1.4'
gmake[2]: ãÅÌØ `all-am' ÎÅ ÔÒÅÂÕÅÔ ×ÙÐÏÌÎÅÎÉÑ ËÏÍÁÎÄ.
...
===>   Generating temporary packing list
===>  Checking if shells/bash-completion already installed
install  -o root -g wheel -m 444 /usr/ports/shells/bash-completion/work/bash_completion/bash_completion /usr/local/etc
The programmable completion library is not enabled by default for various
reasons.  To use it, you should source /usr/local/etc/bash_completion from
your .bashrc file.  For example:
    if [ -f /usr/local/etc/bash_completion ]; then
        . /usr/local/etc/bash_completion
    fi
===>   Registering installation for bash-completion-20050721
/dev/ttyp0
11:01:08
#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
11:01:15
#vim /etc/bashrc
11:01:42
#cd /home/user/

11:01:59
#ls
.Xauthority
.bash_history
.bash_logout
.bash_profile
.bashrc
.cshrc
.gtkrc
.inputrc
.kde
.l3rc
...
splitted-dd-ac
splitted-dd-ad
splitted-dd-ae
test
text
text1
textvi
touchlist
very_long_file_name
ÐÏÎÅÄÅÌØÎÉË, 28 Á×ÇÕÓÔÁ 2006 Ç. 15:00:01 (EEST)
11:02:00
#cd /home/user/. /
.cshrc     bin/       dev/       lib/       rescue/    tmp/
.profile   boot/      dist/      libexec/   root/      usr/
.snap/     cdrom/     etc/       mnt/       sbin/      var/
COPYRIGHT  compat/    home/      proc/      sys/       win/
11:02:00
#cd /home/user/
.Xauthority
.bash_history
.bash_logout
.bash_profile
.bashrc
.cshrc
.gtkrc
.inputrc
.kde/
.l3rc
...
splitted-dd-ac
splitted-dd-ad
splitted-dd-ae
test/
text/
text1
textvi
touchlist
very_long_file_name
ÐÏÎÅÄÅÌØÎÉË, 28 Á×ÇÕÓÔÁ 2006 Ç. 15:00:01 (EEST)/
11:02:00
#vim
прошло 39 минут
/dev/ttyp6
11:41:23
#cat /usr/share/dict/propernames | tr '[A-Z]' '[a-z]' | xargs
aaron adam adlai adrian agatha ahmed ahmet aimee al alain alan alastair albert alberto alejandro alex alexander alexis alf alfred alison allan allen alvin amanda amarth amedeo ami amigo amir amos amy anatole anatoly anderson andre andrea andreas andrew andries andy angela angus anita ann anna annard anne annie anthony anton antonella antonio antony archie ariel arlene arne arnold art arthur audrey
11:45:52
#pw user show | less
11:45:59
#pw user show -a | less
11:46:44
#cat /usr/share/dict/propernames | grep -v root | tr '[A-Z]'

11:51:09
#echo 1248173849712398472395*218937198571398513895 | bc
273271685986110310213907209492571181428525
11:51:21
#echo 2^1000 | bc
10715086071862673209484250490600018105614048117055336074437503883703\
51051124936122493198378815695858127594672917553146825187145285692314\
04359845775746985748039345677748242309854210746050623711418779541821\
53046474983581941267398767559165543946077062914571196477686542167660\
429831652624386837205668069376
11:51:39
#which bc
/usr/bin/bc
11:51:47
#echo $((2123421414124*12341234532523))
-5862210669101202524
11:52:12
#echo $((1+100))
101
11:52:21
#i=0

11:52:30
#while [ $i -lt 10 ]
> do
> echo $i
> i=$((i+1))
> done
0
1
2
3
4
5
6
7
8
9
11:52:46
#which [
/bin/[
11:54:17
#echo $?
0
11:54:28
#cp /etc/asdfasfassafasf /tmp
cp: /etc/asdfasfassafasf: No such file or directory
11:54:48
#echo $?
1
11:54:52
#echo aaaaa$BBBBBB xxxxx
aaaaa xxxxx
11:57:03
#echo aaaaa${BBBBBB} xxxxx
aaaaa xxxxx
11:57:18
#echo aaaaa${BBBBBB}xxxxx
aaaaaxxxxx
11:57:20
#echo aaaaa$BBBBBBxxxxx
aaaaa
11:57:36
#BBBBBBxxxxx=ZLO

11:57:41
#echo aaaaa$BBBBBBxxxxx
aaaaaZLO
11:57:42
#set | less
11:58:18
#a=100

11:59:01
#echo $a
100
11:59:03
#bash
exit
/dev/ttyp9
11:59:08
#echo $a

/dev/ttyp6
11:59:08
#echo $a

11:59:10
#exit
exit
11:59:13
#echo $a
100
11:59:46
#export a

11:59:48
#bash

/dev/ttyp9
11:59:59
#echo $a
100
/dev/ttyp6
11:59:59
#echo $a
100
/dev/ttyp9
12:00:00
#a=23421342134214

/dev/ttyp6
12:00:00
#a=23421342134214

/dev/ttyp9
12:00:24
#echo $a
23421342134214
/dev/ttyp6
12:00:24
#echo $a
exit
23421342134214
12:00:25
#exit
exit
12:00:28
#echo $a
100
12:00:31
#echo $HOSTNAME
fbsd1.unix.nt
12:09:05
#primer="a c"

12:09:21
#echo $primer
a c
12:09:24
#mkdir $primer

12:09:33
#ls
a       c
12:09:34
#ls -l
total 4
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 a
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 c
12:09:37
#rmdir $primer

12:09:44
#mkdir "$primer"

12:09:49
#ls -l
total 2
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 a c
12:09:55
#mkdir '$primer'

12:10:48
#ls -l
total 4
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:10 $primer
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 a c
12:10:51
#mkdir $(date)

12:12:42
#ls -l
total 18
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:10 $primer
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 (EEST)
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 12:12:42
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 2006
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 29
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 a c
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 Á×ÇÕÓÔÁ
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 ×ÔÏÒÎÉË,
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 Ç.
12:12:53
#mkdir "$(date)"

12:12:58
#ls -l
total 20
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:10 $primer
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 (EEST)
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 12:12:42
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 2006
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 29
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 a c
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 Á×ÇÕÓÔÁ
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 ×ÔÏÒÎÉË,
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 ×ÔÏÒÎÉË, 29 Á×ÇÕÓÔÁ 2006 Ç. 12:12:58 (EEST)
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 Ç.
прошло 33 минуты
12:46:13
#touch 'line1
> line2
> line3
> '
12:46:24
#echo *
$primer (EEST) 12:12:42 2006 29 a c line1
line2
line3
 Á×ÇÕÓÔÁ ×ÔÏÒÎÉË, ×ÔÏÒÎÉË, 29 Á×ÇÕÓÔÁ 2006 Ç. 12:12:58 (EEST) Ç.
12:46:26
#ls -l
total 20
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:10 $primer
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 (EEST)
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 12:12:42
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 2006
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 29
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:09 a c
-rw-r--r--  1 root  wheel    0 29 Á×Ç 12:46 line1?line2?line3?
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 Á×ÇÕÓÔÁ
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 ×ÔÏÒÎÉË,
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 ×ÔÏÒÎÉË, 29 Á×ÇÕÓÔÁ 2006 Ç. 12:12:58 (EEST)
drwxr-xr-x  2 root  wheel  512 29 Á×Ç 12:12 Ç.
12:46:39
#echo *
$primer (EEST) 12:12:42 2006 29 a c line1
line2
line3
 Á×ÇÕÓÔÁ ×ÔÏÒÎÉË, ×ÔÏÒÎÉË, 29 Á×ÇÕÓÔÁ 2006 Ç. 12:12:58 (EEST) Ç.
12:46:51
#echo lin*
line1
line2
line3
12:46:55
#ls -l lin*
-rw-r--r--  1 root  wheel  0 29 Á×Ç 12:46 line1?line2?line3?
12:47:52
#vi hello
12:48:20
#sh hello
Hello
Pleased to meet you
12:48:22
#. hello
Hello
Pleased to meet you
12:48:37
#function greet()
> {
> echo Hello, $1
> }
12:49:32
#greet Igor
Hello, Igor
12:51:52
#vi hello
0a1,2
> #!/bin/sh
> 
12:52:15
#chmod +x hello

12:52:17
#./hello
Hello
Pleased to meet you
12:53:54
#echo PATH
PATH
12:54:08
#echo $PATH
/sbin:/bin:/usr/sbin:/usr/bin:/usr/games:/usr/local/sbin:/usr/local/bin:/usr/X11R6/bin:/home/user/bin
12:54:10
#mv hello /home/user/bin/

12:54:17
#hel
hello  help
12:54:17
#hello
Hello
Pleased to meet you
12:54:21
#cat hello
cat: hello: No such file or directory
12:54:27
#cat /home/user/bin/hello
#!/bin/sh
echo Hello
echo Pleased to meet you
12:54:32
#vi myrm
12:56:01
#chmod +x myrm

12:56:08
#touch file

12:56:13
#cat myrm
#!/bin/rm -rf
echo Hello world
12:56:17
#./myrm file

12:59:45
#cat myrm
cat: myrm: No such file or directory
12:59:46
#cat file
cat: file: No such file or directory
12:59:52
#cd /usr/ports/

13:02:02
#make search name=interpret | less
13:02:13
#make search name=script | less
13:02:26
#make search key=interpret | less
13:02:40
#make search key=interpret | grep ^Port:
Port:   eieio-emacs21-0.17_1
Port:   eieio-emacs20-0.17_1
Port:   g-wrap-1.3.4_8
Port:   gauche-sdl-0.5.1
Port:   libpperl-20051214_1
Port:   openzz-1.0.4.4_1
Port:   p5-Devel-SimpleTrace-0.06
Port:   vim+ruby-6.4.6_4
Port:   p-interp-0.5
Port:   freesci-0.3.4c
...
Port:   aolserver-openacs-pg-4.0.10_2
Port:   apache+mod_perl-1.3.34_3
Port:   mod_dtcl-0.12.0
Port:   mod_perl-1.29_1
Port:   mod_perl2-2.0.2,3
Port:   mod_python-3.1.4_1
Port:   mod_ruby-1.2.5
Port:   neowebscript-3.3_2
Port:   rep-gtk-0.15_3
Port:   rep-gtk2-0.18_4,1
13:02:45
#make search key=interpret | grep ^Port: | wc -l
      91
13:02:49
#cd

прошло 99 минут
/dev/ttyp6
14:42:01
#pkg_add -r sudo
Fetching ftp://ftp.freebsd.org/pub/FreeBSD/ports/i386/packages-6.1-release/Latest/sudo.tbz... Done.
pkg_add: package 'sudo-1.6.8.12_1' or its older version already installed
14:42:08
#vi /usr/local/etc/sudoers
19a20
> wheel	ALL=(ALL) ALL

Файлы

  • /home/user/bin/hello
  • myrm
  • /home/user/bin/hello
    >
    #!/bin/sh
    echo Hello
    echo Pleased to meet you
    
    myrm
    >
    #!/bin/rm -rf
    echo Hello world
    

    Статистика

    Время первой команды журнала10:54:07 2006- 8-29
    Время последней команды журнала14:42:08 2006- 8-29
    Количество командных строк в журнале100
    Процент команд с ненулевым кодом завершения, % 9.00
    Процент синтаксически неверно набранных команд, % 0.00
    Суммарное время работы с терминалом *, час 0.94
    Количество командных строк в единицу времени, команда/мин 1.78
    Частота использования команд
    echo27|=======================| 23.48%
    ls11|=========| 9.57%
    cat7|======| 6.09%
    make6|=====| 5.22%
    less6|=====| 5.22%
    mkdir5|====| 4.35%
    cd5|====| 4.35%
    vi4|===| 3.48%
    grep3|==| 2.61%
    chmod2|=| 1.74%
    pw2|=| 1.74%
    bc2|=| 1.74%
    a=234213421342142|=| 1.74%
    touch2|=| 1.74%
    hello2|=| 1.74%
    vim2|=| 1.74%
    bash2|=| 1.74%
    exit2|=| 1.74%
    which2|=| 1.74%
    tr2|=| 1.74%
    while1|| 0.87%
    a=1001|| 0.87%
    BBBBBBxxxxx=ZLO1|| 0.87%
    cp1|| 0.87%
    set1|| 0.87%
    hel1|| 0.87%
    wc1|| 0.87%
    .1|| 0.87%
    greet1|| 0.87%
    mv1|| 0.87%
    myrm1|| 0.87%
    function1|| 0.87%
    primer="a1|| 0.87%
    xargs1|| 0.87%
    export1|| 0.87%
    i=01|| 0.87%
    sh1|| 0.87%
    rmdir1|| 0.87%
    pkg_add1|| 0.87%
    ____
    *) Интервалы неактивности длительностью 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$