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

Содержание

Журнал

Среда (09/20/06)

/dev/pts/0
16:25:50
#apt-get purge bind9
E: Неверная операция purge
16:26:05
#apt-get --purge remove bind9
Построение дерева зависимостей... Готово
Пакеты, которые будут УДАÐd9*
обновлено 0, установлено 0 новых пакетов, для удаления отмечено 1 пакетов, и 363 пакетов не обновлено.
Необходимо скачать 0Б архивов.
После распаковки объем занятого дискового пространства уменьшится на 725kB.
Хотите продолжить [Д/н]?
(Чтение базы данных... на данный момент установлено 86849 файлов и каталогов.)
Удаляется пакет bind9...
Stopping domain name service...:.
Удаляются файлы конфигурации пакета bind9...
dpkg: предупреждение -- при удалении пакета bind9 не пустой каталог /etc/bind не удалён.
--------------------------------------------------------------------------------
16:26:18
#ls /etc/bind/
db.17.168.192.in-addr.arpa  db.vova.linux.nt  slave
16:26:23
#rm /etc/bind/*
rm: невозможно удалить `/etc/bind/slave': Is a directory
16:26:27
#rm -rf /etc/bind/slave/
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
--------------------------------------------------------------------------------
16:26:31
#apt-get install bind9
Настраивается пакет libdns21 (9.3.2-P1-2) ...
Настраивается пакет libisccc0 (9.3.2-P1-2) ...
Настраивается пакет libisccfg1 (9.3.2-P1-2) ...
Настраивается пакет bind9 (9.3.2-P1-2) ...
wrote key file "/etc/bind/rndc.key"
Starting domain name service...: bind.
--------------------------------------------------------------------------------
16:27:42
#ls /etc/bind/
db.0    db.255    db.local  named.conf        named.conf.options  zones.rfc1918
db.127  db.empty  db.root   named.conf.local  rndc.key
16:27:45
#vi /etc/bind/named.conf
16:28:20
#vi /etc/bind/named.conf.
16:28:20
#vi /etc/bind/named.conf.
16:28:20
#vi /etc/bind/named.conf.options
17,19c17,19
< 	// forwarders {
< 	// 	0.0.0.0;
< 	// };
---
> 	forwarders {
> 	 	192.168.15.254;
> 	};
16:32:19
#/etc/init.d/bind9 restart
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
Stopping domain name service...: bind.
Starting domain name service...: bind.
--------------------------------------------------------------------------------
16:32:28
#tail /var/log/daemon.log
Sep 20 16:32:27 linux2 named[10812]: loading configuration from '/etc/bind/named.conf'
Sep 20 16:32:28 linux2 named[10812]: no IPv6 interfaces found
Sep 20 16:32:28 linux2 named[10812]: listening on IPv4 interface lo, 127.0.0.1#53
Sep 20 16:32:28 linux2 named[10812]: listening on IPv4 interface eth0, 192.168.15.2#53
Sep 20 16:32:28 linux2 named[10812]: command channel listening on 127.0.0.1#953
Sep 20 16:32:28 linux2 named[10812]: zone 0.in-addr.arpa/IN: loaded serial 1
Sep 20 16:32:28 linux2 named[10812]: zone 127.in-addr.arpa/IN: loaded serial 1
Sep 20 16:32:28 linux2 named[10812]: zone 255.in-addr.arpa/IN: loaded serial 1
Sep 20 16:32:28 linux2 named[10812]: zone localhost/IN: loaded serial 1
Sep 20 16:32:28 linux2 named[10812]: running
16:32:40
#netstat -ln | grep :53
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
tcp        0      0 192.168.15.2:53         0.0.0.0:*               LISTEN
tcp        0      0 127.0.0.1:53            0.0.0.0:*               LISTEN
udp        0      0 192.168.15.2:53         0.0.0.0:*
udp        0      0 127.0.0.1:53            0.0.0.0:*
--------------------------------------------------------------------------------
16:32:51
#dig @127.0.0.1 mail.ru ns
mail.ru.                4419    IN      NS      ns5.mail.ru.
;; ADDITIONAL SECTION:
ns.mail.ru.             17705   IN      A       194.67.23.130
ns5.mail.ru.            17724   IN      A       194.67.23.232
;; Query time: 148 msec
;; SERVER: 127.0.0.1#53(127.0.0.1)
;; WHEN: Wed Sep 20 16:33:11 2006
;; MSG SIZE  rcvd: 164
--------------------------------------------------------------------------------
16:33:11
#less /etc/bind/named.conf
16:37:50
#vi /etc/bind/named.conf.options
16:38:29
#dig @127.0.0.1 mail.ru n
;; QUESTION SECTION:
;n.                             IN      A
;; AUTHORITY SECTION:
.                       10800   IN      SOA     a.root-servers.net. nstld.verisign-grs.com. 2006091901 1800 900 604800 86400
;; Query time: 220 msec
;; SERVER: 127.0.0.1#53(127.0.0.1)
;; WHEN: Wed Sep 20 16:43:22 2006
;; MSG SIZE  rcvd: 94
--------------------------------------------------------------------------------
16:43:22
#rndc
  notrace       Set debugging level to 0.
  flush         Flushes all of the server's caches.
  flush [view]  Flushes the server's cache for a view.
  flushname name [view]
                Flush the given name from the server's cache(s)
  status        Display status of the server.
  recursing     Dump the queries that are currently recursing (named.recursing)
  *restart      Restart the server.
* == not yet implemented
Version: 9.3.2-P1
--------------------------------------------------------------------------------
16:43:38
#rndc dumdb
rndc: 'dumdb' failed: unknown command
16:43:43
#rndc dumpdb
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
--------------------------------------------------------------------------------
16:43:47
#find /var -name named_dump.db
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
/var/cache/bind/named_dump.db
--------------------------------------------------------------------------------
16:44:08
#less /var/cache/bind/named_dump.db
16:44:37
#grep -v '^;' /var/cache/bind/named_dump.db | less
16:45:03
#rndc dumpdb
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
--------------------------------------------------------------------------------
16:45:09
#rndc
Usage: rndc [-c config] [-s server] [-p port]
        [-k key-file ] [-y key] [-V] command
command is one of the following:
  reload        Reload configuration file and zones.
  reload zone [class [view]]
                Reload a single zone.
  refresh zone [class [view]]
                Schedule immediate maintenance for a zone.
  retransfer zone [class [view]]
                Retransfer a single zone without checking serial number.
...
  notrace       Set debugging level to 0.
  flush         Flushes all of the server's caches.
  flush [view]  Flushes the server's cache for a view.
  flushname name [view]
                Flush the given name from the server's cache(s)
  status        Display status of the server.
  recursing     Dump the queries that are currently recursing (named.recursing)
  *restart      Restart the server.
* == not yet implemented
Version: 9.3.2-P1
16:45:11
#rndc stats
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
--------------------------------------------------------------------------------
16:46:29
#ls /var/cache/bind/
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
named_dump.db  named.stats
--------------------------------------------------------------------------------
16:46:38
#less /var/cache/bind/named.stats
16:47:45
#vi /etc/bind/named.conf.local
16:48:08
#vi /etc/bind/named.conf.options
16:49:18
#/etc/init.d/bind9 restart
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
Stopping domain name service...: bind.
Starting domain name service...: bind.
--------------------------------------------------------------------------------
16:49:27
#tail /var/log/daemon.log
Sep 20 16:49:27 linux2 named[11036]: loading configuration from '/etc/bind/named.conf'
Sep 20 16:49:27 linux2 named[11036]: no IPv6 interfaces found
Sep 20 16:49:27 linux2 named[11036]: listening on IPv4 interface lo, 127.0.0.1#53
Sep 20 16:49:27 linux2 named[11036]: listening on IPv4 interface eth0, 192.168.15.2#53
Sep 20 16:49:27 linux2 named[11036]: command channel listening on 127.0.0.1#953
Sep 20 16:49:27 linux2 named[11036]: zone 0.in-addr.arpa/IN: loaded serial 1
Sep 20 16:49:27 linux2 named[11036]: zone 127.in-addr.arpa/IN: loaded serial 1
Sep 20 16:49:27 linux2 named[11036]: zone 255.in-addr.arpa/IN: loaded serial 1
Sep 20 16:49:27 linux2 named[11036]: zone localhost/IN: loaded serial 1
Sep 20 16:49:27 linux2 named[11036]: running
16:49:39
#vi /etc/bind/named.conf.options
16:50:15
#vi /etc/bind/named.conf.options
16:52:52
#cp /etc/bind/named.conf /tmp
NOTICE: The expiration date displayed in this record is the date the
registrar's sponsorship of the domain name registration in the registry is
currently set to expire. This date does not necessarily reflect the expiration
date of the domain name registrant's agreement with the sponsoring
registrar.  Users may consult the sponsoring registrar's Whois database to
view the registrar's reported date of expiration for this registration.
TERMS OF USE: You are not authorized to access or query our Whois
database through the use of electronic processes that are high-volume and
automated except as reasonably necessary to register domain names or
--------------------------------------------------------------------------------
16:54:30
#vi /tmp/named.conf
39a40,51
> 
> zone "sco.unix.nt" {
> 	type master;
> 	file "/etc/bind/db.sco.unix.nt";
> 	allow-query {
> 		0.0.0.0/0;
> 	};
> 	allow-transfer {
> 		127.0.0.1;
> 	};
> };
> 

Статистика

Время первой команды журнала16:25:50 2006- 9-20
Время последней команды журнала16:54:30 2006- 9-20
Количество командных строк в журнале37
Процент команд с ненулевым кодом завершения, %13.51
Процент синтаксически неверно набранных команд, % 0.00
Суммарное время работы с терминалом *, час 0.48
Количество командных строк в единицу времени, команда/мин 1.29
Частота использования команд
vi10|=========================| 25.00%
rndc6|===============| 15.00%
less4|==========| 10.00%
apt-get3|=======| 7.50%
ls3|=======| 7.50%
dig2|=====| 5.00%
tail2|=====| 5.00%
/etc/init.d/bind92|=====| 5.00%
grep2|=====| 5.00%
rm2|=====| 5.00%
'1|==| 2.50%
netstat1|==| 2.50%
find1|==| 2.50%
cp1|==| 2.50%
____
*) Интервалы неактивности длительностью 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$