/l3/users/igor-public/test/book/igor |
|
$who
igor tty7 2009-03-20 05:42 (:0) igor pts/0 2009-03-20 05:43 (:0.0) igor pts/1 2009-03-20 05:43 (:0.0) igor pts/2 2009-03-20 07:03 (:0.0) igor pts/3 2009-03-20 07:26 (:0.0) |
$whoami
igor |
$l3-agent
|
$find /
/proc/2/net/rpc/nfsd.fh/content /proc/2/net/rpc/nfsd.fh/channel /proc/2/net/rpc/nfsd.fh/flush /proc/2/net/rpc/nfsd.export /proc/2/net/rpc/nfsd.export/content /proc/2/net/rpc/nfsd.export/channel /proc/2/net/rpc/nfsd.export/flush /proc/2/net/rpc/nfsd /proc/2/net/rpc/auth.rpcsec.init /proc/2/net/rpc/auth.rpcsec.init/channel ... /proc/3/task/3/mountinfo /proc/3/task/3/clear_refs /proc/3/task/3/smaps /proc/3/task/3/pagemap /proc/3/task/3/attr /proc/3/task/3/attr/current /proc/3/task/3/attr/prev /proc/3/task/3/attr/exec /proc/3/task/3/attr/fscreate /proc/3/task/3/attr/keycreate |
$find /
/proc/2/net/rpc/nfsd.fh/content /proc/2/net/rpc/nfsd.fh/channel /proc/2/net/rpc/nfsd.fh/flush /proc/2/net/rpc/nfsd.export /proc/2/net/rpc/nfsd.export/content /proc/2/net/rpc/nfsd.export/channel /proc/2/net/rpc/nfsd.export/flush /proc/2/net/rpc/nfsd /proc/2/net/rpc/auth.rpcsec.init /proc/2/net/rpc/auth.rpcsec.init/channel ... /proc/3/task/3/mountinfo /proc/3/task/3/clear_refs /proc/3/task/3/smaps /proc/3/task/3/pagemap /proc/3/task/3/attr /proc/3/task/3/attr/current /proc/3/task/3/attr/prev /proc/3/task/3/attr/exec /proc/3/task/3/attr/fscreate /proc/3/task/3/attr/keycreate |
$find /tmp/
/tmp/ /tmp/tpavlic_cv.pdf /tmp/.X11-unix /tmp/.X11-unix/X0 /tmp/keyring-JRliCB /tmp/keyring-JRliCB/socket /tmp/keyring-JRliCB/ssh /tmp/keyring-JRliCB/socket.pkcs11 /tmp/orbit-igor /tmp/orbit-igor/linc-1592-0-49623c3292258 ... /tmp/cv.pdf /tmp/ns.igor.:0 /tmp/ns.igor.:0/.proglist /tmp/ns.igor.:0/wmii /tmp/.ICE-unix /tmp/gconfd-igor /tmp/gconfd-igor/lock /tmp/gconfd-igor/lock/ior /tmp/install /tmp/.X0-lock |
$vi random-mem-write.x
|
$~
{ain() { i [N]; long long int i; for(;;) { a[i]=0; ----} }--- } } } ... ~ ~ ~ ~ ~ ~ ~ ~ ~ "random-mem-write.c" [New] 9L, 101C written |
$gcc -o random-mem-write random-mem-write.c
|
$./random-mem-write
Segmentation fault |
$./random-mem-write &
[1] 29746 |
$top
top - 08:43:33 up 3:02, 5 users, load average: 0.25, 0.08, 0.02 Tasks: 127 total, 2 running, 125 sleeping, 0 stopped, 0 zombie Cpu(s): 51.0%us, 1.0%sy, 0.0%ni, 48.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st Mem: 3615260k total, 608468k used, 3006792k free, 31480k buffers PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND Swap: 0k total, 0k used, 0k free, 202016k cached 29746 igor 20 0 40552 272 216 R 100 0.0 0:14.00 random-mem-writ 5522 igor 20 0 236m 129m 21m S 1 3.7 3:16.07 firefox-bin 29770 igor 20 0 2264 1160 880 R 1 0.0 0:00.02 top 1 root 20 0 1984 696 596 S 0 0.0 0:01.22 init ... 3795 root 20 0 2220 536 344 S 0 0.0 0:00.00 rpc.idmapd 3812 root 15 -5 0 0 0 S 0 0.0 0:00.00 iscsi_eh 3827 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_addr 3839 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_mcast 3842 root 15 -5 0 0 0 S 0 0.0 0:00.00 iw_cm_wq 3846 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_cm/0 3849 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_cm/1 3852 root 15 -5 0 0 0 S 0 0.0 0:00.00 rdma_cm 3859 root 20 0 1808 464 388 S 0 0.0 0:00.08 iscsid 3860 root 10 -10 2260 2260 1540 S 0 0.1 0:00.18 iscsid |
$kill %
[2]+ Terminated ./random-mem-write |
$kill %
[1]+ Terminated ./random-mem-write |
$kill %
l3script: kill: %: no such job |
$top
top - 09:05:00 up 3:23, 5 users, load average: 0.68, 0.95, 0.73 Tasks: 128 total, 2 running, 126 sleeping, 0 stopped, 0 zombie Cpu(s): 57.8%us, 0.5%sy, 0.0%ni, 41.7%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st Mem: 3615260k total, 653248k used, 2962012k free, 33600k buffers PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND Swap: 0k total, 0k used, 0k free, 204120k cached 7975 igor 20 0 40556 38m 284 R 99 1.1 0:09.38 random-mem-writ 24872 igor 20 0 10856 5928 1480 S 15 0.2 0:11.30 l3-agent 5522 igor 20 0 236m 129m 21m S 2 3.7 3:30.49 firefox-bin 4241 root 20 0 376m 27m 10m S 0 0.8 1:20.34 Xorg ... 3764 root 15 -5 0 0 0 S 0 0.0 0:00.00 rpciod/1 3774 root 15 -5 0 0 0 S 0 0.0 0:00.00 nfsiod 3795 root 20 0 2220 536 344 S 0 0.0 0:00.00 rpc.idmapd 3812 root 15 -5 0 0 0 S 0 0.0 0:00.00 iscsi_eh 3827 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_addr 3839 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_mcast 3842 root 15 -5 0 0 0 S 0 0.0 0:00.00 iw_cm_wq 3846 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_cm/0 3849 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_cm/1 3852 root 15 -5 0 0 0 S 0 0.0 0:00.00 rdma_cm |
$scp random-mem-write.c igor@chub.in:/var/www/igor/tmp/
random-mem-write.c 100% 191 0.2KB/s 00:00 |
$top
top - 09:16:16 up 3:35, 5 users, load average: 0.20, 0.32, 0.48 Tasks: 129 total, 2 running, 127 sleeping, 0 stopped, 0 zombie Cpu(s): 50.7%us, 0.7%sy, 0.0%ni, 48.7%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st Mem: 3615260k total, 675276k used, 2939984k free, 34752k buffers PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND Swap: 0k total, 0k used, 0k free, 217524k cached 14263 igor 20 0 40556 38m 288 R 100 1.1 0:04.90 random-mem-writ 5522 igor 20 0 236m 129m 21m S 2 3.7 3:42.13 firefox-bin 1 root 20 0 1984 696 596 S 0 0.0 0:01.22 init 2 root 15 -5 0 0 0 S 0 0.0 0:00.00 kthreadd ... 3795 root 20 0 2220 536 344 S 0 0.0 0:00.00 rpc.idmapd 3812 root 15 -5 0 0 0 S 0 0.0 0:00.00 iscsi_eh 3827 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_addr 3839 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_mcast 3842 root 15 -5 0 0 0 S 0 0.0 0:00.00 iw_cm_wq 3846 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_cm/0 3849 root 15 -5 0 0 0 S 0 0.0 0:00.00 ib_cm/1 3852 root 15 -5 0 0 0 S 0 0.0 0:00.00 rdma_cm 3859 root 20 0 1808 464 388 S 0 0.0 0:00.10 iscsid 3860 root 10 -10 2260 2260 1540 S 0 0.1 0:00.22 iscsid |
$man time
|
$man 2 time
|
$man 2 ctime
|
$man ctime
|
$man clock
|
$man 3 clock
|
$man 2 clock
|
Время первой команды журнала | 07:28:17 2009- 3-20 | ||||||||||||||||||||||||||||||||||||
Время последней команды журнала | 09:36:06 2009- 3-20 | ||||||||||||||||||||||||||||||||||||
Количество командных строк в журнале | 25 | ||||||||||||||||||||||||||||||||||||
Процент команд с ненулевым кодом завершения, % | 32.00 | ||||||||||||||||||||||||||||||||||||
Процент синтаксически неверно набранных команд, % | 0.00 | ||||||||||||||||||||||||||||||||||||
Суммарное время работы с терминалом *, час | 0.95 | ||||||||||||||||||||||||||||||||||||
Количество командных строк в единицу времени, команда/мин | 0.44 | ||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду 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