/l3/users/12-05-2008/fbsd-net/fbsd2.unix.nt/root :1 :2 :3 :4 :5 :6 :7 :8 :9 :10 :11 :12 :13 :14 :15 :16 :17 :18 |
|
#scp fbsd3:/tmp/script
script script1 |
#scp fbsd3:/tmp/script
script script1 |
#scp fbsd3:/tmp/script
script script1 |
#scp fbsd3:/tmp/script
script script1 |
#scp fbsd3:/tmp/script1 /tmp
The authenticity of host 'fbsd3 (192.168.16.23)' can't be established. DSA key fingerprint is 13:3f:fb:2a:53:62:8e:f8:0e:c7:3a:c9:10:99:b6:25. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added 'fbsd3' (DSA) to the list of known hosts. Password: scp: /tmp/script1: No such file or directory |
#scp fbsd3:/tmp/script1 /tmp
The authenticity of host 'fbsd3 (192.168.16.23)' can't be established. DSA key fingerprint is 13:3f:fb:2a:53:62:8e:f8:0e:c7:3a:c9:10:99:b6:25. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added 'fbsd3' (DSA) to the list of known hosts. Password: scp: /tmp/script1: No such file or directory |
#scp fbsd3:/tmp/script1 /tmp
The authenticity of host 'fbsd3 (192.168.16.23)' can't be established. DSA key fingerprint is 13:3f:fb:2a:53:62:8e:f8:0e:c7:3a:c9:10:99:b6:25. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added 'fbsd3' (DSA) to the list of known hosts. Password: scp: /tmp/script1: No such file or directory |
#scp fbsd3:/tmp/ /tmp/script1
Password: scp: /tmp: not a regular file |
#scp fbsd3:/tmp /tmp/script1
Password: scp: /tmp: not a regular file |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 449 0.4KB/s 00:00 |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 449 0.4KB/s 00:00 |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 449 0.4KB/s 00:00 |
#vim script1
--- /tmp/l3-saved-52599.29080.14827 2008-05-14 13:14:19.000000000 +0000 +++ script1 2008-05-14 13:15:38.000000000 +0000 @@ -11,14 +11,14 @@ do if [ -f $name ] then -fname='basename $name' -n='echo $fname | sed -e "s/$1/$2/"' +fname=`basename $name` +n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n number=((number+1)) fi done -rem='expr $number % 10' +rem=`expr $number % 10` if [$rem -eq 1 ] then echo "File $number renamed" |
#vim script1
--- /tmp/l3-saved-52599.29080.14827 2008-05-14 13:14:19.000000000 +0000 +++ script1 2008-05-14 13:15:38.000000000 +0000 @@ -11,14 +11,14 @@ do if [ -f $name ] then -fname='basename $name' -n='echo $fname | sed -e "s/$1/$2/"' +fname=`basename $name` +n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n number=((number+1)) fi done -rem='expr $number % 10' +rem=`expr $number % 10` if [$rem -eq 1 ] then echo "File $number renamed" |
#vim script1
--- /tmp/l3-saved-52599.29080.14827 2008-05-14 13:14:19.000000000 +0000 +++ script1 2008-05-14 13:15:38.000000000 +0000 @@ -11,14 +11,14 @@ do if [ -f $name ] then -fname='basename $name' -n='echo $fname | sed -e "s/$1/$2/"' +fname=`basename $name` +n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n number=((number+1)) fi done -rem='expr $number % 10' +rem=`expr $number % 10` if [$rem -eq 1 ] then echo "File $number renamed" |
#./script1 .cpp .c
./script1: line 17: syntax error near unexpected token `(' ./script1: line 17: `number=((number+1))' ./script1: line 18: syntax error near unexpected token `fi' ./script1: line 18: `fi' |
#./script1 .cpp .c
./script1: line 17: syntax error near unexpected token `(' ./script1: line 17: `number=((number+1))' ./script1: line 18: syntax error near unexpected token `fi' ./script1: line 18: `fi' |
#./script1 .cpp .c
./script1: line 17: syntax error near unexpected token `(' ./script1: line 17: `number=((number+1))' ./script1: line 18: syntax error near unexpected token `fi' ./script1: line 18: `fi' |
#vim script1
--- /tmp/l3-saved-52599.12482.24019 2008-05-14 13:17:42.000000000 +0000 +++ script1 2008-05-14 13:17:53.000000000 +0000 @@ -14,7 +14,7 @@ fname=`basename $name` n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n -number=((number+1)) +number=$((number+1)) fi done |
#vim script1
--- /tmp/l3-saved-52599.12482.24019 2008-05-14 13:17:42.000000000 +0000 +++ script1 2008-05-14 13:17:53.000000000 +0000 @@ -14,7 +14,7 @@ fname=`basename $name` n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n -number=((number+1)) +number=$((number+1)) fi done |
#vim script1
--- /tmp/l3-saved-52599.12482.24019 2008-05-14 13:17:42.000000000 +0000 +++ script1 2008-05-14 13:17:53.000000000 +0000 @@ -14,7 +14,7 @@ fname=`basename $name` n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n -number=((number+1)) +number=$((number+1)) fi done |
#vim script1
--- /tmp/l3-saved-52599.12482.24019 2008-05-14 13:17:42.000000000 +0000 +++ script1 2008-05-14 13:17:53.000000000 +0000 @@ -14,7 +14,7 @@ fname=`basename $name` n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n -number=((number+1)) +number=$((number+1)) fi done |
#./script1 .cpp .c
./script1: line 22: [6: command not found 6 file(s) renamed] |
#./script1 .cpp .c
./script1: line 22: [6: command not found 6 file(s) renamed] |
#./script1 .cpp .c
./script1: line 22: [6: command not found 6 file(s) renamed] |
#cat script1
#!/usr/local/bin/bash if [ $# -ne 2 ] then echo "Usage: 'basename $0' old-pattern new pattern" exit 1 fi number=0 for name in *$1* do if [ -f $name ] ... then echo "File $number renamed" else if [ $rem -gt 1 -a $rem -lt 5 ] then echo "$number file(s) renamed"] else echo "$number file(s) renamed"] fi fi |
#cat script1
#!/usr/local/bin/bash if [ $# -ne 2 ] then echo "Usage: 'basename $0' old-pattern new pattern" exit 1 fi number=0 for name in *$1* do if [ -f $name ] ... then echo "File $number renamed" else if [ $rem -gt 1 -a $rem -lt 5 ] then echo "$number file(s) renamed"] else echo "$number file(s) renamed"] fi fi |
#cat script1
#!/usr/local/bin/bash if [ $# -ne 2 ] then echo "Usage: 'basename $0' old-pattern new pattern" exit 1 fi number=0 for name in *$1* do if [ -f $name ] ... then echo "File $number renamed" else if [ $rem -gt 1 -a $rem -lt 5 ] then echo "$number file(s) renamed"] else echo "$number file(s) renamed"] fi fi |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 450 0.4KB/s 00:00 |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 450 0.4KB/s 00:00 |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 450 0.4KB/s 00:00 |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 450 0.4KB/s 00:00 |
#scp ./script1 root@fbsd3:/tmp
Password: script1 100% 450 0.4KB/s 00:00 |
#cp script1 script_final
|
#cp script1 script_final
|
#cp script1 script_final
|
#scp ./script_finalfbsd3:/tmp
Password: script_final 100% 450 0.4KB/s 00:00 |
#scp ./script_finalfbsd3:/tmp
Password: script_final 100% 450 0.4KB/s 00:00 |
#scp ./script_finalfbsd3:/tmp
Password: script_final 100% 450 0.4KB/s 00:00 |
#scp ./script_final root@192.168.16.24
The authenticity of host '192.168.16.24 (192.168.16.24)' can't be established. DSA key fingerprint is 13:3f:fb:2a:53:62:8e:f8:0e:c7:3a:c9:10:99:b6:25. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '192.168.16.24' (DSA) to the list of known hosts. Password: script_final 100% 450 0.4KB/s 00:00 |
#scp ./script_final root@192.168.16.24
The authenticity of host '192.168.16.24 (192.168.16.24)' can't be established. DSA key fingerprint is 13:3f:fb:2a:53:62:8e:f8:0e:c7:3a:c9:10:99:b6:25. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '192.168.16.24' (DSA) to the list of known hosts. Password: script_final 100% 450 0.4KB/s 00:00 |
#vim /etc/hosts
--- /tmp/l3-saved-52599.8765.13078 2008-05-14 13:19:32.000000000 +0000 +++ /etc/hosts 2008-05-14 13:20:17.000000000 +0000 @@ -3,3 +3,4 @@ 192.168.16.22 fbsd2.unix.nt fbsd2 192.168.16.22 fbsd2.unix.nt. 192.168.16.23 fbsd3 +192.168.16.24 fbsd4 |
#vim /etc/hosts
--- /tmp/l3-saved-52599.8765.13078 2008-05-14 13:19:32.000000000 +0000 +++ /etc/hosts 2008-05-14 13:20:17.000000000 +0000 @@ -3,3 +3,4 @@ 192.168.16.22 fbsd2.unix.nt fbsd2 192.168.16.22 fbsd2.unix.nt. 192.168.16.23 fbsd3 +192.168.16.24 fbsd4 |
#vim /etc/hosts
--- /tmp/l3-saved-52599.8765.13078 2008-05-14 13:19:32.000000000 +0000 +++ /etc/hosts 2008-05-14 13:20:17.000000000 +0000 @@ -3,3 +3,4 @@ 192.168.16.22 fbsd2.unix.nt fbsd2 192.168.16.22 fbsd2.unix.nt. 192.168.16.23 fbsd3 +192.168.16.24 fbsd4 |
#vim /etc/hosts
--- /tmp/l3-saved-52599.19180.10191 2008-05-14 13:20:25.000000000 +0000 +++ /etc/hosts 2008-05-14 13:20:44.000000000 +0000 @@ -4,3 +4,4 @@ 192.168.16.22 fbsd2.unix.nt. 192.168.16.23 fbsd3 192.168.16.24 fbsd4 +192.168.16.21 fbsd1 |
#vim /etc/hosts
--- /tmp/l3-saved-52599.19180.10191 2008-05-14 13:20:25.000000000 +0000 +++ /etc/hosts 2008-05-14 13:20:44.000000000 +0000 @@ -4,3 +4,4 @@ 192.168.16.22 fbsd2.unix.nt. 192.168.16.23 fbsd3 192.168.16.24 fbsd4 +192.168.16.21 fbsd1 |
#vim /etc/hosts
--- /tmp/l3-saved-52599.19180.10191 2008-05-14 13:20:25.000000000 +0000 +++ /etc/hosts 2008-05-14 13:20:44.000000000 +0000 @@ -4,3 +4,4 @@ 192.168.16.22 fbsd2.unix.nt. 192.168.16.23 fbsd3 192.168.16.24 fbsd4 +192.168.16.21 fbsd1 |
#clear
|
#clear
|
#clear
|
#logname
root |
#logname
root |
#logname
root |
#logname
root |
#logname
root |
#logname
root |
#su user
|
#su user
|
#su user
|
$logname
root |
$logname
root |
$logname
root |
$exit
exit |
$exit
exit |
$exit
exit |
#man useradd
|
#man useradd
|
#man useradd
|
#man useradd
|
#man useradd
|
#man useradd
|
#man user_dd
|
#man user_dd
|
#man user_dd
|
#man user_dd
|
#man user_dd
|
#man user_dd
|
#useradd
bash: useradd: command not found |
#useradd
bash: useradd: command not found |
#useradd
bash: useradd: command not found |
#useradd
bash: useradd: command not found |
#useradd
bash: useradd: command not found |
#useradd
bash: useradd: command not found |
#adduser
Username: ^C |
#adduser
Username: ^C |
#adduser
Username: ^C |
#adduser
Username: ^C |
#man ser
|
#man ser
|
#man ser
|
#man ser
|
#umask
0022 |
#umask
0022 |
#umask
0022 |
#umask
0022 |
#users
users users-admin |
#users
users users-admin |
#users
users users-admin |
#users
users users-admin |
#users
users users-admin |
#!/usr/local/bin/bash if [ $# -ne 2 ] then echo "Usage: 'basename $0' old-pattern new pattern" exit 1 fi number=0 for name in *$1* do if [ -f $name ] then fname=`basename $name` n=`echo $fname | sed -e "s/$1/$2/"` mv $fname $n number=$((number+1)) fi done rem=`expr $number % 10` if [$rem -eq 1 ] then echo "File $number renamed" else if [ $rem -gt 1 -a $rem -lt 5 ] then echo "$number file(s) renamed"] else echo "$number file(s) renamed"] fi fi
Время первой команды журнала | 15:55:32 2008- 5-14 | ||||||||||||||||||||||||||||||||||||||||||
Время последней команды журнала | 17:17:54 2008- 5-14 | ||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в журнале | 101 | ||||||||||||||||||||||||||||||||||||||||||
Процент команд с ненулевым кодом завершения, % | 24.75 | ||||||||||||||||||||||||||||||||||||||||||
Процент синтаксически неверно набранных команд, % | 5.94 | ||||||||||||||||||||||||||||||||||||||||||
Суммарное время работы с терминалом *, час | 0.84 | ||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в единицу времени, команда/мин | 2.01 | ||||||||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду 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