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

Содержание

Журнал

Вторник (09/29/15)

/dev/pts/0
09:42:25
#ls -l $(which chsh)
-rwsr-xr-x 1 root root 41272 Май 26  2012 /usr/bin/chsh
09:43:07
#vi privet.sh
--- /dev/null	2015-09-25 17:23:02.067999996 +0300
+++ privet.sh	2015-09-29 10:53:46.316319809 +0300
@@ -0,0 +1,2 @@
+#!/bin/bash
+echo "Privet ${1}!"
прошло 10 минут
09:53:46
#privet.sh
l3script: privet.sh: команда не найдена
09:53:59
#ls
23423               234235325     file1  file4    privet.sh  wetwet
23423523            234g23        file2  file5    report
234235232252352435  234g23hgfdfh  file3  install  shadow
09:54:22
#echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
09:54:44
#pwd
/root
09:54:47
#/root/privet.sh
l3script: /root/privet.sh: Отказано в доступе
09:55:13
#./privet.sh
l3script: ./privet.sh: Отказано в доступе
09:55:29
#ls -l
итого 16
-rw-r--r-- 1 root root    0 Сен 29 10:26 23423
-rw-r--r-- 1 root root    0 Сен 29 10:26 23423523
-rw-r--r-- 1 root root    0 Сен 29 10:26 234235232252352435
-rw-r--r-- 1 root root    0 Сен 29 10:26 234235325
-rw-r--r-- 1 root root    0 Сен 29 10:26 234g23
-rw-r--r-- 1 root root    0 Сен 29 10:26 234g23hgfdfh
-rw-r--r-- 1 root root    0 Сен 29 10:35 file1
-rw-r--r-- 1 root root    0 Сен 29 10:35 file2
-rw-r--r-- 1 root root    0 Сен 29 10:35 file3
-rw-r--r-- 1 root root    0 Сен 29 10:35 file4
-rw-r--r-- 1 root root    0 Сен 29 10:35 file5
-rw-r--r-- 1 root root 5268 Сен 28 16:43 install
-rw-r--r-- 1 root root   32 Сен 29 10:53 privet.sh
-rw-r--r-- 1 root root    0 Сен 28 14:24 report
-rw-r----- 1 root root 1029 Сен 28 14:23 shadow
-rw-r--r-- 1 root root    0 Сен 29 10:26 wetwet
09:55:39
#chmod u+x privet.sh

09:56:08
#ls -l
итого 16
-rw-r--r-- 1 root root    0 Сен 29 10:26 23423
-rw-r--r-- 1 root root    0 Сен 29 10:26 23423523
-rw-r--r-- 1 root root    0 Сен 29 10:26 234235232252352435
-rw-r--r-- 1 root root    0 Сен 29 10:26 234235325
-rw-r--r-- 1 root root    0 Сен 29 10:26 234g23
-rw-r--r-- 1 root root    0 Сен 29 10:26 234g23hgfdfh
-rw-r--r-- 1 root root    0 Сен 29 10:35 file1
-rw-r--r-- 1 root root    0 Сен 29 10:35 file2
-rw-r--r-- 1 root root    0 Сен 29 10:35 file3
-rw-r--r-- 1 root root    0 Сен 29 10:35 file4
-rw-r--r-- 1 root root    0 Сен 29 10:35 file5
-rw-r--r-- 1 root root 5268 Сен 28 16:43 install
-rwxr--r-- 1 root root   32 Сен 29 10:53 privet.sh
-rw-r--r-- 1 root root    0 Сен 28 14:24 report
-rw-r----- 1 root root 1029 Сен 28 14:23 shadow
-rw-r--r-- 1 root root    0 Сен 29 10:26 wetwet
09:56:16
#ls -l --color
итого 16
-rw-r--r-- 1 root root    0 Сен 29 10:26 23423
-rw-r--r-- 1 root root    0 Сен 29 10:26 23423523
-rw-r--r-- 1 root root    0 Сен 29 10:26 234235232252352435
-rw-r--r-- 1 root root    0 Сен 29 10:26 234235325
-rw-r--r-- 1 root root    0 Сен 29 10:26 234g23
-rw-r--r-- 1 root root    0 Сен 29 10:26 234g23hgfdfh
-rw-r--r-- 1 root root    0 Сен 29 10:35 file1
-rw-r--r-- 1 root root    0 Сен 29 10:35 file2
-rw-r--r-- 1 root root    0 Сен 29 10:35 file3
-rw-r--r-- 1 root root    0 Сен 29 10:35 file4
-rw-r--r-- 1 root root    0 Сен 29 10:35 file5
-rw-r--r-- 1 root root 5268 Сен 28 16:43 install
-rwxr--r-- 1 root root   32 Сен 29 10:53 privet.sh
-rw-r--r-- 1 root root    0 Сен 28 14:24 report
-rw-r----- 1 root root 1029 Сен 28 14:23 shadow
-rw-r--r-- 1 root root    0 Сен 29 10:26 wetwet
09:56:50
#./privet.sh Andrey
Privet Andrey!
09:58:23
#vi privet.sh
09:58:26
#~
Privet Noname!
09:58:28
#./privet.sh Andrey
Privet Andrey!
09:58:33
#vi privet.sh
--- /tmp/l3-saved-7671.2617.20523	2015-09-29 10:58:53.944319807 +0300
+++ privet.sh	2015-09-29 10:59:54.232319809 +0300
@@ -1,2 +1,2 @@
 #!/bin/bash
