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

Содержание

Журнал

Среда (10/17/12)

/dev/pts/0
11:36:59
$mycp
bash: mycp: команда не найдена
11:37:06
$./mycp
./mycp: пропущен операнд, задающий файл
Попробуйте `cp --help' для получения более подробного описания../mycp: пропущен операнд задающий целевой файл
11:37:10
$./mycp
./mycp: пропущен операнд, задающий файл
Попробуйте `cp --help' для получения более подробного описания../mycp: пропущен операнд задающий целевой файл
11:37:50
$./mycp
./mycp: пропущен операнд, задающий файл
11:39:35
$./mycp

11:39:59
$./mycp

11:40:23
$./mycp

11:40:26
$./mycp eee
./mycp: пропущен операнд задающий целевой файл
11:41:31
$./mycp eee
./mycp: пропущен операнд задающий целевой файл
11:42:39
$./mycp eee
./mycp: пропущен операнд задающий целевой файл
11:43:12
$./mycp eee
./mycp: пропущен операнд задающий целевой файл
11:43:18
$./mycp

11:44:11
$./mycp

11:44:14
$./mycp

11:45:33
$./mycp

11:45:34
$./mycp trt
./mycp: пропущен операнд задающий целевой файл
11:45:37
$./mycp trt

11:47:06
$./mycp

11:47:13
$man -k printf
11:49:08
$man 1 printf
11:49:40
$Top of buffer.
   Format of the format string
       The format string is a character string, beginning and ending in its initial shift state, if any.  The format string is composed of zero or more directives: ordinary  char‐
       acters  (not  %), which are copied unchanged to the output stream; and conversion specifications, each of which results in fetching zero or more subsequent arguments.  Each
       conversion specification is introduced by the character %, and ends with a conversion specifier.  In between there may be (in this order) zero or more  flags,  an  optional
       minimum field width, an optional precision and an optional length modifier.
       The arguments must correspond properly (after type promotion) with the conversion specifier.  By default, the arguments are used in the order given, where each '*' and each
       conversion specifier asks for the next argument (and it is an error if insufficiently many arguments are given).  One can also specify explicitly which argument  is  taken,
       at each place where an argument is required, by writing "%m$" instead of '%' and "*m$" instead of '*', where the decimal integer m denotes the position in the argument list
       of the desired argument, indexed starting from 1.  Thus,
           printf("%*d", width, num);
...
Reading...
       Many countries use the day-month-year order.  Hence, an internationalized version must be able to print the arguments in an order specified by the format:
           #include <stdio.h>
           fprintf(stdout, format,
                   weekday, month, day, hour, min);
       where format depends on locale, and may permute the arguments.  With the value:
           "%1$s, %3$d. %2$s, %4$d:%5$.2d\n"
       one might obtain "Sonntag, 3. Juli, 10:02".
       To allocate a sufficiently large string and print into it (code correct for both glibc 2.0 and glibc 2.1):
       #include <stdio.h>
11:51:51
$-- MOST: *stdin* (265,1) 91%
       printf, fprintf, sprintf, snprintf, vprintf, vfprintf, vsprintf, vsnprintf - formatted output conversion
NAME
       #include <stdio.h>
SYNOPSIS
       int printf(const char *format, ...);
       int fprintf(FILE *stream, const char *format, ...);
       int sprintf(char *str, const char *format, ...);
       int snprintf(char *str, size_t size, const char *format, ...);
       #include <stdarg.h>
       int vprintf(const char *format, va_list ap);
-- MOST: *stdin*                                                                                                                                                            (1,1) 0%
11:52:23
$Press `Q' to quit, `H' for help, and SPACE to scroll.

11:52:26
$./mycp

11:52:59
$./mycp

11:53:01
$./mycp rr

11:53:03
$./mycp rr

11:54:32
$ls
inputfile  mycp  mycp.c  mycp.o  ruscheckers  ruscheckers.c  ruscheckers.o
11:55:53
$./mycp

11:56:02
$ls -al
итого 48
drwx------ 2 ol14 ol14 4096 Окт 17 15:54 .
drwxr-xr-x 5 ol14 ol14 4096 Сен 24 10:58 ..
-rw-r--r-- 1 ol14 ol14   35 Окт 17 15:16 inputfile
-rwxr-xr-x 1 ol14 ol14 4496 Окт 17 15:54 mycp
-rw-r--r-- 1 ol14 ol14  148 Окт 17 15:54 mycp.c
-rw-r--r-- 1 ol14 ol14  840 Окт 17 15:54 mycp.o
-rwxr-xr-x 1 ol14 ol14 6152 Сен 21 14:29 ruscheckers
-rw-r--r-- 1 ol14 ol14 4359 Сен 21 14:28 ruscheckers.c
-rw-r--r-- 1 ol14 ol14 2492 Сен 21 14:29 ruscheckers.o

