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

Содержание

Журнал

Среда (03/29/17)

/dev/pts/6
15:48:00
$func
No parameters passed to function.
15:48:15
$func first
Param #1 is first.
15:48:45
$func first second
Param #1 is first.
Parameter #2 is second.
15:49:02
$help if
if: if COMMANDS; then COMMANDS; [ elif COMMANDS; then COMMANDS; ]... [ else COMMANDS; ] fi
    Execute commands based on conditional.
    The `if COMMANDS' list is executed.  If its exit status is zero, then the
    `then COMMANDS' list is executed.  Otherwise, each `elif COMMANDS' list is
    executed in turn, and if its exit status is zero, the corresponding
    `then COMMANDS' list is executed and the if command completes.  Otherwise,
    the `else COMMANDS' list is executed, if present.  The exit status of the
    entire construct is the exit status of the last command executed, or zero
    if no condition tested true.
    Exit Status:
    Returns the status of the last command executed.
15:49:14
$help []
Shell commands matching keyword `[]'
l3script: help: no help topics match `[]'.  Try `help help' or `man -k []' or `info []'.
15:49:29
$func 1
Param #1 is 1.
15:50:11
$func 1 2
Param #1 is 1.
Parameter #2 is 2.
15:50:19
$vi task4.sh
--- /dev/null	2017-03-24 16:46:11.415999982 +0200
+++ task4.sh	2017-03-29 17:00:42.327139858 +0300
@@ -0,0 +1,16 @@
+#! /bin/bash
+
+echo "При помощи какой команды вы бы хотели получить полную справочную команду о программе?"
+read answer
+case $answer in
+	"man" | "info" )
+	   echo 'вЫ ПРАВЫЮ тАК И ЕСТЬ'
+	   ;;
+
+	"WHATIS" | "APROPOS" )
+	   echo 'НЕ СОВСЕМ'
+	   ;;
+	* )
+	   echo 'не верно'
+	   ;;
+esac
прошло 10 минут
16:00:42
$chmod u+x task4.sh

16:01:12
$./task4.sh
При помощи какой команды вы бы хотели получить полную справочную команду о программе?
man
вЫ ПРАВЫЮ тАК И ЕСТЬ
16:01:32
$./task4.sh
При помощи какой команды вы бы хотели получить полную справочную команду о программе?
ds
не верно
16:01:40
$./task4.sh
При помощи какой команды вы бы хотели получить полную справочную команду о программе?
apropos
не верно
16:01:55
$vi task4.sh
--- /tmp/l3-saved-15226.4512.17104	2017-03-29 17:02:10.039128916 +0300
+++ task4.sh	2017-03-29 17:02:38.975129025 +0300
@@ -7,7 +7,7 @@
 	   echo 'вЫ ПРАВЫЮ тАК И ЕСТЬ'
 	   ;;
 
-	"WHATIS" | "APROPOS" )
+	"whatis" | "apropos" )
 	   echo 'НЕ СОВСЕМ'
 	   ;;
 	* )
16:02:39
$./task4.sh
При помощи какой команды вы бы хотели получить полную справочную команду о программе?
apropos
НЕ СОВСЕМ
16:02:50
$vi task5.sh
16:04:00
$ 2
  2 echo 'ÐÐÐÐÑÐ ÐÑÑÑ Ð ÐÑÐÐÑÐÐÐÐÐ ÐÐÑÐÑÑÑ ÐÑÐÐÐ ÐÑÐÐÐÑÐÐÑÑ :'
  3 read PROGRAM \;
  4 if [ -x "$PROGRAM" ]
  5         then
  6          "$PROGRAM"
  7       else
  8          echo -n "Can't run $PROGRAM."
  9 if [ -e "$PROGRAM" ]
 10         then
 11          echo "This file is not executable"
...
~
~
~
~
~
~
~
~
~
"task5.sh" [Новый] 16L, 318C записано
16:10:41
$chmod u+x task5.sh