-echo "Privet ${1:-Noname}!"
+echo "Privet ${1:+Noname}!"
09:59:54
#./privet.sh Andrey
Privet Noname!
09:59:56
#./privet.sh
Privet !
10:00:01
#echo $((7+5))
12
10:00:59
#echo $[7+5]
12
10:01:31
#i=1

10:02:30
#echo $i
1
10:02:45
#i=$[$i+1]

10:03:11
#echo $i
2
10:03:29
#i=$[56/9]

10:04:17
#echo $[56/9]
6
10:04:22
#top
top - 11:05:09 up 3 days, 17:42,  3 users,  load average: 1,01, 1,03, 1,05
Tasks:  57 total,   2 running,  55 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0,0 us,  0,0 sy, 52,7 ni,  0,0 id,  0,0 wa,  0,0 hi,  0,0 si, 47,3 st
KiB Mem:    507368 total,   307792 used,   199576 free,    89936 buffers
KiB Swap:        0 total,        0 used,        0 free,   116672 cached
  PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM    TIME+  COMMAND
 5939 root      39  19 20608 6360  856 R  99,7  1,3   1086:48 john
 7371 root      20   0     0    0    0 S   0,3  0,0   0:00.81 kworker/0:0
 7393 root      20   0 71292 3724 2904 S   0,3  0,7   0:00.99 sshd
    1 root      20   0 10648  832  696 S   0,0  0,2   0:04.72 init
...
    8 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 cpuset
    9 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 khelper
   10 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kdevtmpfs
   11 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 netns
   12 root      20   0     0    0    0 S   0,0  0,0   0:00.00 xenwatch
   13 root      20   0     0    0    0 S   0,0  0,0   0:00.00 xenbus
   14 root      20   0     0    0    0 S   0,0  0,0   0:01.14 sync_supers
   15 root      20   0     0    0    0 S   0,0  0,0   0:00.02 bdi-default
   16 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 kintegrityd
   17 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 kblockd
10:05:18
#ps ax
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:04 init [2]
    2 ?        S      0:00 [kthreadd]
    3 ?        S      0:00 [ksoftirqd/0]
    5 ?        S      0:00 [kworker/u:0]
    6 ?        S      0:00 [migration/0]
    7 ?        S      0:02 [watchdog/0]
    8 ?        S<     0:00 [cpuset]
    9 ?        S<     0:00 [khelper]
   10 ?        S      0:00 [kdevtmpfs]
