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

Содержание

Журнал

Вторник (07/17/18)

/dev/pts/6
15:48:43
$ls -l
итого 2968
-rw-r--r-- 1 user user       0 Июл 17 12:20 1
-rw-r--r-- 1 user user       0 Июл 17 12:20 2
-rw-r--r-- 1 user user       0 Июл 17 12:20 3
-rw-r--r-- 1 user user       0 Июл 17 12:20 33
-rw-r--r-- 1 user user       0 Июл 17 12:20 44
-rw-r--r-- 1 user user       0 Июл 17 12:20 55
drwxr-xr-x 3 user user    4096 Июл 16 15:07 backup
-rwxr-xr-x 1 user user    7994 Окт  9  2014 bigfile
drwxr-xr-x 2 user user    4096 Июл 16 14:24 bin
...
-rwxr-xr-x 1 user user   23048 Окт  9  2014 press_any_key_to_continue.jpg
drwxr-xr-x 3 user user    4096 Июл 17 12:26 proj
drwxr-xr-x 2 user user    4096 Окт  9  2014 sh
drwxr-xr-x 2 user user    4096 Июл 17 16:48 soft
-rw-r--r-- 1 user user      51 Июл 17 12:40 sorted
-rw-r--r-- 1 user user     986 Июл 17 12:50 sorted_passwd
drwxr-xr-x 2 user user    4096 Июл 16 14:13 source
drwxr-xr-x 2 user user    4096 Июл 17 12:26 text
-rw-r--r-- 1 user user      16 Июл 17 12:18 touchlist
-rw-r--r-- 1 user user      51 Июл 17 12:39 unsorted
15:48:46
$cd soft/

15:48:52
$ls-l
l3script: ls-l: команда не найдена
15:48:54
$ls -l
итого 0
15:48:58
$find ~ -regex '.*(\.tar|\.gz|\.rpm)' -exec mv {} ~/soft \;

15:49:57
$find ~ -regex '.*(\.tar|\.gz|\.rpm)' -exec mv {} ~/soft
find: отсутствует аргумент у `-exec'
15:50:02
$find ~ -regex '.*(\.tar|\.gz|\.rpm)' -exec mv {} ~/soft \;

15:50:15
$ls -l
итого 0
15:50:29
$cd

15:51:07
$find ~-name core -ok rm -f {} \;
find: `~-name': Нет такого файла или каталога
find: `core': Нет такого файла или каталога
15:51:35
$find ~ -name core -ok rm -f {} \;
< rm ... /home/user/lpi 1/core > ? y
15:51:58
$find ~ -name core -ok rm -f {} \;

15:54:33
$find / sudo
/
/sys
/sys/fs
/sys/fs/cgroup
/sys/fs/ext4
/sys/fs/ext4/features
/sys/fs/ext4/features/lazy_itable_init
/sys/fs/ext4/features/batched_discard
/sys/fs/ext4/xvda1
/sys/fs/ext4/xvda1/delayed_allocation_blocks
...
/proc/11802/cgroup
/proc/11802/oom_score
/proc/11802/oom_adj
/proc/11802/oom_score_adj
/proc/11802/loginuid
/proc/11802/sessionid
/proc/11802/coredump_filter
/proc/11802/io
/opt
find: `sudo': Нет такого файла или каталога
15:56:39
$cd /etc/sudoers.d/

15:57:03
$ls -l
итого 4
-r--r----- 1 root root 958 Июл  3  2017 README
15:57:08
$ls -lcd
drwxr-xr-x 2 root root 4096 Июл 17 16:33 .
15:57:54
$cd

