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

Содержание

Журнал

Среда (01/13/10)

/dev/ttyp8
14:37:33
#pidof bash
[root@debian1:~]# killall -l
HUP INT QUIT ILL TRAP ABRT IOT BUS FPE KILL USR1 SEGV USR2 PIPE ALRM TERM
STKFLT CHLD CONT STOP TSTP TTIN TTOU URG XCPU XFSZ VTALRM PROF WINCH IO PWR SYS
UNUSED
19565 6294 4510 2188 2064 2015 1914
14:38:36
#top
top - 15:40:26 up 3 days, 20:18,  7 users,  load average: 0.04, 0.04, 0.00
Tasks:  73 total,   1 running,  67 sleeping,   5 stopped,   0 zombie
Cpu(s):  0.0%us,  0.0%sy,  0.0%ni,100.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%
Mem:    594068k total,   558964k used,    35104k free,    74708k buffers
  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
Swap:        0k total,        0k used,        0k free,   368816k cached
    1 root      15   0  1960  648  552 S  0.0  0.1   0:00.05 init
    2 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 migration/0
    3 root      34  19     0    0    0 S  0.0  0.0   0:00.00 ksoftirqd/0
    4 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 events/0
...
    8 root      13  -5     0    0    0 S  0.0  0.0   0:00.00 xenbus
   16 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 kblockd/0
   18 root      20  -5     0    0    0 S  0.0  0.0   0:00.00 kseriod
   55 root      25   0     0    0    0 S  0.0  0.0   0:00.00 pdflush
   56 root      15   0     0    0    0 S  0.0  0.0   0:00.09 pdflush
   57 root      20  -5     0    0    0 S  0.0  0.0   0:00.00 kswapd0
   58 root      20  -5     0    0    0 S  0.0  0.0   0:00.00 aio/0
  609 root      20  -5     0    0    0 S  0.0  0.0   0:00.00 kmirrord
  707 root      10  -5     0    0    0 S  0.0  0.0   0:00.06 reiserfs/0
 1165 root      18   0  1760  640  516 S  0.0  0.1   0:00.00 syslogd
14:43:59
#date
Wed Jan 13 15:44:01 EET 2010
/dev/ttyp0
14:49:46
#ps -x
Warning: bad ps syntax, perhaps a bogus '-'? See http://procps.sf.net/faq.html
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:00 init [2]
    2 ?        S      0:00 [migration/0]
    3 ?        SN     0:00 [ksoftirqd/0]
    4 ?        S<     0:00 [events/0]
    5 ?        S<     0:00 [khelper]
    6 ?        S<     0:00 [kthread]
    7 ?        S<     0:00 [xenwatch]
    8 ?        S<     0:00 [xenbus]
...
10922 ttyp1    T      0:00 less file
16357 ?        Ss     6:53 l3-agent
19523 ?        Ss     0:00 sshd: root@ttyp6
19525 ttyp6    Ss+    0:00 script -f -q /root/.lilalo//29214322232976717785-1263
19564 ttyp6    S+     0:00 script -f -q /root/.lilalo//29214322232976717785-1263
19565 ttyp7    Ss     0:00 bash -i
19604 ttyp7    S+     0:00 screen -x
20522 ?        S<     0:00 [rpciod/0]
20523 ?        S      0:00 [lockd]
21061 ttyp1    R+     0:00 ps -x
14:49:55
#ps U user
  PID TTY      STAT   TIME COMMAND
17154 ?        Ss     0:01 l3-agent
14:50:19
#ps U root
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:00 init [2]
    2 ?        S      0:00 [migration/0]
    3 ?        SN     0:00 [ksoftirqd/0]
    4 ?        S<     0:00 [events/0]
    5 ?        S<     0:00 [khelper]
    6 ?        S<     0:00 [kthread]
    7 ?        S<     0:00 [xenwatch]
    8 ?        S<     0:00 [xenbus]
   16 ?        S<     0:00 [kblockd/0]
