Журнал лабораторных работ

Содержание

Журнал

Четверг (03/10/11)

/dev/pts/1
12:06:31
#wget http://xgu.ru/lilalo/lilalo.tar.gz
--2011-03-10 13:07:06--  http://xgu.ru/lilalo/lilalo.tar.gz
Распознаётся xgu.ru... 91.205.16.235
Устанавливается соединение с xgu.ru|91.205.16.235|:80... соединение установлено.
Запрос HTTP послан, ожидается ответ... 200 OK
Длина: 151793 (148K) [application/x-gzip]
Saving to: «lilalo.tar.gz»
100%[======================================>] 151 793     --.-K/s   в 0,1s
2011-03-10 13:07:06 (1,03 MB/s) - «lilalo.tar.gz» saved [151793/151793]
/dev/pts/0
12:06:31
#wget http://xgu.ru/lilalo/lilalo.tar.gz
--2011-03-10 13:07:06--  http://xgu.ru/lilalo/lilalo.tar.gz
Распознаётся xgu.ru... 91.205.16.235
Устанавливается соединение с xgu.ru|91.205.16.235|:80... соединение установлено.
Запрос HTTP послан, ожидается ответ... 200 OK
Длина: 151793 (148K) [application/x-gzip]
Saving to: «lilalo.tar.gz»
100%[======================================>] 151 793     --.-K/s   в 0,1s
2011-03-10 13:07:06 (1,03 MB/s) - «lilalo.tar.gz» saved [151793/151793]
/dev/pts/0
12:15:29
#screen -x
12:15:33
#screen
/dev/pts/2
12:15:38
#ls /etc
adduser.conf            group-          magic           rc.local
alternatives            gshadow         magic.mime      rcS.d
apt                     gshadow-        mailcap         resolv.conf
bash.bashrc             host.conf       mailcap.order   rmt
bash_completion         hostname        manpath.config  rpc
bash_completion.d       hosts           mime.types      rsyslog.conf
bindresvport.blacklist  hosts.allow     mke2fs.conf     rsyslog.d
ca-certificates         hosts.deny      modprobe.d      samba
ca-certificates.conf    init.d          modules         screenrc
calendar                inittab         motd            securetty
...
deluser.conf            lilalo          profile         ucf.conf
dhcp                    locale.alias    profile.d       udev
dhcp3                   locale.gen      protocols       ufw
dpkg                    localtime       rc0.d           vim
environment             logcheck        rc1.d           w3m
fonts                   login.defs      rc2.d           wgetrc
fstab                   logrotate.conf  rc3.d           X11
gai.conf                logrotate.d     rc4.d
groff                   lsb-base        rc5.d
group                   lynx-cur        rc6.d
12:15:40
#ls /etc/a[bcd]*
/etc/adduser.conf
12:16:02
#ls /etc/a{bcd}*
ls: невозможно получить доступ к /etc/a{bcd}*: Нет такого файла или каталога
12:17:31
#ls /etc/a{b,c,d}*
ls: невозможно получить доступ к /etc/ab*: Нет такого файла или каталога
ls: невозможно получить доступ к /etc/ac*: Нет такого файла или каталога
/etc/adduser.conf
12:17:46
#echo `ls /etc` > file

