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

Содержание

Журнал

Среда (04/04/07)

/dev/ttyp1
12:54:23
$vim 1
13:01:09
$ls /bin/
[           date        getfacl     mkdir       rcp         sh
cat         dd          hostname    mv          realpath    sleep
chflags     df          kenv        pax         red         stty
chio        domainname  kill        pgrep       rm          sync
chmod       echo        link        pkill       rmail       tcsh
cp          ed          ln          ps          rmdir       test
csh         expr        ls          pwd         setfacl     unlink
13:01:09
$ls /bin/sh
/bin/sh
13:01:26
$ls -l /bin/sh
-r-xr-xr-x  1 root  wheel  105740 16 ÎÏÑ 04:10 /bin/sh
13:01:42
$ls /etc/profile
/etc/profile
13:02:17
$vim /etc/profile
13:03:07
$ls
1                       c                       sh
Desktop                 files                   test
Font                    names                   text
base                    pics                    touchlist
bin                     proj                    very_long_file_name
body                    projectX
13:03:52
$cp no_file /tmp
cp: no_file: No such file or directory
13:04:05
$echo $?
1
13:04:12
$pwd
/home/user
13:04:15
$echo $?
0
13:04:16
$touch no_file

13:04:31
$cp no_file /tmp

13:04:42
$echo $?
0
13:04:46
$test 5 -gt 1

13:04:56
$echo $?
0
13:04:57
$test 5 -lt

13:05:04
$echo $?
1
13:05:05
$test -z "$STRING"

13:05:23
$echo $?
0
13:05:37
$test "$P" != print

13:05:53
$echo $?
0
13:06:01
$$
$BASH                  $HISTFILESIZE          $PATH
$BASH_ARGC             $HISTSIZE              $PIPESTATUS
$BASH_ARGV             $HOME                  $PPID
$BASH_COMMAND          $HOSTNAME              $PS1
$BASH_ENV              $HOSTTYPE              $PS2
$BASH_LINENO           $IFS                   $PS4
$BASH_SOURCE           $KDE_FULL_SESSION      $PWD
$BASH_SUBSHELL         $KDE_MULTIHEAD         $RANDOM
$BASH_VERSINFO         $KONSOLE_DCOP          $SECONDS
$BASH_VERSION          $KONSOLE_DCOP_SESSION  $SESSION_MANAGER
...
$DISPLAY               $LOGNAME               $XCURSOR_THEME
$DM_CONTROL            $MACHTYPE              $XDG_CONFIG_DIRS
$EUID                  $MAIL                  $XDG_DATA_DIRS
$FTP_PASSIVE_MODE      $MAILCHECK             $XDM_MANAGED
$GROUPS                $MASTER_SITE_OVERRIDE  $_
$GS_LIB                $MM_CHARSET            $editor_file
$GTK2_RC_FILES         $OLDPWD                $editor_name
$GTK_RC_FILES          $OPTERR                $old_file
$HISTCMD               $OPTIND
$HISTFILE              $OSTYPE
13:06:22
$test -e /etc/motd

13:06:30
$echo $?
0
13:06:39
$test -r /etc/master.passwd

13:06:50
$echo $?
1
13:06:51
$test -k /tmp/

13:07:00
$echo $?
0
13:07:02
$test -w /etc/passwd

13:07:16
$echo $?
1
13:07:18
$man test
13:08:25
$test 5 > 10

13:08:40
$echo $?
0
13:08:43
$test 5 > 10

13:08:53
$echo $?
0
13:08:54
$test 5 -gt

13:09:20
$echo $?
1
13:09:21
$test 10 -gt 5

13:09:30
$echo $?
0
13:09:31
$echo "Your likely color?" ; read FAV_COL ; \
> Red
Your likely color?
Red
bash: Red: command not found
13:10:47
$echo "Your likely color?" ; read FAV_COL ; \
> echo Your likely color - $FAV_COL
Your likely color?
Red
Your likely color - Red
13:11:22
$test $EUID -ne 0 -a -r /etc/master.passwd && \
> echo 'Warning: File /etc/master.passwd u can  read!'
13:13:04
$ls /etc/master.passwd
/etc/master.passwd
13:13:31
$A=0

13:14:26
$while [ $A -lt 10 ]
> do
> A=$((A+1))
> echo $A
> done
1
2
3
4
5
6
7
8
9
10
13:14:51
$ls
1                       c                       sh
10                      files                   test
Desktop                 names                   text
Font                    no_file                 touchlist
base                    pics                    very_long_file_name
bin                     proj
body                    projectX
13:14:57
$ls 10
10
13:15:03
$vim 10
13:15:09
$ls
1                       c                       sh
10                      files                   test
Desktop                 names                   text
Font                    no_file                 touchlist
base                    pics                    very_long_file_name
bin                     proj
body                    projectX
13:15:10
$vim 1
1a2,4
> for file in /etc/*
> 	do [ -r $file ] || echo $file
> done 
13:17:50
$chmod a+x 1

13:18:02
$sh 1
/etc/isdn
/etc/master.passwd
/etc/nsmb.conf
/etc/ntp
/etc/opieaccess
/etc/spwd.db
13:18:07
$vim 1
3c3
< 	do [ -r $file ] || echo $file
---
> 	do [ -r -w $file ] || echo $file
13:19:06
$sh 1
/etc/hosts
[: -w: unexpected operator
/etc/hosts.allow
[: -w: unexpected operator
/etc/hosts.equiv
[: -w: unexpected operator
/etc/hosts.lpd
[: -w: unexpected operator
/etc/inetd.conf
[: -w: unexpected operator
...
[: -w: unexpected operator
/etc/termcap
[: -w: unexpected operator
/etc/timezone
[: -w: unexpected operator
/etc/ttys
[: -w: unexpected operator
/etc/usbd.conf
[: -w: unexpected operator
/etc/wall_cmos_clock
13:19:08
$vim 1
2,4c2,7
< for file in /etc/*
< 	do [ -r -w $file ] || echo $file
< done 
---
> echo 'About what commande you whant know Info?' ; \
> select command in man touch mount make exit clear
> 	do
> 	whatis $command
> 		break
> done
13:21:47
$sh 1
About what commande you whant know Info?
select: not found
1: 4: Syntax error: "do" unexpected
13:21:49
$echo &?
[1] 2915
bash: 1: command not found
[1]+  Done                    echo
13:22:01
$vim 1
13:23:35
$vim 1
2,7c2,14
< echo 'About what commande you whant know Info?' ; \
< select command in man touch mount make exit clear
< 	do
< 	whatis $command
< 		break
< done
---
> echo "What comand you can kno help?"
> read answer
> case $answer in
> 	"man" | "info" )
> 		echo "You right!"
> 	;;
> 
> "whatis" | "apropos" )
> 		echo "No that!"
> 	;;
> * ) echo "ERROR"
> 	;;
> esac
13:27:05
$sh 1
What comand you can kno help?
read
ERROR
13:27:17
$sh 1
What comand you can kno help?
man
You right!
13:27:22
$sh 1
What comand you can kno help?
info
You right!
13:27:26
$sh 1
What comand you can kno help?
aprose
ERROR
13:27:33
$sh 1
What comand you can kno help?
apropos
No that!
13:27:44
$sh 1
What comand you can kno help?
whatis
No that!
13:27:48
$vim 1
2,14c2,15
< echo "What comand you can kno help?"
< read answer
< case $answer in
< 	"man" | "info" )
< 		echo "You right!"
< 	;;
< 
< "whatis" | "apropos" )
< 		echo "No that!"
< 	;;
< * ) echo "ERROR"
< 	;;
< esac
---
> echo "Full Path to the program: "
> read PROGRAM \; 
> if [ -x "$PROGRAM" ]
> 	then
> 		"$PROGRAM"
> 	else
> 		echo -n "Cant run $PROGRAM. "
> 	if [ -e "$PROGRAM" ]
> 		then
> 		echo "This file is not executable"
> 	else
> 		echo "No such File"
> 	fi
> fi
13:31:28
$sh 1
Full Path to the program:
/home/user/1
read: ;: bad variable name
Full Path to the program:
/etc/password
/home/user/1: line 3: read: `;': not a valid identifier
Cant run /etc/password. No such File
13:32:05
$vim 1
13:41:42
$sh 1
Your likely System?
FreeBSD
You the Best (:
I dont know what is that???
13:41:46
$vim 1
5c5
< 	if [ $FAV_OS = Windows ]
---
> 	else [ $FAV_OS = Windows ]
8d7
< 	fi
13:42:49
$sh 1
1: 6: Syntax error: "then" unexpected (expecting "fi")
13:42:50
$vim 1
13:44:18
$sh 1
Your likely System?
FreeBSD
You the Best (:
I dont know what is that???
13:44:22
$sh 1
Your likely System?
Windows
Bill Must Die ^^
13:44:28
$vim 1
2c2,3
< echo "Your likely System?" ; read FAV_OS ; \
---
> echo "Your likely System?"
> read FAV_OS ; \
4c5
< 		then echo "You the Best (:"
---
> 		then echo "You are the Best (:"
13:45:26
$sh 1
Your likely System?
FreeBSD
You are the Best (:
I dont know what is that???
13:45:30
$sh 1
Your likely System?
...
I dont know what is that???
13:45:32
$vim 1
13:45:42
$vim 1
5c5
< 		then echo "You are the Best (:"
---
> 		then echo "You are the Best (:" ; end
прошло 84 минуты
15:10:26
$sh 1
Your likely System?
FreeBSD
You are the Best (:
end: not found
I dont know what is that???
15:10:33
$vim 1
5,6c5
< 		then echo "You are the Best (:" ; end
< 			fi
---
> 		then echo "You are the Best (:"
9a9
> fi
15:11:17
$sh 1
Your likely System?
FreeBSD
You are the Best (:
I dont know what is that???
15:11:20
$sh 1
Your likely System?
Windows
15:11:27
$sh 1
Your likely System?
Window
15:11:33
$vim 1
5c5
< 		then echo "You are the Best (:"
---
> 		do echo "You are the Best (:"
7c7
< 		then echo "Bill Must Die ^^"
---
> 		do echo "Bill Must Die ^^"
15:12:53
$sh 1
Your likely System?
1: 5: Syntax error: "do" unexpected (expecting "then")
15:12:54
$vim 1
4c4
< 	if [ $FAV_OS = FreeBSD ]
---
> 	while [ $FAV_OS = FreeBSD ]
6c6,7
< 	if [ $FAV_OS = Windows ]
---
> 			done
> 	while [ $FAV_OS = Windows ]
8,10c9
< 	else echo "I dont know what is that???"
< fi
< fi
---
> 			done
15:14:25
$sh 1
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
...
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
15:14:31
$vim 1
5,6c5
< 		do echo "You are the Best (:"
< 			done
---
> 		do echo "You are the Best (:" ; done
15:15:20
$sh 1
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
...
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
You are the Best (:
15:15:24
$vim 1
3,8c3,11
< read FAV_OS ; \
< 	while [ $FAV_OS = FreeBSD ]
< 		do echo "You are the Best (:" ; done
< 	while [ $FAV_OS = Windows ]
< 		do echo "Bill Must Die ^^"
< 			done
---
> read FAV_OS
> 	case $FAV_OS in
> 			"FreeBSD" )
> 	echo "You are the Best (:" ;; 
> 	
> 			"Windows" )
> 	echo "Bill Must Die ^^" ;;
> 			* ) echo "X3 what is thaT?" ;;
> esac
15:21:29
$sh 1
Your likely System?
FreeBSD
You are the Best (:
15:21:36
$sh 1
Your likely System?
Windows
Bill Must Die ^^
15:21:43
$sh 1
Your likely System?
Linux
X3 what is thaT?
15:21:49
$sh 1
Your likely System?
^C
15:22:00
$vim 1
15:23:31
$vim 1
15:23:36
$vim 2
15:24:41
$df -h
Filesystem     Size    Used   Avail Capacity  Mounted on
/dev/ad1s1a    2.9G     63M    2.6G     2%    /
devfs          1.0K    1.0K      0B   100%    /dev
/dev/ad1s3f    4.8G    104M    4.4G     2%    /home
/dev/ad1s3e    496M     92K    456M     0%    /tmp
/dev/ad1s3g     21G    3.2G     16G    16%    /usr
/dev/ad1s3d    1.9G     29M    1.7G     2%    /var
15:24:45
$dmesg
Copyright (c) 1992-2006 The FreeBSD Project.
Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994
        The Regents of the University of California. All rights reserved.
FreeBSD is a registered trademark of The FreeBSD Foundation.
FreeBSD 6.2-RC1 #0: Thu Nov 16 05:12:08 UTC 2006
    root@opus.cse.buffalo.edu:/usr/obj/usr/src/sys/SMP
Timecounter "i8254" frequency 1193182 Hz quality 0
CPU: Intel(R) Celeron(R) CPU 1.80GHz (1800.03-MHz 686-class CPU)
  Origin = "GenuineIntel"  Id = 0xf13  Stepping = 3
  Features=0x3febfbff<FPU,VME,DE,PSE,TSC,MSR,PAE,MCE,CX8,APIC,SEP,MTRR,PGE,MCA,CMOV,PAT,PSE36,CLFLUSH,DTS,ACPI,MMX,FXSR,SSE,SSE2,SS,HTT,TM>
...
sc0: VGA <16 virtual consoles, flags=0x300>
vga0: <Generic ISA VGA> at port 0x3c0-0x3df iomem 0xa0000-0xbffff on isa0
Timecounter "TSC" frequency 1800031040 Hz quality 800
Timecounters tick every 1.000 msec
ad1: 38166MB <WDC WD400JB-00ENA0 05.03E05> at ata0-slave UDMA100
acd0: DVDROM <JLMS DVD-ROM LTD-166S/DS0B> at ata1-slave UDMA40
Trying to mount root from ufs:/dev/ad1s1a
drmsub0: <Intel i845G GMCH>: (child of agp_i810.c) on agp0
info: [drm] AGP at 0xd0000000 128MB
info: [drm] Initialized i915 1.4.0 20060119

Статистика

Время первой команды журнала12:54:23 2007- 4- 4
Время последней команды журнала15:24:45 2007- 4- 4
Количество командных строк в журнале101
Процент команд с ненулевым кодом завершения, % 9.90
Процент синтаксически неверно набранных команд, % 1.98
Суммарное время работы с терминалом *, час 1.09
Количество командных строк в единицу времени, команда/мин 1.54
Частота использования команд
sh27|========================| 24.55%
vim23|====================| 20.91%
echo18|================| 16.36%
test13|===========| 11.82%
ls9|========| 8.18%
\3|==| 2.73%
102|=| 1.82%
cp2|=| 1.82%
read2|=| 1.82%
touch1|| 0.91%
&1|| 0.91%
pwd1|| 0.91%
man1|| 0.91%
while1|| 0.91%
?1|| 0.91%
chmod1|| 0.91%
A=01|| 0.91%
dmesg1|| 0.91%
df1|| 0.91%
$1|| 0.91%
____
*) Интервалы неактивности длительностью 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$