...
10922 ttyp1    T      0:00 less file
16357 ?        Ss     6:53 l3-agent
19523 ?        Ss     0:00 sshd: root@ttyp6
19525 ttyp6    Ss+    0:00 script -f -q /root/.lilalo//29214322232976717785-1263
19564 ttyp6    S+     0:00 script -f -q /root/.lilalo//29214322232976717785-1263
19565 ttyp7    Ss     0:00 bash -i
19604 ttyp7    S+     0:00 screen -x
20522 ?        S<     0:00 [rpciod/0]
20523 ?        S      0:00 [lockd]
21077 ttyp1    R+     0:00 ps U root
14:50:25
#ps U user
  PID TTY      STAT   TIME COMMAND
17154 ?        Ss     0:01 l3-agent
14:50:39
#ps -t tty1
[root@debian1:/]# ps U user1
  PID TTY      STAT   TIME COMMAND
  PID TTY          TIME CMD
 1237 tty1     00:00:00 getty
14:50:54
#ps -t tty0
  PID TTY          TIME CMD
14:50:59
#ps -t tty2
  PID TTY          TIME CMD
 1238 tty2     00:00:00 getty
14:51:04
#ps -t tty3
  PID TTY          TIME CMD
 1239 tty3     00:00:00 getty
14:51:07
#ps -ax
Warning: bad ps syntax, perhaps a bogus '-'? See http://procps.sf.net/faq.html
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:00 init [2]
    2 ?        S      0:00 [migration/0]
    3 ?        SN     0:00 [ksoftirqd/0]
    4 ?        S<     0:00 [events/0]
    5 ?        S<     0:00 [khelper]
    6 ?        S<     0:00 [kthread]
    7 ?        S<     0:00 [xenwatch]
    8 ?        S<     0:00 [xenbus]
...
19523 ?        Ss     0:00 sshd: root@ttyp6
19525 ttyp6    Ss+    0:00 script -f -q /root/.lilalo//29214322232976717785-1263
19564 ttyp6    S+     0:00 script -f -q /root/.lilalo//29214322232976717785-1263
19565 ttyp7    Ss     0:00 bash -i
19604 ttyp7    S+     0:00 screen -x
20355 ?        Ss     0:00 /sbin/portmap
20474 ?        Ss     0:00 /sbin/rpc.statd
20522 ?        S<     0:00 [rpciod/0]
20523 ?        S      0:00 [lockd]
21133 ttyp1    R+     0:00 ps -ax
14:51:14
#ps -aux
Warning: bad ps syntax, perhaps a bogus '-'? See http://procps.sf.net/faq.html
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.1   1960   648 ?        Ss   Jan09   0:00 init [2]
root         2  0.0  0.0      0     0 ?        S    Jan09   0:00 [migration/0]
root         3  0.0  0.0      0     0 ?        SN   Jan09   0:00 [ksoftirqd/0]
root         4  0.0  0.0      0     0 ?        S<   Jan09   0:00 [events/0]
root         5  0.0  0.0      0     0 ?        S<   Jan09   0:00 [khelper]
root         6  0.0  0.0      0     0 ?        S<   Jan09   0:00 [kthread]
root         7  0.0  0.0      0     0 ?        S<   Jan09   0:00 [xenwatch]
root         8  0.0  0.0      0     0 ?        S<   Jan09   0:00 [xenbus]
...
root     19523  0.0  0.3   7712  2368 ?        Ss   14:01   0:00 sshd: root@ttyp
root     19525  0.0  0.1   4712   680 ttyp6    Ss+  14:02   0:00 script -f -q /r
root     19564  0.0  0.0   4840   472 ttyp6    S+   14:02   0:00 script -f -q /r
root     19565  0.0  0.4   6640  2664 ttyp7    Ss   14:02   0:00 bash -i
root     19604  0.0  0.1   5564  1016 ttyp7    S+   14:02   0:00 screen -x
daemon   20355  0.0  0.0   1700   368 ?        Ss   14:21   0:00 /sbin/portmap
statd    20474  0.0  0.1   1772   740 ?        Ss   14:21   0:00 /sbin/rpc.statd
root     20522  0.0  0.0      0     0 ?        S<   14:22   0:00 [rpciod/0]
root     20523  0.0  0.0      0     0 ?        S    14:22   0:00 [lockd]
root     21141  0.0  0.1   5176   988 ttyp1    R+   15:51   0:00 ps -aux
14:51:33
#ps -av
Warning: bad ps syntax, perhaps a bogus '-'? See http://procps.sf.net/faq.html
  PID TTY      STAT   TIME  MAJFL   TRS   DRS   RSS %MEM COMMAND
    1 ?        Ss     0:00     17    29  1930   648  0.1 init [2]
    2 ?        S      0:00      0     0     0     0  0.0 [migration/0]
    3 ?        SN     0:00      0     0     0     0  0.0 [ksoftirqd/0]
    4 ?        S<     0:00      0     0     0     0  0.0 [events/0]
    5 ?        S<     0:00      0     0     0     0  0.0 [khelper]
    6 ?        S<     0:00      0     0     0     0  0.0 [kthread]
    7 ?        S<     0:00      0     0     0     0  0.0 [xenwatch]
    8 ?        S<     0:00      0     0     0     0  0.0 [xenbus]
