/l3/users/07-07-2008/fbsd-adm/fbsd1.unix.nt/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 |
|
#lastlogin | less
|
#who
root ttyp0 Jul 10 07:02 (192.168.16.215) root ttyp2 Jul 10 07:02 (:ttyp1:S.0) root ttyp4 Jul 10 07:14 (192.168.16.214) |
#who
root ttyp0 Jul 10 07:02 (192.168.16.215) root ttyp2 Jul 10 07:02 (:ttyp1:S.0) root ttyp4 Jul 10 07:14 (192.168.16.214) |
#who
root ttyp0 Jul 10 07:02 (192.168.16.215) root ttyp2 Jul 10 07:02 (:ttyp1:S.0) root ttyp4 Jul 10 07:14 (192.168.16.214) |
#who
root ttyp0 Jul 10 07:02 (192.168.16.215) root ttyp2 Jul 10 07:02 (:ttyp1:S.0) root ttyp4 Jul 10 07:14 (192.168.16.214) |
#w
8:13AM up 1:12, 3 users, load averages: 1.24, 0.66, 0.48 USER TTY FROM LOGIN@ IDLE WHAT root p0 192.168.16.215 7:02AM - script -t 0 -q /root/. root p2 :ttyp1:S.0 7:02AM - script -t 0 -q /root/. root p4 192.168.16.214 7:14AM 59 script -t 0 -q /root/. ^C |
#w
8:13AM up 1:12, 3 users, load averages: 1.24, 0.66, 0.48 USER TTY FROM LOGIN@ IDLE WHAT root p0 192.168.16.215 7:02AM - script -t 0 -q /root/. root p2 :ttyp1:S.0 7:02AM - script -t 0 -q /root/. root p4 192.168.16.214 7:14AM 59 script -t 0 -q /root/. ^C |
#w -n
8:13AM up 1:13, 3 users, load averages: 1.38, 0.70, 0.49 USER TTY FROM LOGIN@ IDLE WHAT root p0 192.168.16.215 7:02AM - script -t 0 -q /root/. root p2 :ttyp1:S.0 7:02AM - script -t 0 -q /root/. root p4 192.168.16.214 7:14AM 59 script -t 0 -q /root/. |
#logname
root |
#logname
root |
#logname
root |
#logname
root |
#whoami
root |
#whoami
root |
#whoami
root |
#whoami
root |
#adduser
Username: svjat Full name: Svjatoslav Uid (Leave empty for default): Login group [svjat]: wheel Login group is wheel. Invite svjat into other groups? []: n Group n does not exist! Login group is wheel. Invite svjat into other groups? []: Login class [default]: russian Shell (sh csh tcsh bash rbash nologin) [sh]: /usr/local/bin/bash Home directory [/home/svjat]: ... Uid : 1125 Class : russian Groups : wheel Home : /home/svjat Shell : /usr/local/bin/bash Locked : no OK? (yes/no): y adduser: INFO: Successfully added (svjat) to the user database. Add another user? (yes/no): n Goodbye! |
#adduser
Username: svjat Full name: Svjatoslav Uid (Leave empty for default): Login group [svjat]: wheel Login group is wheel. Invite svjat into other groups? []: n Group n does not exist! Login group is wheel. Invite svjat into other groups? []: Login class [default]: russian Shell (sh csh tcsh bash rbash nologin) [sh]: /usr/local/bin/bash Home directory [/home/svjat]: ... Uid : 1125 Class : russian Groups : wheel Home : /home/svjat Shell : /usr/local/bin/bash Locked : no OK? (yes/no): y adduser: INFO: Successfully added (svjat) to the user database. Add another user? (yes/no): n Goodbye! |
#adduser
Username: svjat Full name: Svjatoslav Uid (Leave empty for default): Login group [svjat]: wheel Login group is wheel. Invite svjat into other groups? []: n Group n does not exist! Login group is wheel. Invite svjat into other groups? []: Login class [default]: russian Shell (sh csh tcsh bash rbash nologin) [sh]: /usr/local/bin/bash Home directory [/home/svjat]: ... Uid : 1125 Class : russian Groups : wheel Home : /home/svjat Shell : /usr/local/bin/bash Locked : no OK? (yes/no): y adduser: INFO: Successfully added (svjat) to the user database. Add another user? (yes/no): n Goodbye! |
#adduser
Username: svjat Full name: Svjatoslav Uid (Leave empty for default): Login group [svjat]: wheel Login group is wheel. Invite svjat into other groups? []: n Group n does not exist! Login group is wheel. Invite svjat into other groups? []: Login class [default]: russian Shell (sh csh tcsh bash rbash nologin) [sh]: /usr/local/bin/bash Home directory [/home/svjat]: ... Uid : 1125 Class : russian Groups : wheel Home : /home/svjat Shell : /usr/local/bin/bash Locked : no OK? (yes/no): y adduser: INFO: Successfully added (svjat) to the user database. Add another user? (yes/no): n Goodbye! |
#less /etc/passwd
|
#less /etc/passwd
|
#less /etc/passwd
|
#less /etc/passwd
|
#rmuser svjat
Matching password entry: svjat:*:1125:0:russian:0:0:Svjatoslav:/home/svjat:/usr/local/bin/bash Is this the entry you wish to remove? y Remove user's home directory (/home/svjat)? y Removing user (svjat): mailspool home passwd. |
#rmuser svjat
Matching password entry: svjat:*:1125:0:russian:0:0:Svjatoslav:/home/svjat:/usr/local/bin/bash Is this the entry you wish to remove? y Remove user's home directory (/home/svjat)? y Removing user (svjat): mailspool home passwd. |
#rmuser svjat
Matching password entry: svjat:*:1125:0:russian:0:0:Svjatoslav:/home/svjat:/usr/local/bin/bash Is this the entry you wish to remove? y Remove user's home directory (/home/svjat)? y Removing user (svjat): mailspool home passwd. |
#rmuser svjat
Matching password entry: svjat:*:1125:0:russian:0:0:Svjatoslav:/home/svjat:/usr/local/bin/bash Is this the entry you wish to remove? y Remove user's home directory (/home/svjat)? y Removing user (svjat): mailspool home passwd. |
#less /etc/passwd
|
#less /etc/passwd
|
#less /etc/passwd
|
#less /etc/passwd
|
#echo "x'hn gt,thb"
|
#echo "x'hn gt,thb" | pw useradd senya -h O -L russian -c 'Sem
|
#echo 'x`
pw: login name `senya' already exists |
#pw userdel senja
pw: no such user `senja' |
#pw userdel senya
|
#echo 'x`hn gt,thb' | pw useradd senya -h O -L russian -c 'Sem
|
#echo 'x`hn gt,thb'
x`hn gt,thb |
#echo 'x\'hn gt,thb'
> |
#echo 'x\'hn gt,thb'
> |
#echo 'x\'hn gt,thb'
> |
#echo "x'hn gt,thb"
x'hn gt,thb |
#echo "x'hn gt,thb"
x'hn gt,thb |
#echo "x'hn gt,thb"
x'hn gt,thb |
#pw userdel senya
|
#touch a b
|
#chown root a
|
#chgrp wheel a
|
#chown user:wheel b
|
#chown user:wheel b
|
#chown user:wheel b
|
#ls -l a b
-rw-r--r-- 1 root wheel 0 Jul 10 08:39 a -rw-r--r-- 1 user wheel 0 Jul 10 08:39 b |
#ls -l a b
-rw-r--r-- 1 root wheel 0 Jul 10 08:39 a -rw-r--r-- 1 user wheel 0 Jul 10 08:39 b |
#ls -l a b
-rw-r--r-- 1 root wheel 0 Jul 10 08:39 a -rw-r--r-- 1 user wheel 0 Jul 10 08:39 b |
#chmod u=rx,g=,o= a b
|
#chmod u=rx,g=,o= a b
|
#chmod u=rx,g=,o= a b
|
#ls -l a b
-r-x------ 1 root wheel 0 Jul 10 08:39 a -r-x------ 1 user wheel 0 Jul 10 08:39 b |
#ls -l a b
-r-x------ 1 root wheel 0 Jul 10 08:39 a -r-x------ 1 user wheel 0 Jul 10 08:39 b |
#ls -l a b
-r-x------ 1 root wheel 0 Jul 10 08:39 a -r-x------ 1 user wheel 0 Jul 10 08:39 b |
#md /mytmp
bash: md: command not found |
#md /mytmp
bash: md: command not found |
#md /mytmp
bash: md: command not found |
#md /mytmp
bash: md: command not found |
#mkdir /mytmp
|
#mkdir /mytmp
|
#mkdir /mytmp
|
#mkdir /mytmp
|
#ls
'echo 09:48:03 | tr '[:lower:]' '[:upper:]'' 'echo 123456 | tr '[:lower:]' '[:upper:]'' 'echo 2008 | tr '[:lower:]' '[:upper:]'' 'echo 8 | tr '[:lower:]' '[:upper:]'' 'echo A:\WINDOWS\SYSTEM32 | tr '[:lower:]' '[:upper:]'' 'echo Jul | tr '[:lower:]' '[:upper:]'' 'echo NEWFILE | tr '[:lower:]' '[:upper:]'' 'echo TEST | tr '[:lower:]' '[:upper:]'' 'echo Tue Jul 8 09:48:20 UTC 2008 | tr '[:lower:]' '[:upper:]'' 'echo Tue | tr '[:lower:]' '[:upper:]'' ... name no_file no_file2 screens select1 test testfile while while1 y |
#ls
'echo 09:48:03 | tr '[:lower:]' '[:upper:]'' 'echo 123456 | tr '[:lower:]' '[:upper:]'' 'echo 2008 | tr '[:lower:]' '[:upper:]'' 'echo 8 | tr '[:lower:]' '[:upper:]'' 'echo A:\WINDOWS\SYSTEM32 | tr '[:lower:]' '[:upper:]'' 'echo Jul | tr '[:lower:]' '[:upper:]'' 'echo NEWFILE | tr '[:lower:]' '[:upper:]'' 'echo TEST | tr '[:lower:]' '[:upper:]'' 'echo Tue Jul 8 09:48:20 UTC 2008 | tr '[:lower:]' '[:upper:]'' 'echo Tue | tr '[:lower:]' '[:upper:]'' ... name no_file no_file2 screens select1 test testfile while while1 y |
#ls
'echo 09:48:03 | tr '[:lower:]' '[:upper:]'' 'echo 123456 | tr '[:lower:]' '[:upper:]'' 'echo 2008 | tr '[:lower:]' '[:upper:]'' 'echo 8 | tr '[:lower:]' '[:upper:]'' 'echo A:\WINDOWS\SYSTEM32 | tr '[:lower:]' '[:upper:]'' 'echo Jul | tr '[:lower:]' '[:upper:]'' 'echo NEWFILE | tr '[:lower:]' '[:upper:]'' 'echo TEST | tr '[:lower:]' '[:upper:]'' 'echo Tue Jul 8 09:48:20 UTC 2008 | tr '[:lower:]' '[:upper:]'' 'echo Tue | tr '[:lower:]' '[:upper:]'' ... name no_file no_file2 screens select1 test testfile while while1 y |
#ls
'echo 09:48:03 | tr '[:lower:]' '[:upper:]'' 'echo 123456 | tr '[:lower:]' '[:upper:]'' 'echo 2008 | tr '[:lower:]' '[:upper:]'' 'echo 8 | tr '[:lower:]' '[:upper:]'' 'echo A:\WINDOWS\SYSTEM32 | tr '[:lower:]' '[:upper:]'' 'echo Jul | tr '[:lower:]' '[:upper:]'' 'echo NEWFILE | tr '[:lower:]' '[:upper:]'' 'echo TEST | tr '[:lower:]' '[:upper:]'' 'echo Tue Jul 8 09:48:20 UTC 2008 | tr '[:lower:]' '[:upper:]'' 'echo Tue | tr '[:lower:]' '[:upper:]'' ... name no_file no_file2 screens select1 test testfile while while1 y |
#ls -l > less
|
#ls -l > less
|
#ls -l > less
|
#ls -l > less
|
#less ls -l
|
#less ls -l
|
#less ls -l
|
#less ls -l
|
#less ls -l
|
#less ls -l
|
#less ls -l
|
#less ls -l
|
#alias
|
#alias
|
#alias
|
#alias
|
#ls -l | less
|
#ls -l | less
|
#ls -l | less
|
#ls -l | less
|
#ls -l | less
|
#ls -l | less
|
#ls -l | less
|
#ls -l | less
|
#ls | less
|
#ls | less
|
#ls | less
|
Время первой команды журнала | 08:13:05 2008- 7-10 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Время последней команды журнала | 08:48:12 2008- 7-10 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в журнале | 101 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Процент команд с ненулевым кодом завершения, % | 18.81 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Процент синтаксически неверно набранных команд, % | 3.96 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Суммарное время работы с терминалом *, час | 0.59 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в единицу времени, команда/мин | 2.88 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду 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