...
 7471 ?        Ss     0:00 sshd: ivan [priv]
 7473 ?        S      0:00 sshd: ivan@pts/2
 7474 pts/2    Ss+    0:00 -bash
 7555 ?        Ss     0:00 sshd: petr [priv]
 7557 ?        S      0:00 sshd: petr@pts/3
 7558 pts/3    Ss+    0:00 -bash
 7639 pts/0    S+     0:00 script -f -c l3script -q /root/.lilalo//3214919816900
 7670 pts/0    S+     0:00 script -f -c l3script -q /root/.lilalo//3214919816900
 7671 pts/4    Ss     0:00 l3script
 8624 pts/4    R+     0:00 ps ax
10:05:33
#ps ax | wc -l
59
10:06:02
#top
top - 11:06:28 up 3 days, 17:43,  3 users,  load average: 1,03, 1,04, 1,05
Tasks:  57 total,   2 running,  55 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0,2 us,  0,0 sy, 13,1 ni, 75,2 id,  0,1 wa,  0,0 hi,  0,0 si, 11,4 st
KiB Mem:    507368 total,   308040 used,   199328 free,    89996 buffers
KiB Swap:        0 total,        0 used,        0 free,   116728 cached
  PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM    TIME+  COMMAND
 5939 root      39  19 20608 6360  856 R  99,0  1,3   1088:06 john
    1 root      20   0 10648  832  696 S   0,0  0,2   0:04.72 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.23 ksoftirqd/0
...
    8 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 cpuset
    9 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 khelper
   10 root      20   0     0    0    0 S   0,0  0,0   0:00.00 kdevtmpfs
   11 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 netns
   12 root      20   0     0    0    0 S   0,0  0,0   0:00.00 xenwatch
   13 root      20   0     0    0    0 S   0,0  0,0   0:00.00 xenbus
   14 root      20   0     0    0    0 S   0,0  0,0   0:01.14 sync_supers
   15 root      20   0     0    0    0 S   0,0  0,0   0:00.02 bdi-default
   16 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 kintegrityd
   17 root       0 -20     0    0    0 S   0,0  0,0   0:00.00 kblockd
10:07:03
#echo $[$(ps ax | wc -l)-4]
56
10:09:16
#p=$[$(ps ax | wc -l)-4]

10:09:27
#echo $p
56
10:09:31
#who
root     pts/0        2015-09-29 10:00 (192.168.16.106)
ivan     pts/2        2015-09-29 10:05 (192.168.16.106)
petr     pts/3        2015-09-29 10:05 (192.168.16.106)
10:11:01
#tty
/dev/pts/0
10:11:17
#who
root     pts/0        2015-09-29 10:00 (192.168.16.106)
ivan     pts/2        2015-09-29 10:05 (192.168.16.106)
petr     pts/3        2015-09-29 10:05 (192.168.16.106)
10:13:31
#cat
23423               file1               privet.sh
23423523            file2               .profile
234235232252352435  file3               report
234235325           file4               shadow
234g23              file5               .vim/
234g23hgfdfh        install             .viminfo
.aptitude/          .john/              .vimrc
.bash_history       .l3rc               wetwet
.bash_profile       .lesshst
.bashrc             .lilalo/
10:13:31
#cat
23423               file1               privet.sh
23423523            file2               .profile
234235232252352435  file3               report
234235325           file4               shadow
234g23              file5               .vim/
234g23hgfdfh        install             .viminfo
.aptitude/          .john/              .vimrc
.bash_history       .l3rc               wetwet
.bash_profile       .lesshst
.bashrc             .lilalo/
10:13:31
#cat report

10:13:44
#cat
fjfffguk
fjfffguk
fuyifuyfyu
fuyifuyfyu
xedfgse
xedfgse
aw
aw
aegfseg
aegfseg
10:14:49
#echo $?
0
10:14:58
#cat
w3rw4e
w3rw4e
w4egw4eg
w4egw4eg
w3gw34g
w3gw34g
wgw3g
wgw3g
^C
10:15:08
#echo $?
130
10:15:09
#cat &
[1] 8770
[1]+  Stopped                 cat
10:15:41
#jobs
[1]+  Stopped                 cat
10:15:51
#jobs -l
[1]+  8770 Остановлено (ввод с терминала)                               cat
10:16:02
#cd /proc/8770/fd