...
19523 ?        Ss     0:00      0   306  7405  2368  0.3 sshd: root@ttyp6
19525 ttyp6    Ss+    0:00      0     5  4706   680  0.1 script -f -q /root/.lil
19564 ttyp6    S+     0:00      0     5  4834   472  0.0 script -f -q /root/.lil
19565 ttyp7    Ss     0:00      0   641  5998  2664  0.4 bash -i
19604 ttyp7    S+     0:00      0   282  5281  1016  0.1 screen -x
20355 ?        Ss     0:00      0    10  1689   368  0.0 /sbin/portmap
20474 ?        Ss     0:00      0    36  1735   740  0.1 /sbin/rpc.statd
20522 ?        S<     0:00      0     0     0     0  0.0 [rpciod/0]
20523 ?        S      0:00      0     0     0     0  0.0 [lockd]
21149 ttyp1    R+     0:00      0    61  4902   804  0.1 ps -avx
14:51:39
#pstree -p
init(1)─┬─cron(1215)
        ├─events/0(4)
        ├─gdm(1203)───gdm(1211)─┬─Xvnc(1214)
        │                       └─gdmlogin(1248)
        ├─getty(1237)
        ├─getty(1238)
        ├─getty(1239)
        ├─getty(1240)
        ├─getty(1241)
        ├─getty(1242)
...
        ├─sshd(1872)───script(1874)───script(1913)───bash(1914)─┬─ed(8719)
        │                                                       ├─less(10922)
        │                                                       ├─man(8364)───p+
        │                                                       ├─pstree(21157)
        │                                                       └─vi(6607)
        ├─sshd(1957)───script(1979)───script(2063)───bash(2064)───screen(2212)
        ├─sshd(1959)───script(1961)───script(2014)───bash(2015)───screen(2211)
        ├─sshd(6252)───script(6254)───script(6293)───bash(6294)───screen(6324)
        ├─sshd(7433)───sshd(19523)───script(19525)───script(19564)───bash(19565+
        └─syslogd(1165)
14:54:16
#at
bash: at: command not found
прошло 49 минут
15:44:09
#man at
15:44:25
#man cron
/dev/ttyp8
15:46:17
#vim /etc/crontab
15:50:56
#date
  5 # that none of the other crontabs do.
  6
  7 SHELL=/bin/sh
  8 PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
  9
 10 # m h dom mon dow user  command
 11 17 *    * * *   root    cd / && run-parts --report /etc/cron.hourly
 12 25 6    * * *   root    test -x /usr/sbin/anacron || ( cd / && run-partss
     --report /etc/cron.daily )
 13 47 6    * * 7   root    test -x /usr/sbin/anacron || ( cd / && run-partss
     --report /etc/cron.weekly )
 14 52 6    1 * *   root    test -x /usr/sbin/anacron || ( cd / && run-partss
     --report /etc/cron.monthly )
 15 *  *    * * *   root    logger -p emerg CRONTAB#
 16
 17
~
~
~
"/etc/crontab" 17L, 771C written
Wed Jan 13 16:50:58 EET 2010
/dev/ttyp0
15:51:08
#crontab -l
no crontab for root
/dev/ttyp8
15:51:09
#vim /etc/crontab
--- /tmp/l3-saved-2188.25041.1831	2010-01-13 16:51:10.000000000 +0200
+++ /etc/crontab	2010-01-13 16:51:19.000000000 +0200
@@ -12,6 +12,6 @@
 25 6	* * *	root	test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily )
 47 6	* * 7	root	test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.weekly )
 52 6	1 * *	root	test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.monthly )