15:57:56
$ls -l
итого 2968
-rw-r--r-- 1 user user       0 Июл 17 12:20 1
-rw-r--r-- 1 user user       0 Июл 17 12:20 2
-rw-r--r-- 1 user user       0 Июл 17 12:20 3
-rw-r--r-- 1 user user       0 Июл 17 12:20 33
-rw-r--r-- 1 user user       0 Июл 17 12:20 44
-rw-r--r-- 1 user user       0 Июл 17 12:20 55
drwxr-xr-x 3 user user    4096 Июл 16 15:07 backup
-rwxr-xr-x 1 user user    7994 Окт  9  2014 bigfile
drwxr-xr-x 2 user user    4096 Июл 16 14:24 bin
...
-rwxr-xr-x 1 user user   23048 Окт  9  2014 press_any_key_to_continue.jpg
drwxr-xr-x 3 user user    4096 Июл 17 12:26 proj
drwxr-xr-x 2 user user    4096 Окт  9  2014 sh
drwxr-xr-x 2 user user    4096 Июл 17 16:48 soft
-rw-r--r-- 1 user user      51 Июл 17 12:40 sorted
-rw-r--r-- 1 user user     986 Июл 17 12:50 sorted_passwd
drwxr-xr-x 2 user user    4096 Июл 16 14:13 source
drwxr-xr-x 2 user user    4096 Июл 17 12:26 text
-rw-r--r-- 1 user user      16 Июл 17 12:18 touchlist
-rw-r--r-- 1 user user      51 Июл 17 12:39 unsorted
15:58:08
$man find

Среда (07/18/18)

/dev/pts/2
08:02:08
$find / -regex ".*\.jpe?g"
find: `/etc/ssl/private': Отказано в доступе
find: `/lost+found': Отказано в доступе
find: `/var/lib/sudo': Отказано в доступе
find: `/var/cache/ldconfig': Отказано в доступе
find: `/var/spool/exim4': Отказано в доступе
find: `/var/spool/cron/crontabs': Отказано в доступе
find: `/var/log/exim4': Отказано в доступе
find: `/var/log/iptraf': Отказано в доступе
/home/user/matrix.jpg
/home/user/freebsd.jpg
...
find: `/proc/12506/task/12506/ns': Отказано в доступе
find: `/proc/12506/fd': Отказано в доступе
find: `/proc/12506/fdinfo': Отказано в доступе
find: `/proc/12506/ns': Отказано в доступе
find: `/proc/12507/task/12507/fd': Отказано в доступе
find: `/proc/12507/task/12507/fdinfo': Отказано в доступе
find: `/proc/12507/task/12507/ns': Отказано в доступе
find: `/proc/12507/fd': Отказано в доступе
find: `/proc/12507/fdinfo': Отказано в доступе
find: `/proc/12507/ns': Отказано в доступе
08:06:39
$find / -regex ".*\.jpe?g"~ 2> /dev/null

08:08:22
$find / -regex ".*\.jpe?g"~
find: `/etc/ssl/private': Отказано в доступе
find: `/lost+found': Отказано в доступе
find: `/var/lib/sudo': Отказано в доступе
find: `/var/cache/ldconfig': Отказано в доступе
find: `/var/spool/exim4': Отказано в доступе
find: `/var/spool/cron/crontabs': Отказано в доступе
find: `/var/log/exim4': Отказано в доступе
find: `/var/log/iptraf': Отказано в доступе
find: `/run/exim4': Отказано в доступе
find: `/root': Отказано в доступе
...
find: `/proc/12506/task/12506/ns': Отказано в доступе
find: `/proc/12506/fd': Отказано в доступе
find: `/proc/12506/fdinfo': Отказано в доступе
find: `/proc/12506/ns': Отказано в доступе
find: `/proc/12507/task/12507/fd': Отказано в доступе
find: `/proc/12507/task/12507/fdinfo': Отказано в доступе
find: `/proc/12507/task/12507/ns': Отказано в доступе
find: `/proc/12507/fd': Отказано в доступе
find: `/proc/12507/fdinfo': Отказано в доступе
find: `/proc/12507/ns': Отказано в доступе
08:08:35
$find / -regex ".*\.jpe?g" 2> /dev/null
/home/user/matrix.jpg
/home/user/freebsd.jpg
/home/user/press_any_key_to_continue.jpg
/home/user/granata.jpg
/home/user/ogo.jpg
прошло 119 минут
10:08:13
$echo $?
1
10:08:26
$touch no_file_with_this_namae

10:09:44
$test 5 -gt 1

10:10:04
$echo $?
0
10:10:07
$test 5 -lt 1

10:10:15
$echo $?
1
10:10:16
$test -z "$STRING"

10:10:57
$echo $?
0
10:10:59
$test -z $STRING

10:11:15
$echo $?
0
10:11:17
$test "$P" != print

10:12:02
$echo $?
0
10:12:03
$test -e /etc/motd

10:12:22
$echo $?
0
10:12:23
$test -d /usr/local/bin/