10:16:34
#ls -l
итого 0
lrwx------ 1 root root 64 Сен 29 11:16 0 -> /dev/pts/4
lrwx------ 1 root root 64 Сен 29 11:16 1 -> /dev/pts/4
lrwx------ 1 root root 64 Сен 29 11:16 2 -> /dev/pts/4
10:16:52
#tty
/dev/pts/0
10:17:04
#who
root     pts/0        2015-09-29 10:00 (192.168.16.106)
ivan     pts/2        2015-09-29 10:05 (192.168.16.106)
petr     pts/3        2015-09-29 10:05 (192.168.16.106)
10:17:22
#pstree
init─┬─acpid
     ├─cron
     ├─exim4
     ├─6*[getty]
     ├─john
     ├─l3-agent
     ├─rsyslogd───3*[{rsyslogd}]
     ├─sshd─┬─sshd───bash───script───script───l3script─┬─cat
     │      │                                          └─pstree
     │      └─2*[sshd───sshd───bash]
     └─udevd
10:17:28
#pstree -p
init(1)─┬─acpid(1931)
        ├─cron(1969)
        ├─exim4(2240)
        ├─getty(2285)
        ├─getty(2286)
        ├─getty(2287)
        ├─getty(2288)
        ├─getty(2289)
        ├─getty(2290)
        ├─john(5939)
        ├─l3-agent(3377)
        ├─rsyslogd(1878)─┬─{rsyslogd}(1884)
        │                ├─{rsyslogd}(1886)
        │                └─{rsyslogd}(1887)
        ├─sshd(2261)─┬─sshd(7393)───bash(7395)───script(7639)───script(7670)───+
        │            ├─sshd(7471)───sshd(7473)───bash(7474)
        │            └─sshd(7555)───sshd(7557)───bash(7558)
        └─udevd(276)
10:17:42
#cd ../../7395/fd

10:18:01
#ls -l
итого 0
lrwx------ 1 root root 64 Сен 29 10:00 0 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 10:00 1 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 10:00 2 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 11:18 255 -> /dev/pts/0
10:18:03
#cd ../../7639/fd

10:18:11
#ls -l
итого 0
lrwx------ 1 root root 64 Сен 29 11:18 0 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 11:18 1 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 10:06 2 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 11:18 4 -> /dev/ptmx
lrwx------ 1 root root 64 Сен 29 11:18 5 -> /dev/pts/4
10:18:13
#cd ../../7670/fd

10:18:34
#ls -l
итого 0
lrwx------ 1 root root 64 Сен 29 11:18 1 -> /dev/pts/0
lrwx------ 1 root root 64 Сен 29 10:06 2 -> /dev/pts/0
l-wx------ 1 root root 64 Сен 29 11:18 3 -> /root/.lilalo/3214919816900022178-1443510370.script
lrwx------ 1 root root 64 Сен 29 11:18 4 -> /dev/ptmx
10:18:35
#cd