16:10:49
$./task5.sh
Полный путь к программеб которую нужно выпольнить :
/home/user/test
./task5.sh: line 4: read: `;': неправильный идентификатор
Can't run /home/user/test.No such file
16:11:56
$vi task5.sh
--- /tmp/l3-saved-15226.10423.11239	2017-03-29 17:12:34.763131805 +0300
+++ task5.sh	2017-03-29 17:13:38.907131205 +0300
@@ -1,7 +1,7 @@
 #! /bin/bash
 
 echo 'Полный путь к программеб которую нужно выпольнить :'
-read PROGRAM \;
+read PROGRAM
 if [ -x "$PROGRAM" ]
 	then
 	 "$PROGRAM"
16:13:38
$./task5.sh
Полный путь к программеб которую нужно выпольнить :
/home/user/testt
Can't run /home/user/testt.No such file
16:14:04
$vi task5.sh
16:14:31
$~
Полный путь к программеб которую нужно выпольнить :
/home/user/task4.sh
При помощи какой команды вы бы хотели получить полную справочную команду о программе?
help
не верно
16:15:57
$./task5.sh
Полный путь к программеб которую нужно выпольнить :
/home/user/task4.sh
При помощи какой команды вы бы хотели получить полную справочную команду о программе?
info
вЫ ПРАВЫЮ тАК И ЕСТЬ
16:16:36
$./task5.sh
Полный путь к программеб которую нужно выпольнить :
/etc/passwd-
Can't run /etc/passwd-.This file is not executable
16:18:35
$vi task5.sh
16:19:24
$~
#! /bin/bash
echo "При помощи какой команды вы бы хотели получить полную справочную команду о программе?"
        "man" | "info" )
read answe echo 'вЫ ПРАВЫЮ тАК И ЕСТЬ'
           ;;
case $answer in
        "whatis" | "apropos" )
           echo 'НЕ СОВСЕМ'
           ;;
        * )
           echo 'не верно'
           ;;
esac
"task4.sh" 16L, 385C
16:19:43
$~
                                                            >>
                 справочную команду о программе?"
echo "При помощи какой команды вы бы хотели получить полную справочную команду о программе?"
        "man" | "info" )
read answe echo 'вЫ ПРАВЫЮ тАК И ЕСТЬ'
           ;;
case $answer in
        "whatis" | "apropos" )
           echo 'НЕ СОВСЕМ'
           ;;
...
~
~
~
~
~
~
~
~
~
"task4.sh" 17L, 391C записано
16:20:21
$./task4.sh
При помощи какой команды вы бы хотели получить полную >>
                 справочную команду о программе?
не верно
16:30:01
$logout
l3script: logout: оболочка не является запущенной после входа в систему: используйте `exit'

Четверг (03/30/17)