Четверг (10/18/12)

/dev/pts/0
06:07:34
$nslookup ya.ru
;; connection timed out; no servers could be reached
06:07:59
$ping 192.168.0.1
PING 192.168.0.1 (192.168.0.1) 56(84) bytes of data.
From 192.168.0.127 icmp_seq=1 Destination Host Unreachable
From 192.168.0.127 icmp_seq=2 Destination Host Unreachable
From 192.168.0.127 icmp_seq=3 Destination Host Unreachable
From 192.168.0.127 icmp_seq=4 Destination Host Unreachable
From 192.168.0.127 icmp_seq=5 Destination Host Unreachable
From 192.168.0.127 icmp_seq=6 Destination Host Unreachable
From 192.168.0.127 icmp_seq=7 Destination Host Unreachable
From 192.168.0.127 icmp_seq=8 Destination Host Unreachable
From 192.168.0.127 icmp_seq=9 Destination Host Unreachable
...
From 192.168.0.127 icmp_seq=80 Destination Host Unreachable
From 192.168.0.127 icmp_seq=81 Destination Host Unreachable
From 192.168.0.127 icmp_seq=82 Destination Host Unreachable
From 192.168.0.127 icmp_seq=83 Destination Host Unreachable
From 192.168.0.127 icmp_seq=84 Destination Host Unreachable
From 192.168.0.127 icmp_seq=85 Destination Host Unreachable
From 192.168.0.127 icmp_seq=86 Destination Host Unreachable
From 192.168.0.127 icmp_seq=87 Destination Host Unreachable
^Z
[1]+  Stopped                 ping 192.168.0.1
06:11:25
$ping ya.ru
ping: unknown host ya.ru
06:11:53
$ping ya.ru
^Z
[2]+  Stopped                 ping ya.ru
06:14:56
$ifconfig -a
bash: ifconfig: команда не найдена
06:15:13
$ipconfig -a
bash: ipconfig: команда не найдена
прошло >6 часов
/dev/pts/4
12:17:15
$cd progect/KiR
bash: cd: progect/KiR: Нет такого файла или каталога
12:17:28
$cd project/KiR

12:17:45
$ls
chapter1-9  chapter1-9.geany  checkers  checkers.geany  GTK1  GTK1.geany
12:17:47
$cd checkers

12:17:59
$ls
inputfile  mycp  mycp.c  mycp.o  ruscheckers  ruscheckers.c  ruscheckers.o
12:18:21
$cp
cp: пропущен операнд, задающий файл
Попробуйте `cp --help' для получения более подробного описания.
12:18:55
$./mycp

12:23:44
$./mycp

12:23:54
$./mycp

12:24:01
$./mycp

12:24:09
$./mycp
./mycp: пропущен операнд, задающий файл
12:25:02
$./mycp
./mycp: пропущен операнд, задающий файл
12:30:52
$./mycp

прошло 10 минут
/dev/pts/4
12:40:54
$cd project/KiR/checkers

12:41:08
$./mycp
 argv[0] = ./mycp
 argv[1] = (null)
 argv[2] = ORBIT_SOCKETDIR=/tmp/orbit-ol14
 argv[3] = SSH_AGENT_PID=2957
/dev/pts/6
12:42:36
$mc

Статистика

Время первой команды журнала11:36:59 2012-10-17
Время последней команды журнала12:42:36 2012-10-18
Количество командных строк в журнале52
Процент команд с ненулевым кодом завершения, % 9.62
Процент синтаксически неверно набранных команд, % 5.77
Суммарное время работы с терминалом *, час 0.87
Количество командных строк в единицу времени, команда/мин 1.00
Частота использования команд
mycp31|===========================================================| 59.62%
ls4|=======| 7.69%
cd4|=======| 7.69%
ping3|=====| 5.77%
man2|===| 3.85%
ifconfig1|=| 1.92%
nslookup1|=| 1.92%
Top1|=| 1.92%
--1|=| 1.92%
ipconfig1|=| 1.92%
cp1|=| 1.92%
Press1|=| 1.92%
mc1|=| 1.92%
____
*) Интервалы неактивности длительностью 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$