10:18:56
#find / -user ivan -type f
/tmp/users
/home/ivan/.bashrc
/home/ivan/.bash_history
/home/ivan/d4/d3/d1/f1
/home/ivan/d4/d3/d1/users
/home/ivan/.profile
/home/ivan/.viminfo
/home/ivan/.bash_logout
/proc/7474/task/7474/fdinfo/0
/proc/7474/task/7474/fdinfo/1
...
/proc/7474/oom_adj
/proc/7474/oom_score_adj
/proc/7474/loginuid
/proc/7474/sessionid
/proc/7474/coredump_filter
/proc/7474/io
find: `/proc/8893/task/8893/fd/5': Нет такого файла или каталога
find: `/proc/8893/task/8893/fdinfo/5': Нет такого файла или каталога
find: `/proc/8893/fd/5': Нет такого файла или каталога
find: `/proc/8893/fdinfo/5': Нет такого файла или каталога
10:19:47
#find / -user ivan -type f 2> errors
/tmp/users
/home/ivan/.bashrc
/home/ivan/.bash_history
/home/ivan/d4/d3/d1/f1
/home/ivan/d4/d3/d1/users
/home/ivan/.profile
/home/ivan/.viminfo
/home/ivan/.bash_logout
/proc/7474/task/7474/fdinfo/0
/proc/7474/task/7474/fdinfo/1
...
/proc/7474/stack
/proc/7474/cpuset
/proc/7474/cgroup
/proc/7474/oom_score
/proc/7474/oom_adj
/proc/7474/oom_score_adj
/proc/7474/loginuid
/proc/7474/sessionid
/proc/7474/coredump_filter
/proc/7474/io
10:20:37
#ls
23423               234235325     errors  file3  install    shadow
23423523            234g23        file1   file4  privet.sh  wetwet
234235232252352435  234g23hgfdfh  file2   file5  report
10:20:47
#cat errors
find: `/proc/8901/task/8901/fd/5': Нет такого файла или каталога
find: `/proc/8901/task/8901/fdinfo/5': Нет такого файла или каталога
find: `/proc/8901/fd/5': Нет такого файла или каталога
find: `/proc/8901/fdinfo/5': Нет такого файла или каталога
10:20:54
#find / -user ivan -type f 2> errors 1> files

10:21:13
#find / -user ivan -type f &> all

10:22:00
#mail ivan
Subject: hello
Privet ivan
.
EOT
10:25:12
#ls
23423               234235325     all     file2  file5    privet.sh  wetwet
23423523            234g23        errors  file3  files    report
234235232252352435  234g23hgfdfh  file1   file4  install  shadow
10:25:15
#mail -s report ivan < all

10:25:30
#ls
23423               234235325     all     file2  file5    privet.sh  wetwet
23423523            234g23        errors  file3  files    report
234235232252352435  234g23hgfdfh  file1   file4  install  shadow
10:26:54
#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
10:27:16
#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:27:29
#set -o noclobber

10:28:09
#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:28:56
#lsattr
-------------e-- ./errors
-------------e-- ./file4
-------------e-- ./234g23hgfdfh
-------------e-- ./files
-------------e-- ./234235232252352435
-------------e-- ./all
-------------e-- ./shadow
-------------e-- ./23423523
-------------e-- ./file1
-------------e-- ./23423
-------------e-- ./report
-------------e-- ./file5
-------------e-- ./privet.sh
-------------e-- ./234g23
-------------e-- ./wetwet
-------------e-- ./file3
-------------e-- ./234235325
-------------e-- ./install
-------------e-- ./file2
10:29:38
#chattr +a report

10:30:18
#lsattr
-------------e-- ./errors
-------------e-- ./file4
-------------e-- ./234g23hgfdfh
-------------e-- ./files
-------------e-- ./234235232252352435
-------------e-- ./all
-------------e-- ./shadow
-------------e-- ./23423523
-------------e-- ./file1
-------------e-- ./23423
-----a-------e-- ./report
-------------e-- ./file5
-------------e-- ./privet.sh
-------------e-- ./234g23
-------------e-- ./wetwet
-------------e-- ./file3
-------------e-- ./234235325
-------------e-- ./install
-------------e-- ./file2
10:30:38
#date >> report

10:31:15
#chattr +i report

10:31:20
#rm report
rm: удалить обычный файл «report»? y
rm: невозможно удалить «report»: Операция не позволяется
10:31:43
#mv report report2
mv: невозможно переместить «report» в «report2»: Операция не позволяется
10:31:49
#date > report
l3script: report: Отказано в доступе
10:31:55
#date >> report
l3script: report: Отказано в доступе
10:31:58
#ls
23423               234235325     all     file2  file5    privet.sh  wetwet
23423523            234g23        errors  file3  files    report
234235232252352435  234g23hgfdfh  file1   file4  install  shadow
прошло 23 минуты
10:55:51
#ls f*
file1  file2  file3  file4  file5  files
10:56:06
#ls -1 f*
file1
file2
file3
file4
file5
files
10:56:27
#ls -1 f* | sort -r
files
file5
file4
file3
file2
file1
10:56:33
#ls -1 f* | rm -f