-*  *    * * *   root    logger -p emerg CRONTAB#
+#*  *    * * *   root    logger -p emerg CRONTAB#
 
 
15:54:00
#EDITOR=vim crontab -e
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
"crontab.JXNhgX/crontab" 2L, 70C written
crontab: installing new crontab
15:55:04
#date
Wed Jan 13 16:55:06 EET 2010
15:55:06
#date
Wed Jan 13 16:55:09 EET 2010
15:55:34
#crontab -l -u user
[root@debian1:~]# crontab -l -u root
# m h  dom mon dow   command
* * * * * logger -p emerg cron-from-USER
no crontab for user
15:55:41
#grep -r USER /var/spool/
[root@debian1:~]# grep -r USER /var/spool/
cron/ mail/
cron/ mail/
15:55:41
#grep -r USER /var/spool/
cron/ mail/
15:56:22
#crontab -r -u root
[root@debian1:~]# grep -r USER /var/spool/cron/crontabs/
/var/spool/cron/crontabs/root:* * * * * logger -p emerg cron-from-USER
15:56:42
#grep -r USER /var/spool/cron/crontabs/

15:56:45
#ls -l /var/spool/cron/crontabs/
total 0
15:57:36
$EDITOR=vim
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
"crontab.kAmk4h/crontab" 2L, 73C записано
crontab: installing new crontab
15:58:13
$date
Срд Янв 13 16:58:15 EET 2010
15:58:15
$exit
exit
15:58:30
#grep -r USER /var/spool/cron/crontabs/
/var/spool/cron/crontabs/user:* * * * * logger -p emerg USER-TEST-CRONtab
15:59:17
#date
[root@debian1:~]# crontab -r -u user
Wed Jan 13 16:59:18 EET 2010
15:59:18
#grep -r USER /var/spool/cron/crontabs/

15:59:20
#ls /var/spool/cron/crontabs/

15:59:23
#vim /etc/cron.deny
--- /dev/null	2010-01-09 19:22:11.915890422 +0200
+++ /etc/cron.deny	2010-01-13 16:59:48.000000000 +0200
@@ -0,0 +1 @@
+user
15:59:48
#su - user
l3-agent is already running: pid=17154; pidfile=/home/user/.lilalo/l3-agent.pid
15:59:53
$EDITOR=vim crontab -e
You (user) are not allowed to use this program (crontab)
See crontab(1) for more information
15:59:55
$exit
exit
16:00:17
#su - user
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
"/etc/cron.allow" [New] 1L, 5C written
l3-agent is already running: pid=17154; pidfile=/home/user/.lilalo/l3-agent.pid
16:00:47
$exit
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
No modification made
exit
16:00:49
#rm /etc/cron.allow

16:00:53
#su - user
l3-agent is already running: pid=17154; pidfile=/home/user/.lilalo/l3-agent.pid
16:00:55
$EDITOR=vim crontab -e
You (user) are not allowed to use this program (crontab)
See crontab(1) for more information
16:00:57
$date
Срд Янв 13 17:03:04 EET 2010

Статистика

Время первой команды журнала14:37:33 2010- 1-13
Время последней команды журнала16:00:57 2010- 1-13
Количество командных строк в журнале48
Процент команд с ненулевым кодом завершения, %25.00
Процент синтаксически неверно набранных команд, % 2.08
Суммарное время работы с терминалом *, час 0.56
Количество командных строк в единицу времени, команда/мин 1.43
Частота использования команд
ps11|======================| 22.92%
date7|==============| 14.58%
grep5|==========| 10.42%
EDITOR=vim4|========| 8.33%
crontab3|======| 6.25%
exit3|======| 6.25%
vim3|======| 6.25%
su3|======| 6.25%
man2|====| 4.17%
ls2|====| 4.17%
at1|==| 2.08%
top1|==| 2.08%
pidof1|==| 2.08%
rm1|==| 2.08%
pstree1|==| 2.08%
____
*) Интервалы неактивности длительностью 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$