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

Содержание

Журнал

Вторник (04/04/06)

/dev/ttyv1
14:05:27
#natd -h
natd: unknown option h
Recognized options:
-unregistered_only    [yes|no]
-u                    [yes|no]
      alias only unregistered addresses
-log                  [yes|no]
-l                    [yes|no]
      enable logging
-proxy_only           [yes|no]
      proxy only
...
      punch holes in the firewall for incoming FTP/IRC DCC connections
-skinny_port          port
      set the TCP port for use with the Skinny Station protocol
-log_ipfw_denied      [yes|no]
      log packets converted by natd, but denied by ipfw
-pid_file             file_name
-P                    file_name
      store PID in an alternate file
-instance             instance name
      name of aliasing engine instance
14:09:31
#pkg_addrsync
bash: pkg_addrsync: command not found
прошло 42 минуты
14:51:50
#pkg_add rsync
pkg_add: can't stat package file 'rsync'
14:51:56
#whereis rsync
rsync: /usr/ports/net/rsync
14:52:20
#pkg_add -r rsync
Fetching ftp://ftp.freebsd.org/pub/FreeBSD/ports/i386/packages-6.0-release/Latest/rsync.tbz... Done.
14:52:39
#rcync -avz fbsd2:/etc/ /tmp/etc/
bash: rcync: command not found
14:57:34
#rsync -avz fbsd2:/etc/ /tmp/etc/
ppp/
ppp/ppp.conf
rc.d/
rc.d/DAEMON
rc.d/LOGIN
rc.d/NETWORKING
rc.d/SERVERS
rc.d/abi
rc.d/accounting
rc.d/addswap
...
ssh/ssh_host_dsa_key.pub
ssh/ssh_host_key
ssh/ssh_host_key.pub
ssh/ssh_host_rsa_key
ssh/ssh_host_rsa_key.pub
ssh/sshd_config
ssl/
ssl/openssl.cnf
sent 7320 bytes  received 379012 bytes  10882.59 bytes/sec
total size is 1220100  speedup is 3.16
14:58:35
#cd /tmp

14:59:19
#ls
.ICE-unix               .snap                   Text-Iconv-1.4.tar.gz
.X11-unix               Term-VT102-0.82         etc
.XIM-unix               Term-VT102-0.82.tar.gz
.font-unix              Text-Iconv-1.4
14:59:23
#cd etc

15:00:05
#ls
X11                     login.conf.db           profile
aliases                 mac.conf                protocols
amd.map                 mail                    pwd.db
apmd.conf               mail.rc                 rc
auth.conf               make.conf               rc.bsdextended
bluetooth               manpath.config          rc.conf
crontab                 manpath.config.bak      rc.d
csh.cshrc               master.passwd           rc.firewall
csh.login               motd                    rc.firewall6
csh.logout              mtree                   rc.initdiskless
...
hosts                   pam.d                   snmpd.config
hosts.allow             passwd                  spwd.db
hosts.equiv             pccard_ether            ssh
hosts.lpd               periodic                ssl
inetd.conf              pf.conf                 sysctl.conf
isdn                    pf.os                   syslog.conf
localtime               phones                  termcap
locate.rc               portsnap.conf           ttys
login.access            ppp                     usbd.conf
login.conf              printcap                wall_cmos_clock
15:00:09
#rm rc.conf

15:00:18
#rsync -avz fbsd2:/etc/ /tmp/etc/
Password:
receiving file list ... done
./
rc.conf
sent 48 bytes  received 5995 bytes  212.04 bytes/sec
total size is 1220100  speedup is 201.90
15:01:30
#deco
Demos Commander, Copyright (C) 1989-1997 Serge Vakulenko
прошло 25 минут
15:27:01
#ee /etc/rc.conf
15:29:31
#man route
15:31:24
#shh keygen -l -f /etc/ssh/ssh
bash: shh: command not found
прошло 22 минуты
15:54:03
#ssh keygen -l -f /etc/ssh/ssh
ssh: keygen: hostname nor servname provided, or not known
15:54:13
#ssh keygen -l -f /etc/ssh/ssh
ssh_config            ssh_host_key          ssh_host_rsa_key.pub
ssh_host_dsa_key      ssh_host_key.pub      sshd_config
ssh_host_dsa_key.pub  ssh_host_rsa_key
15:54:13
#ssh keygen -l -f /etc/ssh/ssh
ssh_config            ssh_host_key          ssh_host_rsa_key.pub
ssh_host_dsa_key      ssh_host_key.pub      sshd_config
ssh_host_dsa_key.pub  ssh_host_rsa_key
15:54:13
#ssh keygen -l -f /etc/ssh/ssh_host_dsa_key
ssh: keygen: hostname nor servname provided, or not known
15:55:10
#ssh-keygen -l -f /etc/ssh/ssh_host_dsa_key
2048 79:9b:a1:57:62:a5:3e:ae:f0:3c:60:a3:b3:ae:cd:43 /etc/ssh/ssh_host_dsa_key.pub
15:55:37
#ssh 127.0.0.1
The authenticity of host '127.0.0.1 (127.0.0.1)' can't be established.
DSA key fingerprint is 79:9b:a1:57:62:a5:3e:ae:f0:3c:60:a3:b3:ae:cd:43.
Are you sure you want to continue connecting (yes/no)? no
Host key verification failed.
15:56:16
#ssh-keygen -h
ssh-keygen: illegal option -- h
Usage: ssh-keygen [options]
Options:
  -a trials   Number of trials for screening DH-GEX moduli.
  -B          Show bubblebabble digest of key file.
  -b bits     Number of bits in the key to create.
  -C comment  Provide new comment.
  -c          Change comment in private and public key files.
  -e          Convert OpenSSH to IETF SECSH key file.
  -F hostname Find hostname in known hosts file.