10:12:45
$test -r /etc/shadow

10:13:05
$echo $?
1
10:13:06
$test -k /tmp/

10:13:22
$echo $?
0
10:13:23
$test --help

10:15:55
$help test
test: test [expr]
    Evaluate conditional expression.
    Exits with a status of 0 (true) or 1 (false) depending on
    the evaluation of EXPR.  Expressions may be unary or binary.  Unary
    expressions are often used to examine the status of a file.  There
    are string operators and numeric comparison operators as well.
    The behavior of test depends on the number of arguments.  Read the
    bash manual page for the complete specification.
    File operators:
      -a FILE        True if file exists.
...
      arg1 OP arg2   Arithmetic tests.  OP is one of -eq, -ne,
                     -lt, -le, -gt, or -ge.
    Arithmetic binary operators return true if ARG1 is equal, not-equal,
    less-than, less-than-or-equal, greater-than, or greater-than-or-equal
    than ARG2.
    See the bash manual page bash(1) for the handling of parameters (i.e.
    missing parameters).
    Exit Status:
    Returns success if EXPR evaluates to true; fails if EXPR evaluates to
    false or an invalid argument is given.
10:16:03
$test -w /etc/passwd

10:16:40
$echo $?
1
10:16:43
$test 5 > 10

10:17:12
$echo $?
0
10:17:13
$test 10 > 5

10:18:44
$echo $?
0
10:18:45
$test 10 -eq 5

10:20:39
$echo $?
1
10:20:40
$test '10' > '5'

10:21:06
$echo $?
0
10:21:07
$test 10 > 5

10:21:17
$echo $?
0
10:21:18
$echo "Your favorite color? ; read FAV_COL ; \
>
> green
> q
> ^C
10:22:50
$echo "Your favorite color? ; read FAV_COL ; \
green
10:22:50
$$?
                       "Your favorite color? ; read FAV_COL ; \
                                            "
> green
Your favorite color?
green
l3script: green: команда не найдена
10:23:31
$cat $FAV_COL
cat: green: Нет такого файла или каталога
10:23:52
$find FAV_COL
find: `FAV_COL': Нет такого файла или каталога
10:24:08
$$FAV_COL=green
l3script: green=green: команда не найдена
10:24:23
$$FAV_COL = green
l3script: green: команда не найдена
10:24:33
$touch $FAV_COL = green

10:24:45
$set
BASH=/usr/local/bin/l3script
BASHOPTS=checkwinsize:cmdhist:expand_aliases:extglob:extquote:force_fignore:histappend:interactive_comments:progcomp:promptvars:sourcepath
BASH_ALIASES=()
BASH_ARGC=()
BASH_ARGV=()
BASH_CMDS=()
BASH_COMPLETION_COMPAT_DIR=/etc/bash_completion.d
BASH_LINENO=()
BASH_REMATCH=()
BASH_SOURCE=()
...
LS_COLORS='rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lz=01;31:*.xz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.
MACHTYPE=x86_64-pc-linux-gnu
MAIL=/var/mail/user
MAILCHECK=60
OPTERR=1
OPTIND=1
OSTYPE=linux-gnu
PATH=/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games
PIPESTATUS=([0]="0")
PPID=12358
10:25:40
$set | more
10:26:03
$echo $FAV_COL
green
10:27:23
$test -w /etc/passwd || \
>
>
> ^C
10:28:13
$test -w /etc/passwd ||
> ^C
10:28:25
$test -w /etc/passwd

10:28:28
$echo $?
1
10:29:32
$A=0

10:29:54
$while [ $A -lt 10 ]
> do
> A=$((A+1))
> echo $A
> done
1
2
3
4
5
6
7
8
9
10
10:31:04
$cd

10:31:30
$for file in /etc/*
> do
> [ -r $file ] || echo $file
> done
/etc/group-
/etc/gshadow
/etc/gshadow-
/etc/passwd-
/etc/shadow
/etc/shadow-
/etc/sudoers
10:32:47
$echo "Which command?" ;\
> mount
Which command?
sysfs on /sys type sysfs (rw,nosuid,nodev,noexec,relatime)
proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)
udev on /dev type devtmpfs (rw,relatime,size=10240k,nr_inodes=61932,mode=755)
devpts on /dev/pts type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000)
tmpfs on /run type tmpfs (rw,nosuid,noexec,relatime,size=50740k,mode=755)
/dev/disk/by-uuid/92b79496-a6c3-450d-a438-766caa8504d8 on / type ext4 (rw,relatime,errors=remount-ro,user_xattr,barrier=1,data=ordered)
tmpfs on /run/lock type tmpfs (rw,nosuid,nodev,noexec,relatime,size=5120k)
tmpfs on /run/shm type tmpfs (rw,nosuid,nodev,noexec,relatime,size=101460k)
10:33:30
$echo "Which command?" ;\
> select
l3script: syntax error near unexpected token `newline'
10:34:33
$echo 'Which command?' ;\
> mkdir
Which command?
mkdir: пропущен операнд
Попробуйте «mkdir --help» для получения более подробного описания.
10:35:09
$echo 'Which command?' ;
Which command?
10:35:43
$touch
touch: пропущен операнд, задающий файл
Попробуйте «touch --help» для получения более подробного описания.
10:35:52
$echo 'Which command?' ;\
> touch
Which command?
touch: пропущен операнд, задающий файл
Попробуйте «touch --help» для получения более подробного описания.
10:36:44
$the cat
l3script: the: команда не найдена
10:36:57
$echo 'Full path to program:'
Full path to program:
10:38:46
$read PROGRAM \;
if [ -x "$PROGRAM" ]
l3script: read: `;': неправильный идентификатор
10:44:19
$test $EUID -ne 0 -a -r /etc/shadow &&\
> echo 'file writable'
10:51:02
$test $EUID -ne 0 -a -r /etc/shadow &&
>
>
> echo #?
10:52:06
$test $EUID -ne 0 -a -r /etc/shadow &&
>
> ||
l3script: syntax error near unexpected token `||'
10:52:29
$test -w /etc/passwd

