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

Содержание

Журнал

Среда (12/14/11)

/dev/pts/2
13:49:40
#ping 192.168.30.1
PING 192.168.30.1 (192.168.30.1) 56(84) bytes of data.
64 bytes from 192.168.30.1: icmp_req=1 ttl=62 time=5.48 ms
64 bytes from 192.168.30.1: icmp_req=2 ttl=62 time=6.30 ms
^C
--- 192.168.30.1 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 5.481/5.891/6.301/0.410 ms
13:50:27
#ping 192.168.30.126
PING 192.168.30.126 (192.168.30.126) 56(84) bytes of data.
From 192.168.30.126 icmp_seq=1 Packet filtered
From 192.168.30.126 icmp_seq=2 Packet filtered
From 192.168.30.126 icmp_seq=3 Packet filtered
From 192.168.30.126 icmp_seq=4 Packet filtered
From 192.168.30.126 icmp_seq=5 Packet filtered
From 192.168.30.126 icmp_seq=6 Packet filtered
From 192.168.30.126 icmp_seq=7 Packet filtered
From 192.168.30.126 icmp_seq=8 Packet filtered
From 192.168.30.126 icmp_seq=9 Packet filtered
From 192.168.30.126 icmp_seq=10 Packet filtered
From 192.168.30.126 icmp_seq=11 Packet filtered
From 192.168.30.126 icmp_seq=12 Packet filtered
From 192.168.30.126 icmp_seq=13 Packet filtered
From 192.168.30.126 icmp_seq=14 Packet filtered
From 192.168.30.126 icmp_seq=15 Packet filtered
From 192.168.30.126 icmp_seq=16 Packet filtered
^C
--- 192.168.30.126 ping statistics ---
16 packets transmitted, 0 received, +16 errors, 100% packet loss, time 15025ms
прошло 24 минуты
14:15:18
#ping 192.168.30.126
PING 192.168.30.126 (192.168.30.126) 56(84) bytes of data.
64 bytes from 192.168.30.126: icmp_req=1 ttl=64 time=13.6 ms
64 bytes from 192.168.30.126: icmp_req=2 ttl=64 time=1.53 ms
^C
--- 192.168.30.126 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 1.530/7.595/13.660/6.065 ms
14:19:58
#ping 192.168.30.1
PING 192.168.30.1 (192.168.30.1) 56(84) bytes of data.
64 bytes from 192.168.30.1: icmp_req=1 ttl=62 time=5.24 ms
64 bytes from 192.168.30.1: icmp_req=2 ttl=62 time=3.74 ms
64 bytes from 192.168.30.1: icmp_req=3 ttl=62 time=4.97 ms
^C
--- 192.168.30.1 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2003ms
rtt min/avg/max/mdev = 3.744/4.653/5.246/0.655 ms
прошло 14 минут
14:33:59
#ping 192.168.30.1
PING 192.168.30.1 (192.168.30.1) 56(84) bytes of data.
64 bytes from 192.168.30.1: icmp_req=1 ttl=62 time=4.93 ms
64 bytes from 192.168.30.1: icmp_req=2 ttl=62 time=10.1 ms
64 bytes from 192.168.30.1: icmp_req=3 ttl=62 time=4.62 ms
^C
--- 192.168.30.1 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2002ms
rtt min/avg/max/mdev = 4.629/6.579/10.175/2.547 ms
14:34:04
#ping ya.ru
PING ya.ru (87.250.250.203) 56(84) bytes of data.
64 bytes from www.yandex.ru (87.250.250.203): icmp_req=1 ttl=55 time=36.5 ms
64 bytes from www.yandex.ru (87.250.250.203): icmp_req=2 ttl=55 time=29.0 ms
64 bytes from www.yandex.ru (87.250.250.203): icmp_req=3 ttl=55 time=26.9 ms
64 bytes from www.yandex.ru (87.250.250.203): icmp_req=4 ttl=55 time=27.5 ms
64 bytes from www.yandex.ru (87.250.250.203): icmp_req=5 ttl=55 time=28.4 ms
^C
--- ya.ru ping statistics ---
5 packets transmitted, 5 received, 0% packet loss, time 4006ms
rtt min/avg/max/mdev = 26.917/29.699/36.568/3.514 ms
14:34:17
#ping ya.ru
PING ya.ru (87.250.250.3) 56(84) bytes of data.
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=1 ttl=55 time=26.8 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=2 ttl=55 time=31.5 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=3 ttl=55 time=171 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=4 ttl=55 time=27.8 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=5 ttl=55 time=28.2 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=6 ttl=55 time=28.2 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=7 ttl=55 time=26.6 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=8 ttl=55 time=27.4 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=9 ttl=55 time=27.8 ms
...
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=231 ttl=55 time=27.2 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=232 ttl=55 time=30.7 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=233 ttl=55 time=26.4 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=234 ttl=55 time=28.1 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=235 ttl=55 time=29.9 ms
64 bytes from www.yandex.ru (87.250.250.3): icmp_req=236 ttl=55 time=26.1 ms
^C
--- ya.ru ping statistics ---
236 packets transmitted, 236 received, 0% packet loss, time 235341ms
rtt min/avg/max/mdev = 26.129/29.283/171.938/9.687 ms
14:38:41
#iptables -L
Chain INPUT (policy ACCEPT)
target     prot opt source               destination
Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination
прошло 13 минут
14:51:51
#iptables -A INPUT -d 127.0.0.1 -p icmp -j DROP

