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

Содержание

Журнал

Вторник (04/05/11)

/dev/pts/9
07:15:55
#ping 10.0.0.77
connect: Network is unreachable
07:16:06
#ping 192.168.16.16
PING 192.168.16.16 (192.168.16.16) 56(84) bytes of data.
64 bytes from 192.168.16.16: icmp_seq=1 ttl=64 time=0.446 ms
64 bytes from 192.168.16.16: icmp_seq=2 ttl=64 time=0.090 ms
64 bytes from 192.168.16.16: icmp_seq=3 ttl=64 time=0.091 ms
--- 192.168.16.16 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2000ms
rtt min/avg/max/mdev = 0.090/0.209/0.446/0.167 ms
07:18:17
#netstat -r
Kernel IP routing table
Destination     Gateway         Genmask         Flags   MSS Window  irtt Iface
192.168.17.0    *               255.255.255.0   U         0 0          0 eth0
192.168.16.0    *               255.255.255.0   U         0 0          0 eth0
192.168.15.0    *               255.255.255.0   U         0 0          0 eth0
default         linux253.unix.b 0.0.0.0         UG        0 0          0 eth0
прошло 45 минут
08:04:03
#netstat -rn
Kernel IP routing table
Destination     Gateway         Genmask         Flags   MSS Window  irtt Iface
192.168.17.0    0.0.0.0         255.255.255.0   U         0 0          0 eth0
192.168.16.0    0.0.0.0         255.255.255.0   U         0 0          0 eth0
192.168.15.0    0.0.0.0         255.255.255.0   U         0 0          0 eth0
0.0.0.0         192.168.15.253  0.0.0.0         UG        0 0          0 eth0
08:04:07
#strace route
execve("/sbin/route", ["route"], [/* 39 vars */]) = 0
brk(0)                                  = 0x8cd9000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2b4186472000
uname({sys="Linux", node="linux2.unix.bas", ...}) = 0
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY)      = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=73513, ...}) = 0
mmap(NULL, 73513, PROT_READ, MAP_PRIVATE, 3, 0) = 0x2b4186473000
close(3)                                = 0
open("/lib64/libselinux.so.1", O_RDONLY) = 3
...
poll([{fd=4, events=POLLOUT}], 1, 0)    = 1 ([{fd=4, revents=POLLOUT}])
sendto(4, "\224g\1\0\0\1\0\0\0\0\0\0\003253\00215\003168\003192\7in-a"..., 45, MSG_NOSIGNAL, NULL, 0) = 45
poll([{fd=4, events=POLLIN}], 1, 5000)  = 0 (Timeout)
close(4)                                = 0
write(1, "default         192.168.15.253  "..., 77default         192.168.15.253  0.0.0.0         UG    0      0        0 eth0
) = 77
read(3, "", 4096)                       = 0
close(3)                                = 0
munmap(0x2b4189a5b000, 4096)            = 0
exit_group(0)                           = ?
08:07:39
#strace ls
execve("/bin/ls", ["ls"], [/* 39 vars */]) = 0
brk(0)                                  = 0x13b6d000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2b4896a34000
uname({sys="Linux", node="linux2.unix.bas", ...}) = 0
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY)      = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=73513, ...}) = 0
mmap(NULL, 73513, PROT_READ, MAP_PRIVATE, 3, 0) = 0x2b4896a35000
close(3)                                = 0
open("/lib64/librt.so.1", O_RDONLY)     = 3
...
)               = 9
write(1, "t\n", 2t
)                      = 2
write(1, "Tue Mar 29 17:50:26 ALMT 2011\n", 30Tue Mar 29 17:50:26 ALMT 2011
) = 30
write(1, "xgu.ru\n", 7xgu.ru
)                 = 7
close(1)                                = 0
munmap(0x2b489a025000, 4096)            = 0
exit_group(0)                           = ?
08:07:57
#strace ping 192.168.15.1
execve("/bin/ping", ["ping", "192.168.15.1"], [/* 39 vars */]) = 0
brk(0)                                  = 0x2b1e781ed000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2b1e6a0f2000
uname({sys="Linux", node="linux2.unix.bas", ...}) = 0
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY)      = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=73513, ...}) = 0
mmap(NULL, 73513, PROT_READ, MAP_PRIVATE, 3, 0) = 0x2b1e6a0f3000
close(3)                                = 0
open("/lib64/libresolv.so.2", O_RDONLY) = 3
...
sendmsg(3, {msg_name(16)={sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("192.168.15.1")}, msg_iov(1)=[{"\10\0\fm\301,\0$\354\261\232M\0\0\0\0\334o\10\0\0\0\0\0\20\21\22\23\24\25\26\27"..., 64}], msg_controllen=0, msg_flags=0}, MSG_CONFIRM) = 64
recvmsg(3, {msg_name(16)={sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("192.168.15.1")}, msg_iov(1)=[{"E\0\0TL\336\0\0@\1\216w\300\250\17\1\300\250\17\2\0\0\24m\301,\0$\354\261\232M"..., 192}], msg_controllen=32, {cmsg_len=32, cmsg_level=SOL_SOCKET, cmsg_type=0x1d /* SCM_??? */, ...}, msg_flags=0}, 0) = 84
write(1, "64 bytes from 192.168.15.1: icmp"..., 6164 bytes from 192.168.15.1: icmp_seq=36 ttl=64 time=0.230 ms
) = 61
recvmsg(3, 0x7fff44f23ee0, 0)           = -1 EAGAIN (Resource temporarily unavailable)
sendmsg(3, {msg_name(16)={sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("192.168.15.1")}, msg_iov(1)=[{"\10\0\23h\301,\0%\355\261\232M\0\0\0\0\324s\10\0\0\0\0\0\20\21\22\23\24\25\26\27"..., 64}], msg_controllen=0, msg_flags=0}, MSG_CONFIRM) = 64
recvmsg(3, {msg_name(16)={sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("192.168.15.1")}, msg_iov(1)=[{"E\0\0TL\337\0\0@\1\216v\300\250\17\1\300\250\17\2\0\0\33h\301,\0%\355\261\232M"..., 192}], msg_controllen=32, {cmsg_len=32, cmsg_level=SOL_SOCKET, cmsg_type=0x1d /* SCM_??? */, ...}, msg_flags=0}, 0) = 84
write(1, "64 bytes from 192.168.15.1: icmp"..., 6164 bytes from 192.168.15.1: icmp_seq=37 ttl=64 time=0.236 ms
) = 61
recvmsg(3, 0x7fff44f23ee0, 0)           = -1 EINTR (Interrupted system call)
08:08:45
#strace route add
execve("/sbin/route", ["route", "add"], [/* 39 vars */]) = 0
brk(0)                                  = 0x1706c000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2b62256e2000
uname({sys="Linux", node="linux2.unix.bas", ...}) = 0
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY)      = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=73513, ...}) = 0
mmap(NULL, 73513, PROT_READ, MAP_PRIVATE, 3, 0) = 0x2b62256e3000
close(3)                                = 0
open("/lib64/libselinux.so.1", O_RDONLY) = 3
...
) = 76
write(2, "                              [n"..., 72                              [netmask N] [mss Mss] [window W] [irtt I]
) = 72
write(2, "                              [m"..., 65                              [mod] [dyn] [reinstate] [[dev] If]
) = 65
write(2, "       inet_route [-vF] add {-ho"..., 75       inet_route [-vF] add {-host|-net} Target[/prefix] [metric M] reject
) = 75
write(2, "       inet_route [-FC] flush   "..., 49       inet_route [-FC] flush      NOT supported
) = 49
exit_group(4)                           = ?
08:09:36
#host mail.ru
mail.ru has address 94.100.191.201
mail.ru has address 94.100.191.202
mail.ru has address 94.100.191.203
mail.ru has address 94.100.191.204
mail.ru mail is handled by 10 mxs.mail.ru.
прошло 29 минут
08:39:27
#[root@linux2:~]# dig mail.ru mx
bash: [root@linux2:~]#: command not found
08:40:41
#dig mail.ru mx
; <<>> DiG 9.3.6-P1-RedHat-9.3.6-4.P1.el5_4.2 <<>> mail.ru mx
;; global options:  printcmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 30863
;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 6, ADDITIONAL: 1
;; QUESTION SECTION:
;mail.ru.                       IN      MX
;; ANSWER SECTION:
mail.ru.                516     IN      MX      10 mxs.mail.ru.
;; AUTHORITY SECTION:
...
mail.ru.                516     IN      NS      ns5.mail.ru.
mail.ru.                516     IN      NS      ns4.mail.ru.
mail.ru.                516     IN      NS      ns3.mail.ru.
mail.ru.                516     IN      NS      ns1.mail.ru.
;; ADDITIONAL SECTION:
mxs.mail.ru.            3516    IN      A       94.100.176.20
;; Query time: 0 msec
;; SERVER: 192.168.15.253#53(192.168.15.253)
;; WHEN: Tue Apr  5 12:40:51 2011
;; MSG SIZE  rcvd: 168
08:40:51
#dig mail.ru a
; <<>> DiG 9.3.6-P1-RedHat-9.3.6-4.P1.el5_4.2 <<>> mail.ru a
;; global options:  printcmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 16130
;; flags: qr rd ra; QUERY: 1, ANSWER: 4, AUTHORITY: 6, ADDITIONAL: 0
;; QUESTION SECTION:
;mail.ru.                       IN      A
;; ANSWER SECTION:
mail.ru.                60      IN      A       94.100.191.204
mail.ru.                60      IN      A       94.100.191.201
...
mail.ru.                513     IN      NS      ns4.mail.ru.
mail.ru.                513     IN      NS      ns5.mail.ru.
mail.ru.                513     IN      NS      ns3.mail.ru.
mail.ru.                513     IN      NS      ns.mail.ru.
mail.ru.                513     IN      NS      ns1.mail.ru.
mail.ru.                513     IN      NS      ns2.mail.ru.
;; Query time: 85 msec
;; SERVER: 192.168.15.253#53(192.168.15.253)
;; WHEN: Tue Apr  5 12:40:54 2011
;; MSG SIZE  rcvd: 196
08:40:54
#dig mail.ru a
; <<>> DiG 9.3.6-P1-RedHat-9.3.6-4.P1.el5_4.2 <<>> mail.ru a
;; global options:  printcmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 11940
;; flags: qr rd ra; QUERY: 1, ANSWER: 4, AUTHORITY: 6, ADDITIONAL: 0
;; QUESTION SECTION:
;mail.ru.                       IN      A
;; ANSWER SECTION:
mail.ru.                16      IN      A       94.100.191.203
mail.ru.                16      IN      A       94.100.191.204
...
mail.ru.                469     IN      NS      ns.mail.ru.
mail.ru.                469     IN      NS      ns2.mail.ru.
mail.ru.                469     IN      NS      ns1.mail.ru.
mail.ru.                469     IN      NS      ns5.mail.ru.
mail.ru.                469     IN      NS      ns3.mail.ru.
mail.ru.                469     IN      NS      ns4.mail.ru.
;; Query time: 1 msec
;; SERVER: 192.168.15.253#53(192.168.15.253)
;; WHEN: Tue Apr  5 12:41:38 2011
;; MSG SIZE  rcvd: 196
08:41:38
#dig mail.ru a +short
94.100.191.202
94.100.191.203
94.100.191.204
94.100.191.201
08:41:46
#whoin chub.in
bash: whoin: command not found
прошло 119 минут
10:41:32
#whois chub.in
[Querying whois.inregistry.in]
[whois.inregistry.in]
Access to .IN WHOIS information is provided to assist persons in
determining the contents of a domain name registration record in the
.IN registry database. The data in this record is provided by
.IN Registry for informational purposes only, and .IN does not
guarantee its accuracy.  This service is intended only for query-based
access. You agree that you will use this data only for lawful purposes
and that, under no circumstances will you use this data to: (a) allow,
enable, or otherwise support the transmission by e-mail, telephone, or
...
Name Server:
Name Server:
Name Server:
Name Server:
Name Server:
Name Server:
Name Server:
Name Server:
Name Server:
Name Server:
10:41:39
#cat /proc/sys/kernel/ostype
Linux
прошло 11 минут
10:52:45
#cat /proc/sys/kernel/threads-max
73728
10:52:54
#yum list xen
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
 * addons: mirror.space.kz
 * base: mirror.space.kz
 * extras: mirror.space.kz
 * rpmforge: fr2.rpmfind.net
 * updates: mirror.space.kz
Installed Packages
xen.x86_64                      3.0.3-105.el5_5.5                      installed
10:59:04
#init 6

Файлы

  • /proc/sys/kernel/ostype
  • /proc/sys/kernel/threads-max
  • /proc/sys/kernel/ostype
    >
    Linux
    
    /proc/sys/kernel/threads-max
    >
    73728
    

    Статистика

    Время первой команды журнала07:15:55 2011- 4- 5
    Время последней команды журнала10:59:04 2011- 4- 5
    Количество командных строк в журнале20
    Процент команд с ненулевым кодом завершения, % 5.00
    Процент синтаксически неверно набранных команд, %10.00
    Суммарное время работы с терминалом *, час 0.96
    Количество командных строк в единицу времени, команда/мин 0.35
    Частота использования команд
    dig4|====================| 20.00%
    strace4|====================| 20.00%
    netstat2|==========| 10.00%
    ping2|==========| 10.00%
    cat2|==========| 10.00%
    [root@linux2:~]#1|=====| 5.00%
    yum1|=====| 5.00%
    init1|=====| 5.00%
    host1|=====| 5.00%
    whoin1|=====| 5.00%
    whois1|=====| 5.00%
    ____
    *) Интервалы неактивности длительностью 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$