10:57:12
#ls
23423               234235325     all     file2  file5    privet.sh  wetwet
23423523            234g23        errors  file3  files    report
234235232252352435  234g23hgfdfh  file1   file4  install  shadow
10:57:14
#rm -f

10:57:22
#ls -1 f* | xargs rm -f

10:58:22
#ls
23423     234235232252352435  234g23        all     install    report  wetwet
23423523  234235325           234g23hgfdfh  errors  privet.sh  shadow
11:07:55
#ls @([^0-9]|cd)*
all  errors  install  privet.sh  report  shadow  wetwet
11:08:07
#ls @([^a-e]|cd)*
23423     234235232252352435  234g23        install    report  wetwet
23423523  234235325           234g23hgfdfh  privet.sh  shadow
11:08:23
#cd /bin

11:08:37
#ls @([^a-e]|cd)*
false      less      mount           ping6       sleep          which
fgconsole  lessecho  mountpoint      ps          ss             ypdomainname
fgrep      lessfile  mt              pwd         stty           zcat
findmnt    lesskey   mt-gnu          rbash       su             zcmp
fuser      lesspipe  mv              readlink    sync           zdiff
grep       ln        nano            rm          tailf          zegrep
gunzip     loadkeys  nc              rmdir       tar            zfgrep
gzexe      login     nc.traditional  rnano       tempfile       zforce
gzip       ls        netcat          run-parts   touch          zgrep
hostname   lsblk     netstat         rzsh        true           zless
ip         lsmod     nisdomainname   sed         umount         zmore
kbd_mode   mkdir     open            setfont     uname          znew
kill       mknod     openvt          setupcon    uncompress     zsh
kmod       mktemp    pidof           sh          unicode_start  zsh4
ksh        more      ping            sh.distrib  vdir
11:08:39
#ls @([^a-e]|[cd])*
cat            grep      mkdir           pwd         touch
chgrp          gunzip    mknod           rbash       true
chmod          gzexe     mktemp          readlink    umount
chown          gzip      more            rm          uname
chvt           hostname  mount           rmdir       uncompress
cp             ip        mountpoint      rnano       unicode_start
cpio           kbd_mode  mt              run-parts   vdir
dash           kill      mt-gnu          rzsh        which
date           kmod      mv              sed         ypdomainname
dd             ksh       nano            setfont     zcat
df             less      nc              setupcon    zcmp
dir            lessecho  nc.traditional  sh          zdiff
dmesg          lessfile  netcat          sh.distrib  zegrep
dnsdomainname  lesskey   netstat         sleep       zfgrep
domainname     lesspipe  nisdomainname   ss          zforce
dumpkeys       ln        open            stty        zgrep
false          loadkeys  openvt          su          zless
fgconsole      login     pidof           sync        zmore
fgrep          ls        ping            tailf       znew
findmnt        lsblk     ping6           tar         zsh
fuser          lsmod     ps              tempfile    zsh4
11:09:06
#ls @([^a-e])*
false      less      mount           ping6       sleep          which
fgconsole  lessecho  mountpoint      ps          ss             ypdomainname
fgrep      lessfile  mt              pwd         stty           zcat
findmnt    lesskey   mt-gnu          rbash       su             zcmp
fuser      lesspipe  mv              readlink    sync           zdiff
grep       ln        nano            rm          tailf          zegrep
gunzip     loadkeys  nc              rmdir       tar            zfgrep
gzexe      login     nc.traditional  rnano       tempfile       zforce
gzip       ls        netcat          run-parts   touch          zgrep
hostname   lsblk     netstat         rzsh        true           zless
ip         lsmod     nisdomainname   sed         umount         zmore
kbd_mode   mkdir     open            setfont     uname          znew
kill       mknod     openvt          setupcon    uncompress     zsh
kmod       mktemp    pidof           sh          unicode_start  zsh4
ksh        more      ping            sh.distrib  vdir
11:09:21
#ls @([^a-e]|[cd])*
cat            grep      mkdir           pwd         touch
chgrp          gunzip    mknod           rbash       true
chmod          gzexe     mktemp          readlink    umount
chown          gzip      more            rm          uname
chvt           hostname  mount           rmdir       uncompress
cp             ip        mountpoint      rnano       unicode_start
cpio           kbd_mode  mt              run-parts   vdir
dash           kill      mt-gnu          rzsh        which
date           kmod      mv              sed         ypdomainname
dd             ksh       nano            setfont     zcat
df             less      nc              setupcon    zcmp
dir            lessecho  nc.traditional  sh          zdiff
dmesg          lessfile  netcat          sh.distrib  zegrep
dnsdomainname  lesskey   netstat         sleep       zfgrep
domainname     lesspipe  nisdomainname   ss          zforce
dumpkeys       ln        open            stty        zgrep
false          loadkeys  openvt          su          zless
fgconsole      login     pidof           sync        zmore
fgrep          ls        ping            tailf       znew
findmnt        lsblk     ping6           tar         zsh
fuser          lsmod     ps              tempfile    zsh4
11:09:30
#> *
l3script: *: ambiguous redirect
прошло 40 минут
11:50:26
#> \*

