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

Содержание

Журнал

Среда (03/30/11)

/dev/pts/7
12:53:18
$trap - 2

12:53:22
$trap-2
bash: trap-2: command not found
12:53:26
$trap -2
bash: trap: -2: invalid option
trap: usage: trap [-lp] [arg signal_spec ...]
12:53:31
$trap - 2

12:53:33
$trap 2

12:53:41
$kill $$

прошло 10 минут
13:04:21
$kill $$

13:04:23
$kill $$

13:04:23
$kill $$

13:04:24
$kill $$

13:04:24
$kill $$

13:04:24
$kill $$

13:04:25
$kill $$

13:04:25
$kill $$

13:04:26
$kill $$

13:04:26
$kill $$

13:04:26
$kill $$

13:04:27
$kill $$

13:04:27
$kill $$

13:04:27
$kill $$

13:04:27
$kill $$

Четверг (03/31/11)

/dev/pts/2
06:02:29
$find /etc -name passwd &2>&1 | less
06:03:32
$find /etc -name passwd &2>&1 | less
06:06:10
$find /etc -name passwd &2>&1 | less
06:06:44
$find /etc -name passwd & 2>&1 | less
06:06:53
$find /etc -name passwd 2>&1 | less
06:07:26
$find /etc -name passwd 2>&1 | less
06:07:32
$find /etc -name passwd 2>&1
find: /etc/racoon/certs: Permission denied
find: /etc/audisp: Permission denied
find: /etc/audit: Permission denied
find: /etc/lvm/cache: Permission denied
find: /etc/lvm/backup: Permission denied
find: /etc/lvm/archive: Permission denied
/etc/passwd
find: /etc/cups/ssl: Permission denied
/etc/pam.d/passwd
find: /etc/selinux/targeted/modules/previous: Permission denied
find: /etc/selinux/targeted/modules/active: Permission denied
find: /etc/cron.d: Permission denied
find: /etc/pki/CA: Permission denied
06:07:37
$top
top - 10:15:07 up 16 min,  2 users,  load average: 0.00, 0.00, 0.00
Tasks: 136 total,   1 running, 135 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.2%us,  0.2%sy,  0.0%ni, 99.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:   4016364k total,   597380k used,  3418984k free,    28984k buffers
  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
Swap:  2097164k total,        0k used,  2097164k free,   309432k cached
 2948 root      15   0  361m  14m 6340 S  0.3  0.4   0:01.21 Xorg
 3308 root      15   0  261m  15m 8552 S  0.3  0.4   0:00.14 gnome-terminal
    1 root      15   0 10348  684  576 S  0.0  0.0   0:00.42 init
    2 root      RT  -5     0    0    0 S  0.0  0.0   0:00.00 migration/0
...
    9 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 events/1
   52 root      10  -5     0    0    0 S  0.0  0.0   0:00.01 kblockd/0
   10 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 khelper
   53 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 kblockd/1
   47 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 kthread
   54 root      14  -5     0    0    0 S  0.0  0.0   0:00.00 kacpid
   52 root      10  -5     0    0    0 S  0.0  0.0   0:00.01 kblockd/0
   53 root      10  -5     0    0    0 S  0.0  0.0   0:00.00 kblockd/1
   54 root      14  -5     0    0    0 S  0.0  0.0   0:00.00 kacpid
  162 root      14  -5     0    0    0 S  0.0  0.0   0:00.00 cqueue/0
06:15:20
$date
Thu Mar 31 10:15:23 ALMT 2011
06:15:23
$date; who|wc -l
Thu Mar 31 10:15:35 ALMT 2011
2
06:15:35
$ssh user@192.168.15.253
id socket /var/run/acpid.socket
68        2547  0.0  0.0  12324   844 ?        S    09:59   0:00 hald-addon-keyb
 /dev/input/event2
68        2551  0.0  0.0  12324   848 ?        S    09:59   0:00 hald-addon-keyb
 /dev/input/event1
avahi     2776  0.0  0.0  23272  1276 ?        Ss   10:00   0:00 avahi-daemon: r
al]
avahi     2777  0.0  0.0  23148   336 ?        Ss   10:00   0:00 avahi-daemon: c
dbus      2439  0.0  0.0  21388  1112 ?        Ss   09:59   0:00 dbus-daemon --s
root        10  0.0  0.0      0     0 ?        S<   09:59   0:00 [khelper]
...
user      3669  0.0  0.1  69004  4524 pts/3    Ss   10:02   0:00 bash
user      4105  0.0  0.0  56300  2756 pts/3    S+   10:16   0:00 ssh user@192.16
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
xfs       2732  0.0  0.0  20964  1764 ?        Ss   09:59   0:00 xfs -droppriv -
68        2534  0.1  0.1  31360  4292 ?        Ss   09:59   0:01 hald
root      2948  0.1  0.3 102144 14460 tty7     Ss+  10:00   0:01 /usr/bin/Xorg :
th /var/gdm/:0.Xauth -nolisten tcp vt7
root      3889  0.1  0.0  60956   548 pts/4    Ss+  10:15   0:00 script -f -c ba
o//15673203692709030637-1301544942.script
root      4008  0.2  0.1  69080  4628 pts/5    Ss   10:15   0:00 bash

Пятница (04/01/11)

/dev/pts/2
06:14:37
$ssh 192.168.15.2
user@192.168.15.2's password:
прошло 11 минут
06:26:35
$rm ~/.ssh/known_hosts

