/l3/users/bas/2011-03/linux2.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 :45 :46 :47 |
|
#echo ???*
033_Unit1.html anaconda-ks.cfg backup Desktop install.log install.log.syslog mbox |
#echo ???*echo [bf]*
???*echo backup |
$echo f* b*
file1 file2 b-link b-sourc |
$echo [bf]*
b-link b-sourc file1 file2 |
$echo xxx{1,2,3}yyyy
xxx1yyyy xxx2yyyy xxx3yyyy |
#echo [^bf]*
033_Unit1.html anaconda-ks.cfg Desktop install.log install.log.syslog mbox t |
#echo [^bf]
t |
#echo 111{1,2,3}222
1111222 1112222 1113222 |
$echo xxx{1,2,3}yyyy{1,2,3}
xxx1yyyy1 xxx1yyyy2 xxx1yyyy3 xxx2yyyy1 xxx2yyyy2 xxx2yyyy3 xxx3yyyy1 xxx3yyyy2 xxx3yyyy3 |
$mkdir D2
mkdir: cannot create directory `D2': File exists |
$ls -l
total 4 drwxr-x--x 2 root root 4096 Mar 29 15:04 dir |
$date
Tue Mar 29 17:47:06 ALMT 2011 |
$mkdir `!!`
mkdir `date` mkdir: cannot create directory `Tue': Permission denied mkdir: cannot create directory `Mar': Permission denied mkdir: cannot create directory `29': Permission denied mkdir: cannot create directory `17:47:47': Permission denied mkdir: cannot create directory `ALMT': Permission denied mkdir: cannot create directory `2011': Permission denied |
#ls
033_Unit1.html backup Desktop install.log.syslog t anaconda-ks.cfg date install.log mbox |
#mkdir `date
> ` |
#ls -l
total 28 drwxr-xr-x 2 root root 4096 Mar 29 17:47 17:47:57 drwxr-xr-x 2 root root 4096 Mar 29 17:47 2011 drwxr-xr-x 2 root root 4096 Mar 29 17:47 29 drwxr-xr-x 2 root root 4096 Mar 29 17:47 ALMT drwxr-x--x 2 root root 4096 Mar 29 15:04 dir drwxr-xr-x 2 root root 4096 Mar 29 17:47 Mar drwxr-xr-x 2 root root 4096 Mar 29 17:47 Tue |
#mkdir `date
rmdir `date` rmdir: 17:49:03: No such file or directory |
#ls
033_Unit1.html backup Desktop install.log.syslog t anaconda-ks.cfg date install.log mbox |
#mkdir `date`
|
#ls -l
total 8 drwxr-xr-x 2 root root 4096 Mar 29 17:47 17:47:57 drwxr-x--x 2 root root 4096 Mar 29 15:04 dir |
#rm -rf *
|
#mkdir `date
` ` |
#rmdir `date`
rmdir: 17:49:29: No such file or directory |
#ls -l
total 4 drwxr-xr-x 2 root root 4096 Mar 29 17:49 17:49:26 |
#mkdir "`date`"
|
#ls
033_Unit1.html 29 backup install.log mbox 17:49:32 ALMT date install.log.syslog t 2011 anaconda-ks.cfg Desktop Mar Tue |
#rmdir `!!`
rmdir `ls` rmdir: 033_Unit1.html: Not a directory rmdir: anaconda-ks.cfg: Not a directory rmdir: backup: Directory not empty rmdir: install.log: Not a directory rmdir: install.log.syslog: Not a directory rmdir: mbox: Not a directory rmdir: t: Directory not empty |
#rmdir `date`
rmdir: Tue: No such file or directory rmdir: Mar: No such file or directory rmdir: 29: No such file or directory rmdir: 17:50:02: No such file or directory rmdir: ALMT: No such file or directory rmdir: 2011: No such file or directory |
#ls
033_Unit1.html backup install.log.syslog t anaconda-ks.cfg install.log mbox |
#mkdir "`date`"
|
#ls -l
total 8 drwxr-xr-x 2 root root 4096 Mar 29 17:49 17:49:26 drwxr-xr-x 2 root root 4096 Mar 29 17:50 Tue Mar 29 17:50:15 ALMT 2011 |
#mkdir "My documents"
|
#ls
033_Unit1.html backup install.log.syslog t anaconda-ks.cfg install.log mbox Tue Mar 29 17:50:26 ALMT 2011 |
#date +%Y-%m-%d
2011-03-29 |
#cp -R /etc/ /tmp/etc-`date +%Y-%m-%d`
|
#ls -ld /tmp/etc*
drwxr-xr-x 103 root root 12288 Mar 29 17:51 /tmp/etc-2011-03-29 |
#echo d e f | mkdir
mkdir: missing operand Try `mkdir --help' for more information. |
#echo d e f | xargs mkdir
|
#ls -l
total 36 drwxr-xr-x 2 root root 4096 Mar 29 17:49 17:49:26 drwxr-xr-x 2 root root 4096 Mar 29 17:54 a drwxr-xr-x 2 root root 4096 Mar 29 17:54 b drwxr-xr-x 2 root root 4096 Mar 29 17:54 c drwxr-xr-x 2 root root 4096 Mar 29 17:54 d drwxr-xr-x 2 root root 4096 Mar 29 17:54 e drwxr-xr-x 2 root root 4096 Mar 29 17:54 f drwxr-xr-x 2 root root 4096 Mar 29 17:50 My documents drwxr-xr-x 2 root root 4096 Mar 29 17:50 Tue Mar 29 17:50:15 ALMT 2011 |
#rm -rf *
|
#mkdir a b c
|
#ls -l
total 12 drwxr-xr-x 2 root root 4096 Mar 29 17:54 a drwxr-xr-x 2 root root 4096 Mar 29 17:54 b drwxr-xr-x 2 root root 4096 Mar 29 17:54 c |
#echo d e f | mkdir
mkdir: missing operand Try `mkdir --help' for more information. bash: echo: write error: Broken pipe |
#ls -l
total 12 drwxr-xr-x 2 root root 4096 Mar 29 17:54 a drwxr-xr-x 2 root root 4096 Mar 29 17:54 b drwxr-xr-x 2 root root 4096 Mar 29 17:54 c |
#echo d e f | xargs mkdir
|
#echo /*/*/*/* | wc
1 23180 778289 |
#echo /*/*/*/*/* | wc
1 378675 11390006 |
#cp /*/*/*/*/* /backup
bash: /bin/cp: Argument list too long |
#read A
20 |
#echo 2+2
2+2 |
#echo $((2+2))
4 |
#A=$((A+1))
|
#echo $A
21 |
#echo ~
/root |
#echo ~user
/home/user |
#vim f
|
#~
|
#vim f
|
#unset A
|
#. A
bash: A: No such file or directory |
#. f
|
#echo $A
10 |
#unset A
|
#echo $A
|
#source f
|
#echo $A
10 |
#unset A
|
#sh f
|
#echo $A
|
#echo $SHELL
/bin/bash |
#rpm -qa | grep glibc
compat-glibc-2.3.4-2.26 glibc-common-2.5-49 glibc-2.5-49 glibc-2.5-49 compat-glibc-headers-2.3.4-2.26 compat-glibc-2.3.4-2.26 |
$pwd
/home/user |
$ls
Desktop typescript |
$touch {report,memo,graph}_{sep,oct,nov,dec}_{a,b,c}_{1,2,3}
|
$ls -l
total 8 drwxr-xr-x 2 user user 4096 Mar 28 10:46 Desktop -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_a_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_a_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_a_3 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_b_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_b_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_b_3 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_c_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_c_2 ... -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_a_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_a_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_a_3 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_b_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_b_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_b_3 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_c_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_c_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_sep_c_3 -rw-rw-r-- 1 user user 503 Mar 28 10:54 typescript |
$mkdir a_reports
|
$mkdir september october november december
|
$ls
a_reports graph_oct_a_3 memo_dec_c_2 memo_sep_b_1 report_nov_c_1 december graph_oct_b_1 memo_dec_c_3 memo_sep_b_2 report_nov_c_2 Desktop graph_oct_b_2 memo_nov_a_1 memo_sep_b_3 report_nov_c_3 graph_dec_a_1 graph_oct_b_3 memo_nov_a_2 memo_sep_c_1 report_oct_a_1 graph_dec_a_2 graph_oct_c_1 memo_nov_a_3 memo_sep_c_2 report_oct_a_2 graph_dec_a_3 graph_oct_c_2 memo_nov_b_1 memo_sep_c_3 report_oct_a_3 graph_dec_b_1 graph_oct_c_3 memo_nov_b_2 november report_oct_b_1 graph_dec_b_2 graph_sep_a_1 memo_nov_b_3 october report_oct_b_2 graph_dec_b_3 graph_sep_a_2 memo_nov_c_1 report_dec_a_1 report_oct_b_3 graph_dec_c_1 graph_sep_a_3 memo_nov_c_2 report_dec_a_2 report_oct_c_1 ... graph_nov_a_2 graph_sep_c_1 memo_oct_a_3 report_dec_b_3 report_sep_a_2 graph_nov_a_3 graph_sep_c_2 memo_oct_b_1 report_dec_c_1 report_sep_a_3 graph_nov_b_1 graph_sep_c_3 memo_oct_b_2 report_dec_c_2 report_sep_b_1 graph_nov_b_2 memo_dec_a_1 memo_oct_b_3 report_dec_c_3 report_sep_b_2 graph_nov_b_3 memo_dec_a_2 memo_oct_c_1 report_nov_a_1 report_sep_b_3 graph_nov_c_1 memo_dec_a_3 memo_oct_c_2 report_nov_a_2 report_sep_c_1 graph_nov_c_2 memo_dec_b_1 memo_oct_c_3 report_nov_a_3 report_sep_c_2 graph_nov_c_3 memo_dec_b_2 memo_sep_a_1 report_nov_b_1 report_sep_c_3 graph_oct_a_1 memo_dec_b_3 memo_sep_a_2 report_nov_b_2 september graph_oct_a_2 memo_dec_c_1 memo_sep_a_3 report_nov_b_3 typescript |
$ls | arm {$1=d}
bash: arm: command not found |
$ls -l | grep ^d
drwxrwxr-x 2 user user 4096 Mar 29 18:15 a_reports drwxrwxr-x 2 user user 4096 Mar 29 18:15 december drwxr-xr-x 2 user user 4096 Mar 28 10:46 Desktop drwxrwxr-x 2 user user 4096 Mar 29 18:15 november drwxrwxr-x 2 user user 4096 Mar 29 18:15 october drwxrwxr-x 2 user user 4096 Mar 29 18:15 september |
$cd a_reports/
|
$mkdir one two three
|
$ls
one three two |
$cd
|
$ls
a_reports graph_oct_a_3 memo_dec_c_2 memo_sep_b_1 report_nov_c_1 december graph_oct_b_1 memo_dec_c_3 memo_sep_b_2 report_nov_c_2 Desktop graph_oct_b_2 memo_nov_a_1 memo_sep_b_3 report_nov_c_3 graph_dec_a_1 graph_oct_b_3 memo_nov_a_2 memo_sep_c_1 report_oct_a_1 graph_dec_a_2 graph_oct_c_1 memo_nov_a_3 memo_sep_c_2 report_oct_a_2 graph_dec_a_3 graph_oct_c_2 memo_nov_b_1 memo_sep_c_3 report_oct_a_3 graph_dec_b_1 graph_oct_c_3 memo_nov_b_2 november report_oct_b_1 graph_dec_b_2 graph_sep_a_1 memo_nov_b_3 october report_oct_b_2 graph_dec_b_3 graph_sep_a_2 memo_nov_c_1 report_dec_a_1 report_oct_b_3 graph_dec_c_1 graph_sep_a_3 memo_nov_c_2 report_dec_a_2 report_oct_c_1 ... graph_nov_a_2 graph_sep_c_1 memo_oct_a_3 report_dec_b_3 report_sep_a_2 graph_nov_a_3 graph_sep_c_2 memo_oct_b_1 report_dec_c_1 report_sep_a_3 graph_nov_b_1 graph_sep_c_3 memo_oct_b_2 report_dec_c_2 report_sep_b_1 graph_nov_b_2 memo_dec_a_1 memo_oct_b_3 report_dec_c_3 report_sep_b_2 graph_nov_b_3 memo_dec_a_2 memo_oct_c_1 report_nov_a_1 report_sep_b_3 graph_nov_c_1 memo_dec_a_3 memo_oct_c_2 report_nov_a_2 report_sep_c_1 graph_nov_c_2 memo_dec_b_1 memo_oct_c_3 report_nov_a_3 report_sep_c_2 graph_nov_c_3 memo_dec_b_2 memo_sep_a_1 report_nov_b_1 report_sep_c_3 graph_oct_a_1 memo_dec_b_3 memo_sep_a_2 report_nov_b_2 september graph_oct_a_2 memo_dec_c_1 memo_sep_a_3 report_nov_b_3 typescript |
$pwd
/home/user |
$ls -l *dec_b_?
-rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_b_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_b_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 graph_dec_b_3 -rw-rw-r-- 1 user user 0 Mar 29 18:14 memo_dec_b_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 memo_dec_b_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 memo_dec_b_3 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_dec_b_1 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_dec_b_2 -rw-rw-r-- 1 user user 0 Mar 29 18:14 report_dec_b_3 |
$mv graph_dec_
graph_dec_a_1 graph_dec_a_3 graph_dec_b_2 graph_dec_c_1 graph_dec_c_3 graph_dec_a_2 graph_dec_b_1 graph_dec_b_3 graph_dec_c_2 |
$mv graph_dec_b_1 december/
|
$mv *dec_b_? december/
|
$ls
a_reports graph_oct_b_2 memo_nov_a_3 memo_sep_c_1 report_oct_a_3 december graph_oct_b_3 memo_nov_b_1 memo_sep_c_2 report_oct_b_1 Desktop graph_oct_c_1 memo_nov_b_2 memo_sep_c_3 report_oct_b_2 graph_dec_a_1 graph_oct_c_2 memo_nov_b_3 november report_oct_b_3 graph_dec_a_2 graph_oct_c_3 memo_nov_c_1 october report_oct_c_1 graph_dec_a_3 graph_sep_a_1 memo_nov_c_2 report_dec_a_1 report_oct_c_2 graph_dec_c_1 graph_sep_a_2 memo_nov_c_3 report_dec_a_2 report_oct_c_3 graph_dec_c_2 graph_sep_a_3 memo_oct_a_1 report_dec_a_3 report_sep_a_1 graph_dec_c_3 graph_sep_b_1 memo_oct_a_2 report_dec_c_1 report_sep_a_2 graph_nov_a_1 graph_sep_b_2 memo_oct_a_3 report_dec_c_2 report_sep_a_3 ... graph_nov_b_1 graph_sep_c_2 memo_oct_b_3 report_nov_a_2 report_sep_b_3 graph_nov_b_2 graph_sep_c_3 memo_oct_c_1 report_nov_a_3 report_sep_c_1 graph_nov_b_3 memo_dec_a_1 memo_oct_c_2 report_nov_b_1 report_sep_c_2 graph_nov_c_1 memo_dec_a_2 memo_oct_c_3 report_nov_b_2 report_sep_c_3 graph_nov_c_2 memo_dec_a_3 memo_sep_a_1 report_nov_b_3 september graph_nov_c_3 memo_dec_c_1 memo_sep_a_2 report_nov_c_1 typescript graph_oct_a_1 memo_dec_c_2 memo_sep_a_3 report_nov_c_2 graph_oct_a_2 memo_dec_c_3 memo_sep_b_1 report_nov_c_3 graph_oct_a_3 memo_nov_a_1 memo_sep_b_2 report_oct_a_1 graph_oct_b_1 memo_nov_a_2 memo_sep_b_3 report_oct_a_2 |
Время первой команды журнала | 13:43:02 2011- 3-29 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Время последней команды журнала | 14:21:31 2011- 3-29 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в журнале | 101 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Процент команд с ненулевым кодом завершения, % | 11.88 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Процент синтаксически неверно набранных команд, % | 0.99 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Суммарное время работы с терминалом *, час | 0.64 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в единицу времени, команда/мин | 2.62 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду 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