...
  -p          Change passphrase of private key file.
  -q          Quiet.
  -R hostname Remove host from known_hosts file.
  -r hostname Print DNS resource record.
  -S start    Start point (hex) for generating DH-GEX moduli.
  -T file     Screen candidates for DH-GEX moduli.
  -t type     Specify type of key to create.
  -v          Verbose.
  -W gen      Generator to use for generating DH-GEX moduli.
  -y          Read private key file and print public key.
16:02:41
#ssh-keygen -t dsa
Generating public/private dsa key pair.
Enter file in which to save the key (/root/.ssh/id_dsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /root/.ssh/id_dsa.
Your public key has been saved in /root/.ssh/id_dsa.pub.
The key fingerprint is:
3f:a0:8c:bd:4b:57:a2:24:15:19:98:b3:84:2b:98:45 root@fbsd1.unix.nt
16:04:25
#cat ~/.ssh/id_dsa.pub | ssh fbsd2 'cat >> ~/.ssh/authorized_k
eys'
Password:
16:08:37
#exit
exit
Connection to fbsd2.unix.nt closed.
16:09:52
#ssh fbsd2
Last login: Tue Apr  4 16:01:42 2006 from fbsd3.linux.nt
Copyright (c) 1980, 1983, 1986, 1988, 1990, 1991, 1993, 1994
        The Regents of the University of California.  All rights reserved.
FreeBSD 6.0-RELEASE (MAIN) #0: Mon Apr  3 14:33:41 EEST 2006
Welcome to FreeBSD!
Before seeking technical support, please use the following resources:
o  Security advisories and updated errata information for all releases are
   at http://www.FreeBSD.org/releases/ - always consult the ERRATA section
   for your release first as it's updated frequently.
o  The Handbook and FAQ documents are at http://www.FreeBSD.org/ and,
   along with the mailing lists, can be searched by going to
   http://www.FreeBSD.org/search/.  If the doc distribution has
   been installed, they're also available formatted in /usr/share/doc.
If you still have a question or problem, please take the output of
`uname -a', along with any relevant error messages, and email it
as a question to the questions@FreeBSD.org mailing list.  If you are
unfamiliar with FreeBSD's directory layout, please refer to the hier(7)
manual page.  If you are not familiar with manual pages, type `man man'.
You may also use sysinstall(8) to re-enter the installation and
configuration utility.  Edit /etc/motd to change this login announcement.

Статистика

Время первой команды журнала14:05:27 2006- 4- 4
Время последней команды журнала16:09:52 2006- 4- 4
Количество командных строк в журнале28
Процент команд с ненулевым кодом завершения, %28.57
Процент синтаксически неверно набранных команд, %10.71
Суммарное время работы с терминалом *, час 1.37
Количество командных строк в единицу времени, команда/мин 0.34
Частота использования команд
ssh7|======================| 22.58%
ssh-keygen3|=========| 9.68%
cd2|======| 6.45%
rsync2|======| 6.45%
pkg_add2|======| 6.45%
ls2|======| 6.45%
rcync1|===| 3.23%
authorized_k1|===| 3.23%
shh1|===| 3.23%
man1|===| 3.23%
natd1|===| 3.23%
>1|===| 3.23%
whereis1|===| 3.23%
deco1|===| 3.23%
rm1|===| 3.23%
pkg_addrsync1|===| 3.23%
ee1|===| 3.23%
cat1|===| 3.23%
exit1|===| 3.23%
____
*) Интервалы неактивности длительностью 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$