06:32:18
$ssh 192.168.15.2
user@192.168.15.2's password:
/dev/pts/2
06:35:54
$ssh-keygen -l -f /etc/ssh/ssh_host_rsa_key
2048 b0:eb:1b:d3:22:b5:d5:bb:e8:4a:10:1d:3b:fb:59:f4 /etc/ssh/ssh_host_rsa_key.pub
06:35:58
$hostname
linux1.unix.bas
06:36:03
$ifconfig
bash: ifconfig: command not found
06:36:28
$/sbin/ifconfig
eth0      Link encap:Ethernet  HWaddr E0:CB:4E:DD:EA:D7
          inet addr:192.168.15.1  Bcast:192.168.15.255  Mask:255.255.255.0
          inet6 addr: fe80::e2cb:4eff:fedd:ead7/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:9335 errors:0 dropped:0 overruns:0 frame:0
          TX packets:5327 errors:0 dropped:0 overruns:0 carrier:1
          collisions:0 txqueuelen:1000
          RX bytes:11899404 (11.3 MiB)  TX bytes:401285 (391.8 KiB)
          Interrupt:66 Memory:feac0000-feb00000
lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:942 errors:0 dropped:0 overruns:0 frame:0
          TX packets:942 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:1721516 (1.6 MiB)  TX bytes:1721516 (1.6 MiB)
06:36:30
$ssh-keygen -R 192.168.15.2
/home/user/.ssh/known_hosts updated.
Original contents retained as /home/user/.ssh/known_hosts.old
06:36:32
$exit
exit
Connection to 192.168.15.1 closed.
06:36:57
$vim /home/user/.ssh/config
--- /dev/null	2011-04-01 09:36:24.228733637 +0600
+++ /home/user/.ssh/config	2011-04-01 10:37:16.000000000 +0600
@@ -0,0 +1,2 @@
+Host *
+ VisualHostkey yes
06:37:18
$chmod 600 /home/user/.ssh/config

06:37:43
#exit
exit
Connection to 192.168.15.1 closed.
06:40:09
$ssh 192.168.15.1 date
user@192.168.15.1's password:
Permission denied, please try again.
user@192.168.15.1's password:
Fri Apr  1 10:37:11 ALMT 2011
06:40:33
$ssh root@192.168.15.1
root@192.168.15.1's password:
Last login: Fri Apr  1 10:06:22 2011 from linux2.unix.bas
l3-agent is already running: pid=3677; pidfile=/root/.lilalo/l3-agent.pid
06:43:08
$cat < /tmp/ggg

06:44:03
$cat /tmp/ggg
dfsdf
06:44:10
$cat < /tmp/ggg
iefj
06:46:17
$cat < /tmp/ggg

06:46:54
$ls -l /tmp/ggg
prw-rw-r-- 1 user user 0 Apr  1 10:44 /tmp/ggg
06:46:56
$echo fffff > /tmp/ggg
bash: /tmp/ggg: Interrupted system call
06:47:24
$cat > /tmp/ggg
sdfasf
asdfas
dfas
dfas
fas
asdfasdf
06:47:33
$cat < /tmp/ggg

06:47:35
$cat > /tmp/ggg

06:48:33
$less /etc/ssh/sshd_config
прошла 81 минута
/dev/pts/9
08:10:20
$ls
a_reports  bin          december  find.log  november  september
backups    cpumem.info  Desktop   mbox      october   typescript
08:10:22
$date
Fri Apr  1 12:10:24 ALMT 2011
08:10:24
$pstree
init─┬─acpid
     ├─atd
     ├─auditd─┬─audispd───{audispd}
     │        └─{auditd}
     ├─automount───4*[{automount}]
     ├─avahi-daemon───avahi-daemon
     ├─bonobo-activati───{bonobo-activati}
     ├─bt-applet
     ├─clock-applet
     ├─crond
...
     ├─smartd
     ├─sshd───sshd───script───script───bash
     ├─syslogd
     ├─trashapplet
     ├─udevd
     ├─watchdog/0
     ├─watchdog/1
     ├─wnck-applet
     ├─xfs
     └─yum-updatesd───yum-updatesd-he
/dev/pts/3
08:17:59
$su -
Password:
08:18:09
#cat
bios
bios
08:18:25
#cat >
bash: syntax error near unexpected token `newline'
08:18:31
#cat
bios;
bios;
08:18:45
#vim GRUB
08:24:32
#init 6

Статистика

Время первой команды журнала12:53:18 2011- 3-30
Время последней команды журнала08:24:32 2011- 4- 1
Количество командных строк в журнале65
Процент команд с ненулевым кодом завершения, % 6.15
Процент синтаксически неверно набранных команд, % 3.08
Суммарное время работы с терминалом *, час 1.21
Количество командных строк в единицу времени, команда/мин 0.90
Частота использования команд
kill16|================| 16.33%
cat10|==========| 10.20%
&7|=======| 7.14%
less7|=======| 7.14%
17|=======| 7.14%
find7|=======| 7.14%
ggg7|=======| 7.14%
ssh5|=====| 5.10%
2>4|====| 4.08%
trap4|====| 4.08%
date3|===| 3.06%
ifconfig2|==| 2.04%
vim2|==| 2.04%
ssh-keygen2|==| 2.04%
ls2|==| 2.04%
exit2|==| 2.04%
top1|=| 1.02%
chmod1|=| 1.02%
trap-21|=| 1.02%
rm1|=| 1.02%
echo1|=| 1.02%
wc1|=| 1.02%
who1|=| 1.02%
init1|=| 1.02%
hostname1|=| 1.02%
su1|=| 1.02%
pstree1|=| 1.02%
____
*) Интервалы неактивности длительностью 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$