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

Содержание

Журнал

Вторник (09/05/17)

/dev/pts/0
09:21:44
#ls n*
nano  nc  nc.traditional  netcat  netstat  nisdomainname
09:22:05
#ls ?i*
dir  findmnt  kill  nisdomainname  pidof  ping  ping6
09:22:31
#cd

09:26:43
#touch 54564 4564as 123123 sd4sdf 12423412 sdfsd45s4 4sds4sdf

09:27:10
#ls
123123  12423412  4564as  4sds4sdf  54564  d1  d2  f1  f1H  install  messages  sd4sdf  sdfsd45s4  syslog
09:27:52
#shopt
autocd          off
cdable_vars     off
cdspell         off
checkhash       off
checkjobs       off
checkwinsize    on
cmdhist         on
compat31        off
compat32        off
compat40        off
...
no_empty_cmd_completion off
nocaseglob      off
nocasematch     off
nullglob        off
progcomp        on
promptvars      on
restricted_shell        off
shift_verbose   off
sourcepath      on
xpg_echo        off
09:29:06
#shopt -s extglob

09:30:12
#shopt
autocd          off
cdable_vars     off
cdspell         off
checkhash       off
checkjobs       off
checkwinsize    on
cmdhist         on
compat31        off
compat32        off
compat40        off
...
no_empty_cmd_completion off
nocaseglob      off
nocasematch     off
nullglob        off
progcomp        on
promptvars      on
restricted_shell        off
shift_verbose   off
sourcepath      on
xpg_echo        off
09:30:14
#ls +([[:digit:]])
123123  12423412  54564
09:31:44
#shopt -u extglob

09:32:02
#ls +([[:digit:]])
l3script: syntax error near unexpected token `('
09:32:04
#shopt -s extglob

09:32:14
#ls +([[:digit:]])
123123  12423412  54564
09:32:17
#ls *([[:digit:]])
123123  12423412  54564
09:35:35
#rm *([[:digit:]])

09:36:39
#ls
4564as  4sds4sdf  d1  d2  f1  f1H  install  messages  sd4sdf  sdfsd45s4  syslog
09:36:42
#ls *([[1-9]])
ls: невозможно получить доступ к *([[1-9]]): Нет такого файла или каталога
09:37:01
#ls *([[:1-9:]])
ls: невозможно получить доступ к *([[:1-9:]]): Нет такого файла или каталога
09:37:08
#ls *([[:1-9:]])*
4564as  4sds4sdf  f1  f1H  install  messages  sd4sdf  sdfsd45s4  syslog
d1:
f1  f2
d2:
d3
09:37:12
#find . -mmin -10 -type f
./.lilalo/59212332172429021-1504596001.info
./.lilalo/.report.dat
./.lilalo/59212332172429021-1504596001.script
09:38:53
#find . -mmin -20 -type f
./4sds4sdf
./.lilalo/59212332172429021-1504596001.info
./.lilalo/.report.dat
./.lilalo/2411425643282601169-1504595156.script
./.lilalo/2411425643282601169-1504595156.info
./.lilalo/59212332172429021-1504596001.script
./.bash_history
./sd4sdf
./sdfsd45s4
./4564as
09:39:20
#find . -mmin -30 -type f
./4sds4sdf
./.lilalo/59212332172429021-1504596001.info
./.lilalo/.report.dat
./.lilalo/2411425643282601169-1504595156.script
./.lilalo/2411425643282601169-1504595156.info
./.lilalo/59212332172429021-1504596001.script
./.lilalo/2411425643282601169-1504595156_1504595531_etc_skel_.bashrc.diff
./.bash_history
./sd4sdf
./sdfsd45s4
./.viminfo
./4564as
09:39:27
#find . -mmin -30 -type f -maxdept 1
find: unknown predicate `-maxdept'
09:39:49
#find --help
Usage: find [-H] [-L] [-P] [-Olevel] [-D help|tree|search|stat|rates|opt|exec] [path...] [expression]
default path is the current directory; default expression is -print
expression may consist of: operators, options, tests, and actions:
operators (decreasing precedence; -and is implicit where no others are given):
      ( EXPR )   ! EXPR   -not EXPR   EXPR1 -a EXPR2   EXPR1 -and EXPR2
      EXPR1 -o EXPR2   EXPR1 -or EXPR2   EXPR1 , EXPR2