14:52:54
#ping 127.0.0.1
PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.
^C
--- 127.0.0.1 ping statistics ---
3 packets transmitted, 0 received, 100% packet loss, time 2015ms
14:53:16
#iptables -L --line-numbers
Chain INPUT (policy ACCEPT)
num  target     prot opt source               destination
1    DROP       icmp --  anywhere             localhost.localdomain
Chain FORWARD (policy ACCEPT)
num  target     prot opt source               destination
Chain OUTPUT (policy ACCEPT)
num  target     prot opt source               destination
14:53:43
#iptables -D 1
iptables: Bad rule (does a matching rule exist in that chain?).
14:53:51
#iptables -D INPUT 1

14:55:23
#ping 127.0.0.1
PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.
64 bytes from 127.0.0.1: icmp_req=1 ttl=64 time=0.138 ms
64 bytes from 127.0.0.1: icmp_req=2 ttl=64 time=0.137 ms
^C
--- 127.0.0.1 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 999ms
rtt min/avg/max/mdev = 0.137/0.137/0.138/0.011 ms
14:55:25
#iptables -A INPUT --dport 22 -p tcp -j ALLOW
iptables v1.4.8: unknown option `--dport'
Try `iptables -h' or 'iptables --help' for more information.
/dev/pts/0
14:56:00
#man iptables
/dev/pts/2
14:57:06
#iptables -A INPUT -p tcp --dport 22 -j ACCEPT

15:02:56
#iptables -A INPUT -p tcp --syn -j DROP

15:03:51
#nmap localhost
Starting Nmap 5.00 ( http://nmap.org ) at 2011-12-14 16:04 EET
Interesting ports on localhost.localdomain (127.0.0.1):
Not shown: 998 filtered ports
PORT   STATE  SERVICE
22/tcp open   ssh
80/tcp closed http
Nmap done: 1 IP address (1 host up) scanned in 8.18 seconds
15:04:44
#iptables -F

15:07:08
#iptables -L
Chain INPUT (policy ACCEPT)
target     prot opt source               destination
Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination
прошло 22 минуты
/dev/pts/4
15:29:18
#w
 16:31:02 up 23:56,  3 users,  load average: 0,17, 0,16, 0,07
USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT
root     pts/0    192.168.30.65    Tue16    2:25   1.61s  0.31s script -f -c ba
root     pts/2    192.168.30.65    10:27   23:51   1.46s  0.53s script -f -c ba
root     pts/4    192.168.30.65    16:28    0.00s  1.16s  0.02s script -f -c ba

Статистика

Время первой команды журнала13:49:40 2011-12-14
Время последней команды журнала15:29:18 2011-12-14
Количество командных строк в журнале22
Процент команд с ненулевым кодом завершения, %18.18
Процент синтаксически неверно набранных команд, % 0.00
Суммарное время работы с терминалом *, час 1.66
Количество командных строк в единицу времени, команда/мин 0.22
Частота использования команд
iptables10|=============================================| 45.45%
ping9|========================================| 40.91%
man1|====| 4.55%
w1|====| 4.55%
nmap1|====| 4.55%
____
*) Интервалы неактивности длительностью 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$