10:54:48
$echo #?

10:55:02
$test -r /etc/passwd

10:55:14
$echo #?

10:55:15
$echo $?
0
10:55:27
$test -w /etc/passwd

10:55:31
$echo $?
1
10:55:33
$test -w /etc/passwd && echo 'yeas'

10:56:00
$test -w /etc/passwd || echo 'yeas'
yeas
10:56:11
$cd

10:57:18
$touch echo.sh

10:57:39
$vim echo.sh
--- /tmp/l3-saved-12359.16170.17323	2018-07-18 11:57:44.950460341 +0300
+++ echo.sh	2018-07-18 12:03:30.822505667 +0300
@@ -0,0 +1,14 @@
+#!/bin/bash
+
+echo "wich program"
+read answer
+case $answer in 
+"man" | "info"  )
+	echo 'you are rite'
+::
+"whatis" | "apropos"  )
+	echo 'not that way'
+::
+* )echo 'you are wrong'
+::
+esac
11:03:30
$./ echo.sh
l3script: ./: Это каталог
11:03:40
$./echo.sh
l3script: ./echo.sh: Отказано в доступе

Статистика

Время первой команды журнала15:48:43 2018- 7-17
Время последней команды журнала11:03:40 2018- 7-18
Количество командных строк в журнале101
Процент команд с ненулевым кодом завершения, %23.76
Процент синтаксически неверно набранных команд, % 4.95
Суммарное время работы с терминалом *, час 1.19
Количество командных строк в единицу времени, команда/мин 1.42
Частота использования команд
echo31|=======================| 23.85%
test27|====================| 20.77%
find12|=========| 9.23%
\8|======| 6.15%
cd6|====| 4.62%
ls6|====| 4.62%
touch4|===| 3.08%
&4|===| 3.08%
\.gz3|==| 2.31%
\.rpm)'3|==| 2.31%
read3|==| 2.31%
52|=| 1.54%
null2|=| 1.54%
set2|=| 1.54%
echo.sh2|=| 1.54%
more1|| 0.77%
101|| 0.77%
while1|| 0.77%
$FAV_COL=green1|| 0.77%
man1|| 0.77%
$?1|| 0.77%
ls-l1|| 0.77%
for1|| 0.77%
vim1|| 0.77%
A=01|| 0.77%
help1|| 0.77%
cat1|| 0.77%
$FAV_COL1|| 0.77%
the1|| 0.77%
'5'1|| 0.77%
____
*) Интервалы неактивности длительностью 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$