positional options (always true): -daystart -follow -regextype
normal options (always true, specified before other expressions):
      -depth --help -maxdepth LEVELS -mindepth LEVELS -mount -noleaf
      --version -xdev -ignore_readdir_race -noignore_readdir_race
...
      -readable -writable -executable
      -wholename PATTERN -size N[bcwkMG] -true -type [bcdpflsD] -uid N
      -used N -user NAME -xtype [bcdpfls]
actions: -delete -print0 -printf FORMAT -fprintf FILE FORMAT -print
      -fprint0 FILE -fprint FILE -ls -fls FILE -prune -quit
      -exec COMMAND ; -exec COMMAND {} + -ok COMMAND ;
      -execdir COMMAND ; -execdir COMMAND {} + -okdir COMMAND ;
Report (and track progress on fixing) bugs via the findutils bug-reporting
page at http://savannah.gnu.org/ or, if you have no web access, by sending
email to <bug-findutils@gnu.org>.
09:40:20
#find . -maxdepth 1 -mmin -30 -type f
./4sds4sdf
./.bash_history
./sd4sdf
./sdfsd45s4
./.viminfo
./4564as
09:40:50
#find . -maxdepth 1 -mmin -20 -type f
./4sds4sdf
./sd4sdf
./sdfsd45s4
./4564as
09:41:05
#find . -maxdepth 1 -mmin -20 -type f | xargs rm -v
удалён «./4sds4sdf»
удалён «./sd4sdf»
удалён «./sdfsd45s4»
удалён «./4564as»
09:41:59
#ls
d1  d2  f1  f1H  install  messages  syslog
09:42:20
#ls -l $(wich passwd)
l3script: wich: команда не найдена
итого 24
drwxr-xr-x 2 root root 4096 Сен  4 12:36 d1
drwxr-xr-x 3 root root 4096 Сен  4 12:31 d2
lrwxrwxrwx 1 root root   11 Сен  4 13:51 f1 -> /root/d1/f1
-rw-r--r-- 2 root root    0 Сен  4 12:15 f1H
-rw-r--r-- 1 root root 5268 Окт 13  2014 install
-rw-r----- 1 root root  292 Сен  4 15:49 messages
-rw-r----- 1 root root 1100 Сен  4 15:51 syslog
прошло 32 минуты
10:14:56
#ls -l $(which passwd)
-rwsr-xr-x 1 root root 51096 Май 26  2012 /usr/bin/passwd
10:15:06
#ls -l `which passwd`
-rwsr-xr-x 1 root root 51096 Май 26  2012 /usr/bin/passwd
10:20:03
#echo $(($ps ax | wc -l)-4))
l3script: syntax error near unexpected token `)'
10:21:01
#echo $(($(ps ax | wc -l)-4))
64
10:21:08
#top
top - 11:21:36 up 3 days, 20:07,  2 users,  load average: 0,00, 0,03, 0,05
Tasks:  65 total,   1 running,  58 sleeping,   6 stopped,   0 zombie
%Cpu(s):  0,1 us,  0,0 sy,  0,0 ni, 99,8 id,  0,1 wa,  0,0 hi,  0,0 si,  0,0 st
KiB Mem:    507368 total,   312120 used,   195248 free,    86952 buffers
KiB Swap:        0 total,        0 used,        0 free,   115312 cached
  PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM    TIME+  COMMAND
    1 root      20   0 10648  832  696 S   0,0  0,2   0:06.32 init
    2 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kthreadd
    3 root      20   0     0    0    0 S   0,0  0,0   0:00.52 ksoftirqd/0
    5 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kworker/u:0
...
 2303 root      20   0 18368  968  812 S   0,0  0,2   0:00.00 getty
 2304 root      20   0 18368  968  812 S   0,0  0,2   0:00.00 getty
 2549 root      20   0     0    0    0 S   0,0  0,0   0:11.78 kworker/0:1
 3371 root      20   0     0    0    0 S   0,0  0,0   0:00.71 flush-202:0
 3414 root      20   0 51404  13m 1740 S   0,0  2,7   3:42.79 l3-agent
 7051 user      20   0 18168  472  308 S   0,0  0,1   0:00.08 script
 7052 user      20   0 24396 3160 1836 S   0,0  0,6   0:00.54 l3script
 7181 user      20   0 34356 3372 2108 T   0,0  0,7   0:00.02 vi
 7253 user      20   0 34428 3452 2132 T   0,0  0,7   0:00.04 vi
 7346 user      20   0 34416 3748 2416 T   0,0  0,7   0:00.06 vi
10:21:38
#echo $[$(ps ax | wc -l)-4]
64
10:22:42
#du -sh /*
7,2M    /bin
18M     /boot
0       /dev
3,4M    /etc
11M     /home
0       /initrd.img
122M    /lib
3,0M    /lib32
4,0K    /lib64
16K     /lost+found
...
1,6M    /root
152K    /run
5,4M    /sbin
4,0K    /selinux
4,0K    /srv
0       /sys
8,0K    /tmp
409M    /usr
292M    /var
0       /vmlinuz
10:26:36
#du -sh /* >2 /dev/null
du: невозможно получить доступ к «/proc/10300/task/10300/fd/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10300/task/10300/fdinfo/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10300/fd/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10300/fdinfo/11»: Нет такого файла или каталога
10:27:48
#du -sh /* 2> /dev/null
7,2M    /bin
18M     /boot
0       /dev
3,4M    /etc
11M     /home
0       /initrd.img
122M    /lib
3,0M    /lib32
4,0K    /lib64
16K     /lost+found
...
1,6M    /root
152K    /run
5,4M    /sbin
4,0K    /selinux
4,0K    /srv
0       /sys
8,0K    /tmp
409M    /usr
292M    /var
0       /vmlinuz
10:27:56
#du -sh /* 2> /dev/null >f1

10:28:15
#ls
2  d1  d2  f1  f1H  install  messages  syslog
10:28:23
#du -sh /* 2> /dev/null >f1

10:30:18
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
/dev/pts/0
10:30:57
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
10:30:59
#set -o | wc -l
27
10:31:12
#set -o noclobber

10:31:52
#du -sh /* 2> /dev/null >f1

10:32:27
#du -sh /* 2> /dev/null >f1

10:32:28
#du -sh /* 1>f1 2> /dev/null

10:34:00
#du -sh /* 1>f1
du: невозможно получить доступ к «/proc/10478/task/10478/fd/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10478/task/10478/fdinfo/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10478/fd/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10478/fdinfo/11»: Нет такого файла или каталога
10:34:24
#du -sh /* 1>f1
du: невозможно получить доступ к «/proc/10507/task/10507/fd/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10507/task/10507/fdinfo/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10507/fd/11»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/10507/fdinfo/11»: Нет такого файла или каталога
10:35:05
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
10:35:08
#du -sh /* 1>f1
l3script: f1: не могу переписать уже существующий файл
10:35:14
#set +o noclobber

10:37:49
#ls
ls           lsattr       lsblk        lscpu        lsinitramfs  lsmod        lspci        lspgpot      lsusb
10:37:49
#ls
ls           lsattr       lsblk        lscpu        lsinitramfs  lsmod        lspci        lspgpot      lsusb
10:37:49
#lsattr f1
lsattr: Неподдерживаемая операция While reading flags on f1
10:38:08
#lsattr files
lsattr: Нет такого файла или каталога while trying to stat files
10:38:11
#lsattr f1
lsattr: Неподдерживаемая операция While reading flags on f1
/dev/pts/6
10:39:14
#lsattr f1
lsattr: Неподдерживаемая операция While reading flags on f1
10:39:23
#ls
2  d1  d2  f1  f1H  install  messages  syslog
10:39:32
#ls -l
итого 32
-rw-r--r-- 1 root root  255 Сен  5 11:27 2
drwxr-xr-x 2 root root 4096 Сен  4 12:36 d1
drwxr-xr-x 3 root root 4096 Сен  4 12:31 d2
lrwxrwxrwx 1 root root   11 Сен  4 13:51 f1 -> /root/d1/f1
-rw-r--r-- 2 root root  255 Сен  5 11:34 f1H
-rw-r--r-- 1 root root 5268 Окт 13  2014 install
-rw-r----- 1 root root  292 Сен  4 15:49 messages
-rw-r----- 1 root root 1100 Сен  4 15:51 syslog
10:40:03
#lsattr f1h
lsattr: Нет такого файла или каталога while trying to stat f1h
10:40:14
#lsattr f1H
-------------e-- f1H
10:40:18
#lsattr +a f1H
lsattr: Нет такого файла или каталога while trying to stat +a
-------------e-- f1H
10:40:38
#chattr +a f1H

10:40:59
#ls -l
итого 32
-rw-r--r-- 1 root root  255 Сен  5 11:27 2
drwxr-xr-x 2 root root 4096 Сен  4 12:36 d1
drwxr-xr-x 3 root root 4096 Сен  4 12:31 d2
lrwxrwxrwx 1 root root   11 Сен  4 13:51 f1 -> /root/d1/f1
-rw-r--r-- 2 root root  255 Сен  5 11:34 f1H
-rw-r--r-- 1 root root 5268 Окт 13  2014 install
-rw-r----- 1 root root  292 Сен  4 15:49 messages
-rw-r----- 1 root root 1100 Сен  4 15:51 syslog
10:41:04
#ls -l >f1H
l3script: f1H: Операция не позволяется
10:41:11
#ls -l >>f1H

10:41:15
#chattr -a f1H

10:41:30
#chattr +i f1H

10:42:20
#rm f1H
rm: невозможно удалить «f1H»: Операция не позволяется
10:42:26
#chattr
Usage: chattr [-RVf] [-+=AaCcDdeijsSu] [-v version] files...
10:42:48
#chattr help
Must use '-v', =, - or +
10:42:54
#chattr --help
Usage: chattr [-RVf] [-+=AaCcDdeijsSu] [-v version] files...
10:42:58
#lsattr
lsattr: Неподдерживаемая операция While reading flags on ./f1
----i--------e-- ./f1H
-------------e-- ./d2
-------------e-- ./messages
-------------e-- ./d1
-------------e-- ./2
-------------e-- ./syslog
-------------e-- ./install
10:43:16
#lsattr --help
lsattr: неверный ключ -- «-»
Usage: lsattr [-RVadlv] [files...]
10:43:21
#chattr -i f1H

10:49:54
#la *a
l3script: la: команда не найдена
прошло >3 часов
/dev/pts/4
14:15:05
#cp /etc/pa
pam.conf  pam.d/    passwd    passwd-
14:15:05
#cp /etc/pa
pam.conf  pam.d/    passwd    passwd-
14:15:05
#cp /etc/passwd .

14:21:45
#ls
2  d1  d2  f1  f1H  install  messages  passwd  syslog
14:21:51
#cat passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/bin/sh
bin:x:2:2:bin:/bin:/bin/sh
sys:x:3:3:sys:/dev:/bin/sh
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/bin/sh
man:x:6:12:man:/var/cache/man:/bin/sh
lp:x:7:7:lp:/var/spool/lpd:/bin/sh
mail:x:8:8:mail:/var/mail:/bin/sh
news:x:9:9:news:/var/spool/news:/bin/sh
...
list:x:38:38:Mailing List Manager:/var/list:/bin/sh
irc:x:39:39:ircd:/var/run/ircd:/bin/sh
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
Debian-exim:x:101:103::/var/spool/exim4:/bin/false
user:x:1000:1000:user,,,:/home/user:/bin/bash
sshd:x:102:65534::/var/run/sshd:/usr/sbin/nologin
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:21:56
#cat passwd | grep 100
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:22:36
#cat passwd | grep ^ivan
ivan:x:1001:1001::/home/ivan:/bin/bash
14:25:20
#cat passwd | grep bash$
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:26:28
#cat passwd | grep bash$
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:26:28
#cat passwd | grep bash$
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:27:14
#cat passwd | grep bash$1
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:27:17
#cat passwd | grep bash$2
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:27:21
#cat passwd | grep bash$a
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:27:23
#cat passwd | grep bash$f
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:27:26
#cat passwd | grep bash$
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:27:59
#f=1

14:28:02
#cat passwd | grep bash$f

14:28:04
#cat passwd | grep 'bash$f'

14:28:35
#cat passwd | grep 'bash$'
root:x:0:0:root:/root:/bin/bash
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:28:37
#cat passwd | grep 'h..e'
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
14:31:13
#cat passwd | grep '0{2}'

14:35:45
#cat passwd | grep '0{2,}'

14:35:48
#cat passwd | egrep '0{2,}'
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
user:x:1000:1000:user,,,:/home/user:/bin/bash
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash

Файлы

  • passwd
  • passwd
    >
    root:x:0:0:root:/root:/bin/bash
    daemon:x:1:1:daemon:/usr/sbin:/bin/sh
    bin:x:2:2:bin:/bin:/bin/sh
    sys:x:3:3:sys:/dev:/bin/sh
    sync:x:4:65534:sync:/bin:/bin/sync
    games:x:5:60:games:/usr/games:/bin/sh
    man:x:6:12:man:/var/cache/man:/bin/sh
    lp:x:7:7:lp:/var/spool/lpd:/bin/sh
    mail:x:8:8:mail:/var/mail:/bin/sh
    news:x:9:9:news:/var/spool/news:/bin/sh
    uucp:x:10:10:uucp:/var/spool/uucp:/bin/sh
    proxy:x:13:13:proxy:/bin:/bin/sh
    www-data:x:33:33:www-data:/var/www:/bin/sh
    backup:x:34:34:backup:/var/backups:/bin/sh
    list:x:38:38:Mailing List Manager:/var/list:/bin/sh
    irc:x:39:39:ircd:/var/run/ircd:/bin/sh
    gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
    nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
    libuuid:x:100:101::/var/lib/libuuid:/bin/sh
    Debian-exim:x:101:103::/var/spool/exim4:/bin/false
    user:x:1000:1000:user,,,:/home/user:/bin/bash
    sshd:x:102:65534::/var/run/sshd:/usr/sbin/nologin
    ivan:x:1001:1001::/home/ivan:/bin/bash
    petr:x:1002:1002::/home/petr:/bin/bash
    

    Статистика

    Время первой команды журнала09:21:44 2017- 9- 5
    Время последней команды журнала14:35:48 2017- 9- 5
    Количество командных строк в журнале101
    Процент команд с ненулевым кодом завершения, %30.69
    Процент синтаксически неверно набранных команд, % 0.99
    Суммарное время работы с терминалом *, час 1.27
    Количество командных строк в единицу времени, команда/мин 1.32
    Частота использования команд
    ls24|=================| 17.02%
    cat18|============| 12.77%
    grep16|===========| 11.35%
    du11|=======| 7.80%
    lsattr9|======| 6.38%
    f18|=====| 5.67%
    find8|=====| 5.67%
    chattr7|====| 4.96%
    null6|====| 4.26%
    set6|====| 4.26%
    shopt5|===| 3.55%
    wc4|==| 2.84%
    cp3|==| 2.13%
    echo3|==| 2.13%
    rm2|=| 1.42%
    f1H2|=| 1.42%
    egrep1|| 0.71%
    touch1|| 0.71%
    top1|| 0.71%
    >1|| 0.71%
    xargs1|| 0.71%
    cd1|| 0.71%
    f=11|| 0.71%
    la1|| 0.71%
    21|| 0.71%
    ____
    *) Интервалы неактивности длительностью 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$