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

Содержание

Журнал

Вторник (03/13/07)

/dev/pts/9
15:10:05
#vim /etc/xinetd.d
15:10:58
#vim /etc/xinetd.d
15:11:11
#telnet 127.0.0.1 chargen
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
15:15:18
#vim /etc/ho
15:15:18
#vim /etc/ho
15:15:18
#vim /etc/hosts.allow
13c13
< #
---
> ALL : ALL#
15:17:14
#telnet 127.0.0.1 chargen
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
15:17:17
#telnet 127.0.0.1
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:17:21
#vim /etc/hosts.allow
13c13
< ALL : ALL#
---
> ALL : ALL
15:17:56
#telnet 127.0.0.1
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
15:17:57
#telnet 127.0.0.1 chrgen
       various  modes.   If you believe that it is doing the wrong thing under
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
telnet: could not resolve 127.0.0.1/chrgen: Servname not supported for ai_socktype
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:18:07
#telnet 127.0.0.1 chargen
       various  modes.   If you believe that it is doing the wrong thing under
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
telnet: could not resolve 127.0.0.1/chargenrgen: Servname not supported for ai_socktype
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:18:19
#telnet 127.0.0.1 chargen
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:18:48
#vim /etc/hosts.allow
13c13
< ALL : ALL
---
> ALL:ALL
15:19:13
#telnet 127.0.0.1 chargen
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
15:19:15
#vim /etc/x
15:19:15
#vim /etc/xinetd.conf
15:20:24
#telnet 127.0.0.1 25
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
220 linux2.net.nt ESMTP Exim 4.63 Tue, 13 Mar 2007 15:20:32 +0200
q
500 unrecognized command
q
500 unrecognized command
}
exit
Connection closed by foreign host.
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:20:55
#tail /var/l
lib/        local/      lock/       log/        lost+found/
15:20:55
#tail /var/log/daemon.log
[root@linux1:~]#
Mar 13 11:32:42 linux2 xinetd[7113]: removing daytime
Mar 13 11:32:42 linux2 xinetd[7113]: removing daytime
Mar 13 11:32:42 linux2 xinetd[7113]: removing discard
Mar 13 11:32:42 linux2 xinetd[7113]: removing discard
Mar 13 11:32:42 linux2 xinetd[7113]: removing echo
Mar 13 11:32:42 linux2 xinetd[7113]: removing echo
Mar 13 11:32:42 linux2 xinetd[7113]: removing time
Mar 13 11:32:42 linux2 xinetd[7113]: removing time
Mar 13 11:32:42 linux2 xinetd[7113]: xinetd Version 2.3.14 started with libwrap loadavg options compiled in.
Mar 13 11:32:42 linux2 xinetd[7113]: Started working: 0 available services
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:22:01
#vim /etc/xinetd.d/chargen
9c9
< 	disable		= yes
---
> 	disable		= no
21c21
< 	disable		= yes
---
> 	disable		= no
15:23:29
#kilall -1 xinetd
       various  modes.   If you believe that it is doing the wrong thing under
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
bash: kilall: command not found
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:23:53
#killall -1 xinetd
       Efforts have been made to have netcat "do the right thing" in  all  its
       various  modes.   If you believe that it is doing the wrong thing under
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:24:04
#tail /var/log/daemon.log
[root@linux1:~]#
Mar 13 15:24:03 linux2 xinetd[7113]: removing daytime
Mar 13 15:24:03 linux2 xinetd[7113]: removing daytime
Mar 13 15:24:03 linux2 xinetd[7113]: removing discard
Mar 13 15:24:03 linux2 xinetd[7113]: removing discard
Mar 13 15:24:03 linux2 xinetd[7113]: removing echo
Mar 13 15:24:03 linux2 xinetd[7113]: removing echo
Mar 13 15:24:03 linux2 xinetd[7113]: removing time
Mar 13 15:24:03 linux2 xinetd[7113]: removing time
Mar 13 15:24:03 linux2 xinetd[7113]: Swapping defaults
Mar 13 15:24:03 linux2 xinetd[7113]: Reconfigured: new=2 old=0 dropped=0 (services)
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:24:26
#telnet 127.0.0.1 chargen
Z[\]^_`abcdefghijklmnopqrstuvwxyz{|}!"#$%&'()*+,-./0123456789:;<=>?@ABCD
[\]^_`abcdefghijklmnopqrstuvwxyz{|}!"#$%&'()*+,-./0123456789:;<=>?@ABCDE
\]^_`abcdefghijklmnopqrstuvwxyz{|}!"#$%&'()*+,-./0123456789:;<=>?@ABCDEF
]^_`abcdefghijklmnopqrstuvwxyz{|}!"#$%&'()*+,-./0123456789:;<=>?@ABCDEFG
^_`abcdefghijklmnopqrstuvwxyz{|}!"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGH
_`abcdefghijklmnopqrstuvwxyz{|}!"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHI
q
^]
telnet> q
Connection closed.
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:24:51
#vim /etc/xinetd.d/chargen
21c21
< 	disable		= no
---
> 	disable		= yes
15:27:43
#killall -1 xinetd
       Efforts have been made to have netcat "do the right thing" in  all  its
       various  modes.   If you believe that it is doing the wrong thing under
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:27:49
#vim /etc/xinetd.d/chargen
15:28:46
#vim /etc/ser
15:28:57
#vim /etc/services
В сервисес прописан сервис чарген на порту 19 vim /etc/services
15:29:46
#ps aux | grep cha
root     14490  0.8  0.0   3196   732 ?        S    15:34   0:00 (xinetd service)  chargen -stream localhost
root     14506  0.0  0.0   3744   764 pts/10   R+   15:34   0:00 grep cha
15:34:42
#ps aux | grep cha
root     14520  0.0  0.0   3740   760 pts/10   R+   15:34   0:00 grep cha
15:34:55
#netstat -lnp -A inet
tcp        0      0 0.0.0.0:19              0.0.0.0:*               LISTEN     7113/xinetd
tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN     2490/cupsd
tcp        0      0 0.0.0.0:3128            0.0.0.0:*               LISTEN     2744/(squid)
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN     2628/exim4
udp        0      0 0.0.0.0:32768           0.0.0.0:*                          2570/avahi-daemon:
udp        0      0 0.0.0.0:32769           0.0.0.0:*                          2721/rpc.statd
udp        0      0 0.0.0.0:32770           0.0.0.0:*                          2744/(squid)
udp        0      0 0.0.0.0:777             0.0.0.0:*                          2721/rpc.statd
udp        0      0 0.0.0.0:3130            0.0.0.0:*                          2744/(squid)
udp        0      0 0.0.0.0:5353            0.0.0.0:*                          2570/avahi-daemon:
udp        0      0 0.0.0.0:631             0.0.0.0:*                          2490/cupsd
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)
15:35:57
#netstat -lnp -A inet | grep xinetd
       various  modes.   If you believe that it is doing the wrong thing under
       whatever circumstances, please notify me and tell me how you  think  it
       should  behave.   If  netcat  is not able to do some task you think up,
       minor tweaks to the code will probably fix that.  It provides  a  basic
       and  easily-modified  template  for writing other network applications,
       and I certainly encourage people to make custom mods and  send  in  any
       improvements  they  make  to  it.  Continued feedback from the Internet
[root@linux1:~]#
[root@linux1:~]#
[root@linux1:~]#
tcp        0      0 0.0.0.0:19              0.0.0.0:*               LISTEN     7113/xinetd
netscsid                             nroff
netstat                              nslookup
network-admin                        nstat
newaliases                           nsupdate
[root@linux1:~]# man nc
Переформатирование nc(1), подождите...
NC(1)                                                                    NC(1)

Статистика

Время первой команды журнала15:10:05 2007- 3-13
Время последней команды журнала15:35:57 2007- 3-13
Количество командных строк в журнале34
Процент команд с ненулевым кодом завершения, %41.18
Процент синтаксически неверно набранных команд, % 2.94
Суммарное время работы с терминалом *, час 0.43
Количество командных строк в единицу времени, команда/мин 1.31
Частота использования команд
vim14|====================================| 36.84%
telnet10|==========================| 26.32%
tail3|=======| 7.89%
grep3|=======| 7.89%
killall2|=====| 5.26%
ps2|=====| 5.26%
netstat2|=====| 5.26%
#^1|==| 2.63%
kilall1|==| 2.63%
____
*) Интервалы неактивности длительностью 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$