/l3/users/viktor-dremkov/redhat/linux4.unix.bas/root :1 :2 :3 :4 :5 :6 :7 :8 :9 :10 :11 :12 :13 :14 :15 :16 :17 :18 :19 :20 :21 :22 :23 :24 :25 :26 :27 :28 :29 :30 :31 :32 :33 :34 :35 :36 :37 :38 :39 :40 :41 :42 :43 :44 |
|
#ls
chargen-dgram discard-dgram eklogin krb5-telnet telnet chargen-stream discard-stream ekrb5-telnet kshell time-dgram daytime-dgram echo-dgram gssftp rsync time-stream daytime-stream echo-stream klogin tcpmux-server |
#less /etc/services
|
#cp telnet myprg
|
#vi myprg
--- /tmp/l3-saved-8839.13474.24845 2010-06-09 12:24:18.000000000 +0600 +++ myprg 2010-06-09 12:24:38.000000000 +0600 @@ -1,13 +1,13 @@ # default: on # description: The telnet server serves telnet sessions; it uses \ # unencrypted username/password pairs for authentication. -service telnet +service finger { disable = no flags = REUSE socket_type = stream wait = no user = root - server = /usr/sbin/in.telnetd + server = /usr/bin/bc log_on_failure += USERID } |
#pkill -1 inetd
|
#nc 127.0.0.1 79
2+2 2+2 |
#which bc
/usr/bin/bc |
#vi myprg
--- /tmp/l3-saved-8839.9840.14853 2010-06-09 12:25:06.000000000 +0600 +++ myprg 2010-06-09 12:25:14.000000000 +0600 @@ -8,6 +8,6 @@ socket_type = stream wait = no user = root - server = /usr/bin/bc + server = /bin/bash log_on_failure += USERID } |
#pkill -1 inetd
|
#nc 127.0.0.1 79
ls / # |
#less /var/log/messages
|
#vi myprg
--- /tmp/l3-saved-8839.16661.27724 2010-06-09 12:25:45.000000000 +0600 +++ myprg 2010-06-09 12:25:56.000000000 +0600 @@ -4,7 +4,7 @@ service finger { disable = no - flags = REUSE + #flags = REUSE socket_type = stream wait = no user = root |
#nc 127.0.0.1 79
f f ff f ff fffffff fffff |
#netstat -lnp | grep 79
tcp 0 0 0.0.0.0:79 0.0.0.0:* LISTEN 3895/xinetd |
#vi myprg
--- /tmp/l3-saved-8839.3057.17331 2010-06-09 12:26:48.000000000 +0600 +++ myprg 2010-06-09 12:27:00.000000000 +0600 @@ -9,5 +9,6 @@ wait = no user = root server = /bin/bash +server_args = /bin/bash -i log_on_failure += USERID } |
#pkill -1 inetd
|
#nc 127.0.0.1 79
f f f f f |
#ls /var/log/
acpid btmp gdm messages.1 secure xen anaconda.log conman httpd pm secure.1 Xorg.0.log anaconda.syslog conman.old lastlog ppp spooler Xorg.0.log.old anaconda.xlog cron libvirt prelink spooler.1 Xorg.2.log audit cron.1 mail rpmpkgs squid yum.log boot.log cups maillog rpmpkgs.1 tallylog boot.log.1 dmesg maillog.1 samba vbox brcm-iscsi.log faillog messages scrollkeeper.log wtmp |
#ls
chargen-dgram discard-dgram eklogin krb5-telnet tcpmux-server chargen-stream discard-stream ekrb5-telnet kshell telnet daytime-dgram echo-dgram gssftp myprg time-dgram daytime-stream echo-stream klogin rsync time-stream |
#cat myprg
# default: on # description: The telnet server serves telnet sessions; it uses \ # unencrypted username/password pairs for authentication. service finger { disable = no #flags = REUSE socket_type = stream wait = no user = root server = /bin/bash server_args = /bin/bash -i log_on_failure += USERID } |
#grep xinet /var/log/*
/var/log/messages:Jun 8 18:51:12 linux4 xinetd[3830]: xinetd Version 2.3.14 started with libwrap loadavg labeled-networking options compiled in. /var/log/messages:Jun 8 18:51:12 linux4 xinetd[3830]: Started working: 0 available services /var/log/messages:Jun 8 20:52:34 linux4 xinetd[3830]: Exiting... /var/log/messages:Jun 8 20:54:25 linux4 xinetd[3899]: xinetd Version 2.3.14 started with libwrap loadavg labeled-networking options compiled in. /var/log/messages:Jun 8 20:54:25 linux4 xinetd[3899]: Started working: 0 available services /var/log/messages:Jun 8 21:33:48 linux4 xinetd[3899]: Exiting... /var/log/messages:Jun 9 10:26:24 linux4 xinetd[3895]: xinetd Version 2.3.14 started with libwrap loadavg labeled-networking options compiled in. /var/log/messages:Jun 9 10:26:24 linux4 xinetd[3895]: Started working: 0 available services /var/log/messages:Jun 9 10:59:36 linux4 xinetd[3895]: Starting reconfiguration /var/log/messages:Jun 9 10:59:36 linux4 xinetd[3895]: Swapping defaults ... /var/log/messages:Jun 9 12:25:17 linux4 xinetd[3895]: readjusting service telnet /var/log/messages:Jun 9 12:25:17 linux4 xinetd[3895]: readjusting service finger /var/log/messages:Jun 9 12:25:17 linux4 xinetd[3895]: Reconfigured: new=0 old=3 dropped=0 (services) /var/log/messages:Jun 9 12:27:03 linux4 xinetd[3895]: Starting reconfiguration /var/log/messages:Jun 9 12:27:03 linux4 xinetd[3895]: Swapping defaults /var/log/messages:Jun 9 12:27:03 linux4 xinetd[3895]: readjusting service echo-stream /var/log/messages:Jun 9 12:27:03 linux4 xinetd[3895]: readjusting service telnet /var/log/messages:Jun 9 12:27:03 linux4 xinetd[3895]: readjusting service finger /var/log/messages:Jun 9 12:27:03 linux4 xinetd[3895]: Reconfigured: new=0 old=3 dropped=0 (services) /var/log/rpmpkgs:xinetd-2.3.14-10.el5.i386.rpm |
#grep xinet /var/log/* | less
|
#less /var/log/messages
|
#telnet 127.0.0.1 79
Trying 127.0.0.1... ls |
#telnet 127.0.0.1 7
Trying 127.0.0.1... |
#telnet 127.0.0.1 9
Trying 127.0.0.1... |
#netstat -lnp | less
|
#ifconfig lo up
|
#telnet 127.0.0.1 79
Trying 127.0.0.1... Connected to localhost.localdomain (127.0.0.1). Escape character is '^]'. /bin/bash: /bin/bash: cannot execute binary file Connection closed by foreign host. |
#vi myprg
--- /tmp/l3-saved-8839.24173.3849 2010-06-09 12:31:02.000000000 +0600 +++ myprg 2010-06-09 12:31:19.000000000 +0600 @@ -9,6 +9,6 @@ wait = no user = root server = /bin/bash -server_args = /bin/bash -i + server_args = -i log_on_failure += USERID } |
#pkill -1 xinetd
You have new mail in /var/spool/mail/root |
#telnet 127.0.0.1 79
Trying 127.0.0.1... Connected to localhost.localdomain (127.0.0.1). Escape character is '^]'. |
#^]
telnet> q Connection closed. |
#cat myprg
# default: on # description: The telnet server serves telnet sessions; it uses \ # unencrypted username/password pairs for authentication. service finger { disable = no #flags = REUSE socket_type = stream wait = no user = root server = /bin/bash server_args = -i log_on_failure += USERID } |
#tail /var/log/messages
Jun 9 12:30:49 linux4 xinetd[3895]: START: finger pid=9233 from=127.0.0.1 Jun 9 12:30:49 linux4 xinetd[3895]: EXIT: finger status=126 pid=9233 duration=0(sec) Jun 9 12:31:25 linux4 xinetd[3895]: Starting reconfiguration Jun 9 12:31:25 linux4 xinetd[3895]: Swapping defaults Jun 9 12:31:25 linux4 xinetd[3895]: readjusting service echo-stream Jun 9 12:31:25 linux4 xinetd[3895]: readjusting service telnet Jun 9 12:31:25 linux4 xinetd[3895]: readjusting service finger Jun 9 12:31:25 linux4 xinetd[3895]: Reconfigured: new=0 old=3 dropped=0 (services) Jun 9 12:31:26 linux4 xinetd[3895]: START: finger pid=9269 from=127.0.0.1 Jun 9 12:31:35 linux4 xinetd[3895]: EXIT: finger status=0 pid=9269 duration=9(sec) |
#grep finger /etc/services
finger 79/tcp finger 79/udp cfinger 2003/tcp # GNU Finger |
#vi myprg
|
#man xinetd.conf
|
#nc 192.168.15.1 60000
|
#nc 192.168.15.1 60000
|
#nc 192.168.15.2 79
|
# default: on # description: The telnet server serves telnet sessions; it uses \ # unencrypted username/password pairs for authentication. service finger { disable = no #flags = REUSE socket_type = stream wait = no user = root server = /bin/bash server_args = -i log_on_failure += USERID }
Время первой команды журнала | 08:23:26 2010- 6- 9 | |||||||||||||||||||||||||||||||||||||||||||||
Время последней команды журнала | 08:48:22 2010- 6- 9 | |||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в журнале | 41 | |||||||||||||||||||||||||||||||||||||||||||||
Процент команд с ненулевым кодом завершения, % | 2.44 | |||||||||||||||||||||||||||||||||||||||||||||
Процент синтаксически неверно набранных команд, % | 0.00 | |||||||||||||||||||||||||||||||||||||||||||||
Суммарное время работы с терминалом *, час | 0.42 | |||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в единицу времени, команда/мин | 1.64 | |||||||||||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду w. В поле WHAT, соответствующем текущему терминалу, должна быть указана программа script.
Команды, при наборе которых были допущены синтаксические ошибки, выводятся перечёркнутым текстом:
$ l s-l bash: l: command not found |
Если код завершения команды равен нулю, команда была выполнена без ошибок. Команды, код завершения которых отличен от нуля, выделяются цветом.
$ test 5 -lt 4 |
Команды, ход выполнения которых был прерван пользователем, выделяются цветом.
$ 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 |
Команды, выполненные с привилегиями суперпользователя, выделяются слева красной чертой.
# id uid=0(root) gid=0(root) Gruppen=0(root) |
Изменения, внесённые в текстовый файл с помощью редактора, запоминаются и показываются в журнале в формате ed. Строки, начинающиеся символом "<", удалены, а строки, начинающиеся символом ">" -- добавлены.
$ vi ~/.bashrc
|
Для того чтобы изменить файл в соответствии с показанными в диффшоте изменениями, можно воспользоваться командой patch. Нужно скопировать изменения, запустить программу patch, указав в качестве её аргумента файл, к которому применяются изменения, и всавить скопированный текст:
$ patch ~/.bashrc |
Для того чтобы получить краткую справочную информацию о команде, нужно подвести к ней мышь. Во всплывающей подсказке появится краткое описание команды.
Если справочная информация о команде есть, команда выделяется голубым фоном, например: vi. Если справочная информация отсутствует, команда выделяется розовым фоном, например: notepad.exe. Справочная информация может отсутствовать в том случае, если (1) команда введена неверно; (2) если распознавание команды LiLaLo выполнено неверно; (3) если информация о команде неизвестна LiLaLo. Последнее возможно для редких команд.
Большие, в особенности многострочные, всплывающие подсказки лучше всего показываются браузерами KDE Konqueror, Apple Safari и Microsoft Internet Explorer. В браузерах Mozilla и Firefox они отображаются не полностью, а вместо перевода строки выводится специальный символ.
Время ввода команды, показанное в журнале, соответствует времени начала ввода командной строки, которое равно тому моменту, когда на терминале появилось приглашение интерпретатора
Имя терминала, на котором была введена команда, показано в специальном блоке. Этот блок показывается только в том случае, если терминал текущей команды отличается от терминала предыдущей.
Вывод не интересующих вас в настоящий момент элементов журнала, таких как время, имя терминала и других, можно отключить. Для этого нужно воспользоваться формой управления журналом вверху страницы.
Небольшие комментарии к командам можно вставлять прямо из командной строки. Комментарий вводится прямо в командную строку, после символов #^ или #v. Символы ^ и v показывают направление выбора команды, к которой относится комментарий: ^ - к предыдущей, v - к следующей. Например, если в командной строке было введено:
$ whoami
user
$ #^ Интересно, кто я?в журнале это будет выглядеть так:
$ whoami
user
Интересно, кто я? |
Если комментарий содержит несколько строк, его можно вставить в журнал следующим образом:
$ whoami
user
$ cat > /dev/null #^ Интересно, кто я?
Программа whoami выводит имя пользователя, под которым мы зарегистрировались в системе. - Она не может ответить на вопрос о нашем назначении в этом мире.В журнале это будет выглядеть так:
$ whoami user
|
Комментарии, не относящиеся непосредственно ни к какой из команд, добавляются точно таким же способом, только вместо симолов #^ или #v нужно использовать символы #=
1 2 3 4Группы команд, выполненных на разных терминалах, разделяются специальной линией. Под этой линией в правом углу показано имя терминала, на котором выполнялись команды. Для того чтобы посмотреть команды только одного сенса, нужно щёкнуть по этому названию.
LiLaLo (L3) расшифровывается как Live Lab Log.
Программа разработана для повышения эффективности обучения Unix/Linux-системам.
(c) Игорь Чубин, 2004-2008