/dev/pts/6
08:28:42
$cat /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/bin/sh
bin:x:2:2:bin:/bin:/bin/sh
sys:x:3:3:sys:/dev:/bin/sh
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/bin/sh
man:x:6:12:man:/var/cache/man:/bin/sh
lp:x:7:7:lp:/var/spool/lpd:/bin/sh
mail:x:8:8:mail:/var/mail:/bin/sh
news:x:9:9:news:/var/spool/news:/bin/sh
...
irc:x:39:39:ircd:/var/run/ircd:/bin/sh
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
Debian-exim:x:101:103::/var/spool/exim4:/bin/false
user:x:1000:1000:user,,,:/home/user:/bin/bash
sshd:x:102:65534::/var/run/sshd:/usr/sbin/nologin
ivan:x:1001:1001::/home/ivan:/bin/bash
petr:x:1002:1002::/home/petr:/bin/bash
anna:x:1003:1003::/home/anna:/bin/bash
прошло 11 минут
08:40:29
$id
uid=1000(user) gid=1000(user) группы=1000(user),24(cdrom),25(floppy),29(audio),30(dip),44(video),46(plugdev)
08:45:31
$id -u ivan
1001
08:46:01
$id ivan | cut -f1 -d " " | cut -f2 -d "+"
uid=1001(ivan)
08:47:32
$id ivan | cut -f1 -d " " | cut -f2 -d "="
1001(ivan)
08:47:57
$id ivan | cut -f1 -d " " | cut -f2 -d "=" | cut -f1 "("
cut: (: Нет такого файла или каталога
08:48:16
$id ivan | cut -f1 -d " " | cut -f2 -d "=" | cut -f1 -d "("
1001
08:48:24
$chfn ivan
chfn: доступ запрещён.
08:52:53
$cp ~/ mym
.bash_history                          Light_Alloy_4.4.784_RC2_by_FAFNIR.exe  pamyatka.pdf                           text1
.bash_logout                           .lilalo/                               press_any_key_to_continue.jpg          .text.txt.swo
.bash_profile                          lpi 1/                                 .profile                               .text.txt.swp
.bashrc                                lpi 2/                                 proj/                                  touchlist
bigfile                                man_smb_conf                           sh/                                    .vim/
bin/                                   matrix.jpg                             soft/                                  .viminfo
freebsd.jpg                            names/                                 task4.sh                               Вопрос
granata.jpg                            no_file_with_this_n                    task5.sh
.l3rc                                  ogo.jpg                                text/
08:52:53
$cp ~/mymotd /etc/motd
cp: не удалось выполнить stat для «/home/user/mymotd»: Нет такого файла или каталога
прошло >2 часов
/dev/pts/6
11:35:33
$logname
logname: регистрационное имя отсутствует
11:35:38
$logname
logname: регистрационное имя отсутствует
11:35:49
$whoami
user
прошло 90 минут
/dev/pts/6
13:05:56
$cd /tmp/mytmp/

13:06:30
$> test

13:06:37
$ls- l
l3script: ls-: команда не найдена
13:07:01
$ls -l
итого 0
-rw-r--r-- 1 user user 0 Мар 30 14:06 test
13:07:04
$rm test

13:09:50
$> test

Файлы

  • /etc/passwd
  • /etc/passwd
    >
    root:x:0:0:root:/root:/bin/bash
    daemon:x:1:1:daemon:/usr/sbin:/bin/sh
    bin:x:2:2:bin:/bin:/bin/sh
    sys:x:3:3:sys:/dev:/bin/sh
    sync:x:4:65534:sync:/bin:/bin/sync
    games:x:5:60:games:/usr/games:/bin/sh
    man:x:6:12:man:/var/cache/man:/bin/sh
    lp:x:7:7:lp:/var/spool/lpd:/bin/sh
    mail:x:8:8:mail:/var/mail:/bin/sh
    news:x:9:9:news:/var/spool/news:/bin/sh
    uucp:x:10:10:uucp:/var/spool/uucp:/bin/sh
    proxy:x:13:13:proxy:/bin:/bin/sh
    www-data:x:33:33:www-data:/var/www:/bin/sh
    backup:x:34:34:backup:/var/backups:/bin/sh
    list:x:38:38:Mailing List Manager:/var/list:/bin/sh
    irc:x:39:39:ircd:/var/run/ircd:/bin/sh
    gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
    nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
    libuuid:x:100:101::/var/lib/libuuid:/bin/sh
    Debian-exim:x:101:103::/var/spool/exim4:/bin/false
    user:x:1000:1000:user,,,:/home/user:/bin/bash
    sshd:x:102:65534::/var/run/sshd:/usr/sbin/nologin
    ivan:x:1001:1001::/home/ivan:/bin/bash
    petr:x:1002:1002::/home/petr:/bin/bash
    anna:x:1003:1003::/home/anna:/bin/bash
    

    Статистика

    Время первой команды журнала15:48:00 2017- 3-29
    Время последней команды журнала13:09:50 2017- 3-30
    Количество командных строк в журнале48
    Процент команд с ненулевым кодом завершения, %35.42
    Процент синтаксически неверно набранных команд, % 2.08
    Суммарное время работы с терминалом *, час 1.17
    Количество командных строк в единицу времени, команда/мин 0.68
    Частота использования команд
    id6|===========| 11.11%
    vi6|===========| 11.11%
    task4.sh5|=========| 9.26%
    func5|=========| 9.26%
    task5.sh4|=======| 7.41%
    cut4|=======| 7.41%
    ~3|=====| 5.56%
    logname2|===| 3.70%
    chmod2|===| 3.70%
    cp2|===| 3.70%
    >2|===| 3.70%
    help2|===| 3.70%
    test2|===| 3.70%
    chfn1|=| 1.85%
    cd1|=| 1.85%
    rm1|=| 1.85%
    whoami1|=| 1.85%
    logout1|=| 1.85%
    cat1|=| 1.85%
    21|=| 1.85%
    ls1|=| 1.85%
    ls-1|=| 1.85%
    ____
    *) Интервалы неактивности длительностью 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$