Файлы

  • &
  • cat
  • errors
  • report
  • &
    >
    [1] 8770
    [1]+  Stopped                 cat
    
    cat
    >
    fjfffguk
    fjfffguk
    fuyifuyfyu
    fuyifuyfyu
    xedfgse
    xedfgse
    aw
    aw
    aegfseg
    aegfseg
    
    errors
    >
    find: `/proc/8901/task/8901/fd/5': Нет такого файла или каталога
    find: `/proc/8901/task/8901/fdinfo/5': Нет такого файла или каталога
    find: `/proc/8901/fd/5': Нет такого файла или каталога
    find: `/proc/8901/fdinfo/5': Нет такого файла или каталога
    
    report
    >

    Статистика

    Время первой команды журнала09:42:25 2015- 9-29
    Время последней команды журнала11:50:26 2015- 9-29
    Количество командных строк в журнале101
    Процент команд с ненулевым кодом завершения, %11.88
    Процент синтаксически неверно набранных команд, % 0.99
    Суммарное время работы с терминалом *, час 1.45
    Количество командных строк в единицу времени, команда/мин 1.16
    Частота использования команд
    ls26|====================| 20.80%
    echo10|========| 8.00%
    cat7|=====| 5.60%
    privet.sh7|=====| 5.60%
    cd6|====| 4.80%
    >5|====| 4.00%
    find4|===| 3.20%
    rm3|==| 2.40%
    set3|==| 2.40%
    wc3|==| 2.40%
    cd)*3|==| 2.40%
    report3|==| 2.40%
    vi3|==| 2.40%
    who3|==| 2.40%
    date3|==| 2.40%
    lsattr2|=| 1.60%
    mail2|=| 1.60%
    all2|=| 1.60%
    errors2|=| 1.60%
    ps2|=| 1.60%
    top2|=| 1.60%
    jobs2|=| 1.60%
    [cd])*2|=| 1.60%
    chattr2|=| 1.60%
    tty2|=| 1.60%
    pstree2|=| 1.60%
    i=$[$i+1]1|| 0.80%
    sort1|| 0.80%
    chmod1|| 0.80%
    \*1|| 0.80%
    ~1|| 0.80%
    p=$[$(ps1|| 0.80%
    mv1|| 0.80%
    *1|| 0.80%
    pwd1|| 0.80%
    xargs1|| 0.80%
    files1|| 0.80%
    shopt1|| 0.80%
    9]1|| 0.80%
    i=11|| 0.80%
    ____
    *) Интервалы неактивности длительностью 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$