12:22:18
#vim file
12:22:27
#~
cat: adduser.conf: Нет такого файла или каталога
cat: alternatives: Нет такого файла или каталога
cat: apt: Нет такого файла или каталога
cat: bash.bashrc: Нет такого файла или каталога
cat: bash_completion: Нет такого файла или каталога
cat: bash_completion.d: Нет такого файла или каталога
cat: bindresvport.blacklist: Нет такого файла или каталога
cat: ca-certificates: Нет такого файла или каталога
cat: ca-certificates.conf: Нет такого файла или каталога
cat: calendar: Нет такого файла или каталога
...
cat: sysctl.d: Нет такого файла или каталога
cat: terminfo: Нет такого файла или каталога
cat: timezone: Нет такого файла или каталога
cat: ucf.conf: Нет такого файла или каталога
cat: udev: Нет такого файла или каталога
cat: ufw: Нет такого файла или каталога
cat: vim: Нет такого файла или каталога
cat: w3m: Нет такого файла или каталога
cat: wgetrc: Нет такого файла или каталога
cat: X11: Нет такого файла или каталога
12:22:33
#echo "date `date -%Y`"
date: неверный ключ -- %
Попробуйте `date --help' для получения более подробного описания.
date
12:23:40
#echo `date -%Y`
date: неверный ключ -- %
Попробуйте `date --help' для получения более подробного описания.
12:23:49
#date -%Y
date: неверный ключ -- %
Попробуйте `date --help' для получения более подробного описания.
12:23:54
#date -%Y
date: неверный ключ -- %
Попробуйте `date --help' для получения более подробного описания.
12:24:00
#date -%y
date: неверный ключ -- %
Попробуйте `date --help' для получения более подробного описания.
12:24:02
#date
Чтв Мар 10 13:24:04 EET 2011
12:24:04
#vim 12
--- /dev/null	2011-03-09 10:27:44.262550540 +0200
+++ 12	2011-03-10 13:25:33.218599037 +0200
@@ -0,0 +1,3 @@
+folde1
+folde2
+folde3
12:25:33
#mkdir `cat 12`

12:25:44
#ls
12    file1   folde2  hard           hello-vi.txt   lilalo.tar.gz
file  folde1  folde3  hello-vi1.txt  hello-vi.txt!  link
12:25:45
#du -sh $(find / -name wilen)
6,1M    .
12:27:15
#du -sh $(find / -name sid)
6,1M    .
12:27:26
#du -sh $(find / -name root)
6,1M    /root
0       /dev/root
0       /dev/.udev/links/root
0       /proc/1/task/1/root
0       /proc/1/root
0       /proc/2/task/2/root
0       /proc/2/root
0       /proc/3/task/3/root
0       /proc/3/root
0       /proc/4/task/4/root
...
0       /proc/8424/task/8424/root
0       /proc/8424/root
0       /proc/8425/task/8425/root
0       /proc/8425/root
0       /proc/8466/task/8466/root
0       /proc/8466/root
0       /proc/8467/task/8467/root
0       /proc/8467/root
du: невозможно получить доступ к «/proc/8690/task/8690/root»: Нет такого файла или каталога
du: невозможно получить доступ к «/proc/8690/root»: Нет такого файла или каталога
12:27:35
#cd

12:27:39
#a=1

12:28:55
#b=8

12:29:00
#echo $((a+b))
9
12:29:07
#echo $((a/b))
0
12:29:16
#echo $((a*b))
8
12:29:27
#a=4

12:29:35
#echo $((a*b))
32
12:29:37
#~
bash: /root: является директорией
12:30:07
#~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:07
#~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:07
#~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:07
#~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:07
#cd

12:30:21
#su user

12:30:25
$cd

12:30:27
$~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:27
$~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:27
$cd /

12:30:46
$~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:46
$~
~backup/     ~gnats       ~lp          ~news        ~sshd/       ~uucp
~bin/        ~irc         ~mail/       ~nobody      ~sync/       ~www-data
~daemon/     ~libuuid/    ~man/        ~proxy/      ~sys/
~games/      ~list        ~messagebus/ ~root/       ~user/
12:30:46
$cd

12:33:41
$ls /etc/a{b,c,d}*
ls: невозможно получить доступ к /etc/ab*: Нет такого файла или каталога
ls: невозможно получить доступ к /etc/ac*: Нет такого файла или каталога
/etc/adduser.conf
12:36:19
$ls /etc/a{b,c,d}* 2>/dev/null
/etc/adduser.conf
12:36:33
$ls
passwd
12:36:59
$vim 12
12:37:46
$mkdir < 12
mkdir: пропущен операнд
Попробуйте `mkdir --help' для получения более подробного описания.
12:37:51
$ls
12  passwd
12:37:52
$ls
12  passwd
12:37:56
$touch < 12
touch: пропущен операнд, задающий файл
Попробуйте `touch --help' для получения более подробного описания.
12:38:03
$mv 12 ab

12:38:16
$touch < ab
touch: пропущен операнд, задающий файл
Попробуйте `touch --help' для получения более подробного описания.
12:38:19
$touch <ab
touch: пропущен операнд, задающий файл
Попробуйте `touch --help' для получения более подробного описания.
12:38:31
$touch
ab             .bash_logout   .bashrc        .lilalo/       .profile
.bash_history  .bash_profile  .l3rc          passwd         .viminfo
12:38:31
$touch `cat ab`

12:38:42
$history
    1  l3 pwd
    2  exit
    3  cd
    4  ls
    5  vim passwd
    6  view passwd
    7  ex passwd
    8  exit
    9  pwd
   10  cd
...
   29  ls
   30  vim 12
   31  mkdir < 12
   32  ls
   33  touch < 12
   34  mv 12 ab
   35  touch < ab
   36*
   37  touch `cat ab`
   38  history
12:39:37
$history > file

12:39:45
$vim file
12:41:42
$ls /etc | grep apt | sort
apt
12:42:06
$ls /etc | grep m* | sort
adduser.conf
alternatives
apt
bash.bashrc
bash_completion
bash_completion.d
bindresvport.blacklist
ca-certificates
ca-certificates.conf
calendar
...
sysctl.d
terminfo
timezone
ucf.conf
udev
ufw
vim
w3m
wgetrc
X11
12:42:12
$ls /etc | egrep '^m*' | sort
adduser.conf
alternatives
apt
bash.bashrc
bash_completion
bash_completion.d
bindresvport.blacklist
ca-certificates
ca-certificates.conf
calendar
...
sysctl.d
terminfo
timezone
ucf.conf
udev
ufw
vim
w3m
wgetrc
X11
12:43:33
$ls /etc/a{b,c,d}* 1>file
ls: невозможно получить доступ к /etc/ab*: Нет такого файла или каталога
ls: невозможно получить доступ к /etc/ac*: Нет такого файла или каталога
12:44:02
$ls /etc/a{b,c,d}* 1>file 2>/dev/null

12:44:25
$ls
ab  dir1  file  folder1  passwd
12:45:01
$ab > echo
bash: ab: команда не найдена
12:45:05
$cat > 123
fadfja;f
fas;dfjkas;f
;lfakjaf;
12:47:08
$vim 123
12:47:16
$~
123  ab  dir1  echo  file  folder1  passwd
12:47:17
$touch A:\\System\\32

прошло 43 минуты
13:30:56
$ls
123  ab  A:\System\32  dir1  echo  file  folder1  passwd
13:30:57
$ls \?*
ls: невозможно получить доступ к ?*: Нет такого файла или каталога
13:35:35
$ls
123  ab  A:\System\32  dir1  echo  file  folder1  passwd
13:35:37
$cd

прошло 82 минуты
14:58:26
$exit
exit
/dev/pts/0
14:59:20
#screen
/dev/pts/3
14:59:25
#alias exit=echo 'no exit'
bash: alias: no exit: не найден
/dev/pts/6
14:59:29
#screen -x
/dev/pts/3
14:59:37
#alias exit='echo no exit'

14:59:48
#exit
no exit

Суббота (03/12/11)

/dev/hvc0
09:14:55
#chmod -x /bin/chmod

09:15:05
#ls -la
итого 40
drwx------  3 root root 4096 Мар  7 14:17 .
drwxr-xr-x 21 root root 4096 Мар  5 14:48 ..
-rw-------  1 root root 2145 Мар  7 14:17 .bash_history
-rw-r--r--  1 root root   21 Мар  7 14:15 .bash_profile
-rw-r--r--  1 root root  631 Мар  7 13:41 .bashrc
-rw-r--r--  1 root root   51 Мар 10 16:27 .l3rc
drwxr-xr-x  2 root root 4096 Мар 12 08:14 .lilalo
-rw-r--r--  1 root root  140 Ноя 19  2007 .profile
-rw-------  1 root root 4683 Мар  7 14:17 .viminfo
09:15:14
#touch 111

09:15:18
#ls
111
09:15:21
#ls -l
итого 0
-rw-r--r-- 1 root root 0 Мар 12 08:15 111
09:15:22
#chmod +x 111
bash: /bin/chmod: Отказано в доступе
09:15:35
#ls
111
09:15:37
#/lib/ld-linux.so.2 /bin/chmod +x /bin/chmod

09:16:01
#ls
111
09:16:02
#ls -l
итого 0
-rwxr-xr-x 1 root root 0 Мар 12 08:15 111

Понедельник (04/11/11)

/dev/hvc0
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:19
#apt-get vim
E: Неверная операция vim
11:10:22
#apt-get update
Получено:1 http://ftp.ua.debian.org squeeze Release.gpg [1 671 B]
Игн http://ftp.ua.debian.org/debian/ squeeze/main Translation-en
Игн http://ftp.ua.debian.org/debian/ squeeze/main Translation-ru
Получено:2 http://ftp.ua.debian.org squeeze Release [79,8 kB]
Получено:3 http://ftp.ua.debian.org squeeze/main i386 Packages [8 633 kB]
Получено 8 714 kБ за 10с (810 kБ/c)
Чтение списков пакетов... Готово
11:10:22
#apt-get update
Получено:1 http://ftp.ua.debian.org squeeze Release.gpg [1 671 B]
Игн http://ftp.ua.debian.org/debian/ squeeze/main Translation-en
Игн http://ftp.ua.debian.org/debian/ squeeze/main Translation-ru
Получено:2 http://ftp.ua.debian.org squeeze Release [79,8 kB]
Получено:3 http://ftp.ua.debian.org squeeze/main i386 Packages [8 633 kB]
Получено 8 714 kБ за 10с (810 kБ/c)
Чтение списков пакетов... Готово

Файлы

  • 123
  • 123
    >
    fadfja;f
    fas;dfjkas;f
    ;lfakjaf;
    

    Статистика

    Время первой команды журнала12:06:31 2011- 3-10
    Время последней команды журнала11:10:22 2011- 4-11
    Количество командных строк в журнале101
    Процент команд с ненулевым кодом завершения, %33.66
    Процент синтаксически неверно набранных команд, % 0.99
    Суммарное время работы с терминалом *, час 0.80
    Количество командных строк в единицу времени, команда/мин 2.10
    Частота использования команд
    ls25|=====================| 21.01%
    ~11|=========| 9.24%
    apt-get9|=======| 7.56%
    echo8|======| 6.72%
    touch7|=====| 5.88%
    cd6|=====| 5.04%
    vim5|====| 4.20%
    screen4|===| 3.36%
    file4|===| 3.36%
    date4|===| 3.36%
    sort3|==| 2.52%
    ab3|==| 2.52%
    du3|==| 2.52%
    alias2|=| 1.68%
    mkdir2|=| 1.68%
    wget2|=| 1.68%
    null2|=| 1.68%
    chmod2|=| 1.68%
    122|=| 1.68%
    history2|=| 1.68%
    grep2|=| 1.68%
    exit2|=| 1.68%
    egrep1|| 0.84%
    a=11|| 0.84%
    b=81|| 0.84%
    1231|| 0.84%
    ld-linux.so.21|| 0.84%
    cat1|| 0.84%
    mv1|| 0.84%
    su1|| 0.84%
    a=41|| 0.84%
    ____
    *) Интервалы неактивности длительностью 30 минут и более не учитываются

    Справка

    Для того чтобы использовать LiLaLo, не нужно знать ничего особенного: всё происходит само собой. Однако, чтобы ведение и последующее использование журналов было как можно более эффективным, желательно иметь в виду следующее:
    1. В журнал автоматически попадают все команды, данные в любом терминале системы.

    2. Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду w. В поле WHAT, соответствующем текущему терминалу, должна быть указана программа script.

    3. Команды, при наборе которых были допущены синтаксические ошибки, выводятся перечёркнутым текстом:
      $ l s-l
      bash: l: command not found
      

    4. Если код завершения команды равен нулю, команда была выполнена без ошибок. Команды, код завершения которых отличен от нуля, выделяются цветом.
      $ test 5 -lt 4
      Обратите внимание на то, что код завершения команды может быть отличен от нуля не только в тех случаях, когда команда была выполнена с ошибкой. Многие команды используют код завершения, например, для того чтобы показать результаты проверки

    5. Команды, ход выполнения которых был прерван пользователем, выделяются цветом.
      $ 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
      

    6. Команды, выполненные с привилегиями суперпользователя, выделяются слева красной чертой.
      # id
      uid=0(root) gid=0(root) Gruppen=0(root)
      

    7. Изменения, внесённые в текстовый файл с помощью редактора, запоминаются и показываются в журнале в формате ed. Строки, начинающиеся символом "<", удалены, а строки, начинающиеся символом ">" -- добавлены.
      $ vi ~/.bashrc
      2a3,5
      >    if [ -f /usr/local/etc/bash_completion ]; then
      >         . /usr/local/etc/bash_completion
      >        fi
      

    8. Для того чтобы изменить файл в соответствии с показанными в диффшоте изменениями, можно воспользоваться командой patch. Нужно скопировать изменения, запустить программу patch, указав в качестве её аргумента файл, к которому применяются изменения, и всавить скопированный текст:
      $ patch ~/.bashrc
      В данном случае изменения применяются к файлу ~/.bashrc

    9. Для того чтобы получить краткую справочную информацию о команде, нужно подвести к ней мышь. Во всплывающей подсказке появится краткое описание команды.

      Если справочная информация о команде есть, команда выделяется голубым фоном, например: vi. Если справочная информация отсутствует, команда выделяется розовым фоном, например: notepad.exe. Справочная информация может отсутствовать в том случае, если (1) команда введена неверно; (2) если распознавание команды LiLaLo выполнено неверно; (3) если информация о команде неизвестна LiLaLo. Последнее возможно для редких команд.

    10. Большие, в особенности многострочные, всплывающие подсказки лучше всего показываются браузерами KDE Konqueror, Apple Safari и Microsoft Internet Explorer. В браузерах Mozilla и Firefox они отображаются не полностью, а вместо перевода строки выводится специальный символ.

    11. Время ввода команды, показанное в журнале, соответствует времени начала ввода командной строки, которое равно тому моменту, когда на терминале появилось приглашение интерпретатора

    12. Имя терминала, на котором была введена команда, показано в специальном блоке. Этот блок показывается только в том случае, если терминал текущей команды отличается от терминала предыдущей.

    13. Вывод не интересующих вас в настоящий момент элементов журнала, таких как время, имя терминала и других, можно отключить. Для этого нужно воспользоваться формой управления журналом вверху страницы.

    14. Небольшие комментарии к командам можно вставлять прямо из командной строки. Комментарий вводится прямо в командную строку, после символов #^ или #v. Символы ^ и v показывают направление выбора команды, к которой относится комментарий: ^ - к предыдущей, v - к следующей. Например, если в командной строке было введено:

      $ whoami
      
      user
      
      $ #^ Интересно, кто я?
      
      в журнале это будет выглядеть так:
      $ whoami
      
      user
      
      Интересно, кто я?

    15. Если комментарий содержит несколько строк, его можно вставить в журнал следующим образом:

      $ whoami
      
      user
      
      $ cat > /dev/null #^ Интересно, кто я?
      
      Программа whoami выводит имя пользователя, под которым 
      мы зарегистрировались в системе.
      -
      Она не может ответить на вопрос о нашем назначении 
      в этом мире.
      
      В журнале это будет выглядеть так:
      $ whoami
      user
      
      Интересно, кто я?
      Программа whoami выводит имя пользователя, под которым
      мы зарегистрировались в системе.

      Она не может ответить на вопрос о нашем назначении
      в этом мире.
      Для разделения нескольких абзацев между собой используйте символ "-", один в строке.

    16. Комментарии, не относящиеся непосредственно ни к какой из команд, добавляются точно таким же способом, только вместо симолов #^ или #v нужно использовать символы #=

    17. Содержимое файла может быть показано в журнале. Для этого его нужно вывести с помощью программы cat. Если вывод команды отметить симоволами #!, содержимое файла будет показано в журнале в специально отведённой для этого секции.
    18. Для того чтобы вставить скриншот интересующего вас окна в журнал, нужно воспользоваться командой l3shot. После того как команда вызвана, нужно с помощью мыши выбрать окно, которое должно быть в журнале.
    19. Команды в журнале расположены в хронологическом порядке. Если две команды давались одна за другой, но на разных терминалах, в журнале они будут рядом, даже если они не имеют друг к другу никакого отношения.
      1
          2
      3   
          4
      
      Группы команд, выполненных на разных терминалах, разделяются специальной линией. Под этой линией в правом углу показано имя терминала, на котором выполнялись команды. Для того чтобы посмотреть команды только одного сенса, нужно щёкнуть по этому названию.

    О программе

    LiLaLo (L3) расшифровывается как Live Lab Log.
    Программа разработана для повышения эффективности обучения Unix/Linux-системам.
    (c) Игорь Чубин, 2004-2008

    $Id$