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

Содержание

Журнал

Вторник (12/11/07)

19:59:31
#pkill -9 l3-agent

19:59:38
#l3-agent
Removing stale pidfile
19:59:43
#df -h .lilalo
Файловая система      Разм  Исп  Дост  Исп% смонтирована на
/dev/hda1             788M  636M  112M  86% /
20:00:36
#df -h .lilalo/
Файловая система      Разм  Исп  Дост  Исп% смонтирована на
/dev/hda1             788M  636M  112M  86% /
20:00:41
#du -sh .lilalo/
1,2M    .lilalo/
20:00:51
#l3-agent
l3-agent is already running: pid=4038; pidfile=/root/.lilalo/l3-agent.pid
20:01:00
#netstat -lntp | grep apache
tcp6       0      0 :::80                   :::*                    LISTEN     4002/apache2
20:01:33
#netstat -lntp | grep ldap

20:01:40
#netstat -lntp | grep slapd
tcp        0      0 0.0.0.0:389             0.0.0.0:*               LISTEN     2466/slapd
tcp6       0      0 :::389                  :::*                    LISTEN     2466/slapd
20:01:47
#ldappasswd --help
ldappasswd: invalid option -- -
ldappasswd: unrecognized option --
Change password of an LDAP user
usage: ldappasswd [options] [user]
  user: the authentication identity, commonly a DN
Password change options:
  -a secret  old password
  -A         prompt for old password
  -t file    read file for old password
  -s secret  new password
...
  -U authcid SASL authentication identity
  -v         run in verbose mode (diagnostics to standard output)
  -V         print version info (-VV only)
  -w passwd  bind password (for simple authentication)
  -W         prompt for bind password
  -x         Simple authentication
  -X authzid SASL authorization identity ("dn:<dn>" or "u:<user>")
  -y file    Read password from file
  -Y mech    SASL mechanism
  -Z         Start TLS request (-ZZ to require successful response)
20:08:13
#ldappasswd admin
ldap_sasl_interactive_bind_s: No such attribute (16)
20:08:32
#ldappasswd cn=admin
ldap_sasl_interactive_bind_s: No such attribute (16)
20:08:38
#ldappasswd cn=admin,dc=clint
ldap_sasl_interactive_bind_s: No such attribute (16)
20:08:54
##

20:10:06
#slapcat
dn: dc=clint
objectClass: top
objectClass: dcObject
objectClass: organization
o: clint
dc: clint
structuralObjectClass: organization
entryUUID: d994cc7c-3c58-102c-85c2-b11cb9075ba5
creatorsName:
modifiersName:
...
objectClass: organizationalRole
objectClass: simpleSecurityObject
userPassword:: e1NTSEF9K0RPWUFDODFRbTBUSnp4bjNOU0ZIbUE3dytDSnR0QmY=
structuralObjectClass: organizationalRole
entryUUID: 34e06c68-3c5d-102c-94bd-b159500af7b9
creatorsName:
modifiersName:
createTimestamp: 20071211174946Z
modifyTimestamp: 20071211174946Z
entryCSN: 20071211174946Z#000001#00#000000
20:10:10
#ldappasswd -A -x -D "cn=admin,dc=clint" -w rootpass -W
Old password:
Re-enter old password:
Enter LDAP Password:
ldap_bind: Invalid credentials (49)
20:11:29
#ldappasswd -A -x -D "cn=admin,dc=clint"
Old password:
Re-enter old password:
ldap_bind: Server is unwilling to perform (53)
        additional info: unauthenticated bind (DN with no password) disallowed
20:11:45
#ldappasswd -A -x -D "cn=admin,dc=clint"
Old password:
Re-enter old password:
ldap_bind: Server is unwilling to perform (53)
        additional info: unauthenticated bind (DN with no password) disallowed
20:11:56
#ldappasswd -A -x -D "cn=admin,dc=clint" -w r00tpass -S admin
Old password:
Re-enter old password:
New password:
Re-enter new password:
ldap_bind: Invalid credentials (49)
20:12:54
#slapcat
dn: dc=clint
objectClass: top
objectClass: dcObject
objectClass: organization
o: clint
dc: clint
structuralObjectClass: organization
entryUUID: d994cc7c-3c58-102c-85c2-b11cb9075ba5
creatorsName:
modifiersName:
...
objectClass: organizationalRole
objectClass: simpleSecurityObject
userPassword:: e1NTSEF9K0RPWUFDODFRbTBUSnp4bjNOU0ZIbUE3dytDSnR0QmY=
structuralObjectClass: organizationalRole
entryUUID: 34e06c68-3c5d-102c-94bd-b159500af7b9
creatorsName:
modifiersName:
createTimestamp: 20071211174946Z
modifyTimestamp: 20071211174946Z
entryCSN: 20071211174946Z#000001#00#000000
20:13:35
#ldappasswd -A -x -D "cn=admin,dc=clint"

20:15:10
#vim /etc/ldap/
20:15:10
#vim /etc/ldap/schema/
20:15:10
#cd /etc/ldap/

20:15:42
#mv samba.schema schema/

20:16:00
#/etc/init.d/slapd restart
Stopping OpenLDAP: slapd.
Starting OpenLDAP: slapd - failed.
The operation failed but no output was produced. For hints on what went
wrong please refer to the system's logfiles (e.g. /var/log/syslog) or
try running the daemon in Debug mode like via "slapd -d 16383" (warning:
this will create copious output).
Below, you can find the command line options used by this script to
run slapd and slurpd. Do not forget to specify those options if you
want to look to debugging output:
  slapd -g openldap -u openldap
20:16:09
#slapd -g openldap -u openldap -d
slapd: option requires an argument -- d
usage: slapd options
        -4              IPv4 only
        -6              IPv6 only
        -T {acl|add|auth|cat|dn|index|passwd|test}
                        Run in Tool mode
        -c cookie       Sync cookie of consumer
        -d level        Debug level
        -f filename     Configuration file
        -F dir  Configuration directory
        -g group        Group (id or name) to run as
        -h URLs         List of URLs to serve
        -l facility     Syslog facility (default: LOCAL4)
        -n serverName   Service name
        -o <opt>[=val] generic means to specify options; supported options:
                slp[={on|off}] enable/disable SLP
        -r directory    Sandbox directory to chroot to
        -s level        Syslog level
        -u user         User (id or name) to run as
        -V              print version info (-VV only)
20:16:59
#slapd -g openldap -u openldap -d 2
@(#) $OpenLDAP: slapd 2.3.30 (Mar  9 2007 05:43:02) $
        root@windlord:/tmp/buildd/openldap2.3-2.3.30/debian/build/servers/slapd
could not stat config file "/etc/ldap/samba.schema": No such file or directory (2)
slapd stopped.
connections_destroy: nothing to destroy.
20:17:03
#cd /etc/ldap/

20:17:21
#vim /etc/ldap/slapd.conf
15c15
< include         /etc/ldap/samba.schema
---
> include         /etc/ldap/schema/samba.schema
63c63
< # rootdn          "cn=admin,dc=clint"
---
> rootdn          "cn=admin,dc=clint"
20:18:17
#/etc/init.d/slapd restart
Stopping OpenLDAP: slapd.
Starting OpenLDAP: slapd.
20:18:19
#vim /etc/ldap/slapd.conf
20:19:14
#man slapd.comf
20:19:22
#man slapd.con
20:19:31
#slappasswd
New password:
Re-enter new password:
{SSHA}qTvIZUq/hxglPb3fRt5cHS1QIBnf5crV
20:19:39
#vim /etc/ldap/slapd.conf
63a64
> rootpw					{SSHA}qTvIZUq/hxglPb3fRt5cHS1QIBnf5crV
20:20:24
#slaptest
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
config file testing succeeded
20:20:29
#vim /etc/ldap/slapd.conf
20:20:51
#slaptest
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
config file testing succeeded
20:20:53
#vim /etc/ldap/slapd.conf
20:21:23
#/etc/init.d/slapd restart
Stopping OpenLDAP: slapd.
Starting OpenLDAP: slapd.
20:21:27
#/etc/init.d/slapd stop
Stopping OpenLDAP: slapd.
20:22:48
#slapd -d 256
@(#) $OpenLDAP: slapd 2.3.30 (Mar  9 2007 05:43:02) $
        root@windlord:/tmp/buildd/openldap2.3-2.3.30/debian/build/servers/slapd
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
slapd starting
conn=0 fd=11 ACCEPT from IP=127.0.0.1:3902 (IP=0.0.0.0:389)
bind: invalid dn (admin)
conn=0 op=0 RESULT tag=97 err=34 text=invalid DN
conn=0 op=1 UNBIND
conn=0 fd=11 closed
daemon: shutdown requested and initiated.
slapd shutdown: waiting for 0 threads to terminate
slapd stopped.
20:24:06
#dpkg -L phpldapadmin | grep config
/usr/share/phpldapadmin/config
/usr/share/phpldapadmin/config/config.php.example
/usr/share/phpldapadmin/lib/config_default.php
20:24:34
#man config
20:24:53
#man phpldapadmin
20:24:59
#man
20:24:59
#. /etc/bash_completion

20:25:15
#cd /usr/share/phpldapadmin/

20:25:25
#ls
config  doc  htdocs  index.php  lang  lib  locale  patch-stamp  templates  tools  VERSION
20:25:26
#vim config/config.php
20:25:26
#vim config/config.php.example
20:25:55
#vim config/config.php
116c116
< // $ldapservers->SetValue($i,'server','low_bandwidth',false);
---
> $ldapservers->SetValue($i,'server','low_bandwidth',false);
139a140
> $ldapservers->SetValue($i,'login','string','uid=admin,dc=clinika');
20:30:27
#/etc/init.d/apache2 restart
Forcing reload of web server (apache2)... waiting .
20:30:46
#/etc/init.d/slapd stop
Stopping OpenLDAP: slapd.
20:30:54
#/etc/init.d/slapd start
Starting OpenLDAP: slapd.
20:30:57
#vim config/config.php
131c131
< // $ldapservers->SetValue($i,'login','attr','dn');
---
> $ldapservers->SetValue($i,'login','attr','dn');
20:39:11
#slapcat
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
dn: dc=clint
objectClass: top
objectClass: dcObject
objectClass: organization
o: clint
dc: clint
structuralObjectClass: organization
entryUUID: d994cc7c-3c58-102c-85c2-b11cb9075ba5
...
objectClass: organizationalRole
objectClass: simpleSecurityObject
userPassword:: e1NTSEF9K0RPWUFDODFRbTBUSnp4bjNOU0ZIbUE3dytDSnR0QmY=
structuralObjectClass: organizationalRole
entryUUID: 34e06c68-3c5d-102c-94bd-b159500af7b9
creatorsName:
modifiersName:
createTimestamp: 20071211174946Z
modifyTimestamp: 20071211174946Z
entryCSN: 20071211174946Z#000001#00#000000
20:39:15
#vim config/config.php
95c95,96
< $ldapservers->SetValue($i,'server','auth_type','session');
---
> $ldapservers->SetValue($i,'server','auth_type','cookie');
> #$ldapservers->SetValue($i,'server','auth_type','session');
140c141
< $ldapservers->SetValue($i,'login','string','uid=admin,dc=clinika');
---
> $ldapservers->SetValue($i,'login','string','');
20:42:40
#vim config/config.php
141d140
< $ldapservers->SetValue($i,'login','string','');
20:44:35
#vim config/config.php
132c132,133
< $ldapservers->SetValue($i,'login','attr','dn');
---
> #$ldapservers->SetValue($i,'login','attr','dn');
> $ldapservers->SetValue($i,'login','attr','uid');
140a142
> $ldapservers->SetValue($i,'login','string','uid=<username>,dc=clinika');
145c147
< // $ldapservers->SetValue($i,'login','class','');
---
> #$ldapservers->SetValue($i,'login','class','');
прошло 32 минуты
21:16:59
#slapcat
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
dn: dc=clint
objectClass: top
objectClass: dcObject
objectClass: organization
o: clint
dc: clint
structuralObjectClass: organization
entryUUID: d994cc7c-3c58-102c-85c2-b11cb9075ba5
...
objectClass: organizationalRole
objectClass: simpleSecurityObject
userPassword:: e1NTSEF9K0RPWUFDODFRbTBUSnp4bjNOU0ZIbUE3dytDSnR0QmY=
structuralObjectClass: organizationalRole
entryUUID: 34e06c68-3c5d-102c-94bd-b159500af7b9
creatorsName:
modifiersName:
createTimestamp: 20071211174946Z
modifyTimestamp: 20071211174946Z
entryCSN: 20071211174946Z#000001#00#000000
21:17:35
#ldappasswd --help
ldappasswd: invalid option -- -
ldappasswd: unrecognized option --
Change password of an LDAP user
usage: ldappasswd [options] [user]
  user: the authentication identity, commonly a DN
Password change options:
  -a secret  old password
  -A         prompt for old password
  -t file    read file for old password
  -s secret  new password
...
  -U authcid SASL authentication identity
  -v         run in verbose mode (diagnostics to standard output)
  -V         print version info (-VV only)
  -w passwd  bind password (for simple authentication)
  -W         prompt for bind password
  -x         Simple authentication
  -X authzid SASL authorization identity ("dn:<dn>" or "u:<user>")
  -y file    Read password from file
  -Y mech    SASL mechanism
  -Z         Start TLS request (-ZZ to require successful response)
21:18:19
##

21:19:17
#ldappasswd -A -S cn=admin,dc=clinika
(reverse-i-search)`ldappasswd -A -': #
Old password:
Re-enter old password:
New password:
Re-enter new password:
ldap_sasl_interactive_bind_s: No such attribute (16)
21:19:44
#vim /etc/ldap/
21:19:44
#vim /etc/ldap/ldap.conf
21:20:13
#vim /etc/ldap/
21:20:13
#vim /etc/ldap/slapd.conf
64c64
< rootpw					{SSHA}qTvIZUq/hxglPb3fRt5cHS1QIBnf5crV
---
> rootpw          {SSHA}qTvIZUq/hxglPb3fRt5cHS1QIBnf5crV
21:20:45
#/etc/init.d/slapd stop
Stopping OpenLDAP: slapd.
21:21:36
#slapd -d 512
@(#) $OpenLDAP: slapd 2.3.30 (Mar  9 2007 05:43:02) $
        root@windlord:/tmp/buildd/openldap2.3-2.3.30/debian/build/servers/slapd
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
slapd starting
<= bdb_equality_candidates: (uid) index_param failed (18)
daemon: shutdown requested and initiated.
slapd shutdown: waiting for 0 threads to terminate
slapd stopped.
21:22:00
#vim /etc/ldap/slapd.conf
21:22:27
#ldappasswd -A -S "cn=admin,dc=clinika"
Old password:
Re-enter old password:
New password:
Re-enter new password:
ldap_sasl_interactive_bind_s: Can't contact LDAP server (-1)
21:23:04
#/etc/init.d/slapd start
Starting OpenLDAP: slapd.
21:23:12
#ldappasswd -A -S "cn=admin,dc=clinika"
Old password:
Re-enter old password:
New password:
Re-enter new password:
ldap_sasl_interactive_bind_s: No such attribute (16)
21:23:21
#ldappasswd -S "cn=admin,dc=clinika"
New password:
Re-enter new password:
ldap_sasl_interactive_bind_s: No such attribute (16)
21:23:37
#ldappasswd -S "cn=admin,dc=clinika" -x -d 5
New password:
Re-enter new password:
ldap_create
ldap_bind
ldap_simple_bind
ldap_sasl_bind
ldap_send_initial_request
ldap_new_connection 1 1 0
ldap_int_open_connection
ldap_connect_to_host: TCP localhost:389
...
ldap_parse_extended_result
ber_scanf fmt ({eaa) ber:
ldap_msgfree
ldap_err2string
Result: Strong(er) authentication required (8)
Additional info: only authenticated users may change passwords
ldap_free_connection 1 1
ldap_send_unbind
ber_flush: 7 bytes to sd 3
ldap_free_connection: actually freed
21:24:43
#ldappasswd -S "cn=admin,dc=clinika" -x
New password:
Re-enter new password:
Result: Strong(er) authentication required (8)
Additional info: only authenticated users may change passwords
21:25:26
#man ldappasswd
21:28:27
#ldappasswd -S "cn=admin,dc=clinika" -x -D -W
New password:
Re-enter new password:
ldap_bind: Invalid DN syntax (34)
        additional info: invalid DN
21:32:40
#ldappasswd -S "cn=admin,dc=clinika" -x -W
New password:
Re-enter new password:
Enter LDAP Password:
ldap_bind: Invalid credentials (49)
21:33:00
#ldappasswd -S "cn=admin,dc=clinika" -x -W
New password:
Re-enter new password:
Enter LDAP Password:
ldap_bind: Invalid credentials (49)
21:33:20
#ldappasswd -S "cn=admin,dc=clinika" -x -D admin -W
New password:
Re-enter new password:
Enter LDAP Password:
ldap_bind: Invalid DN syntax (34)
        additional info: invalid DN
21:34:33
#ldappasswd -S "cn=admin,dc=clinika" -x -D cn=admin,dc=clinika -W
New password:
Re-enter new password:
Enter LDAP Password:
ldap_bind: Invalid credentials (49)
21:34:54
#vim /etc/ldap/slapd.conf
21:37:13
#vim config/config.php
21:37:24
#pwd
/usr/share/phpldapadmin
21:37:26
#vim config/config.php
21:39:26
#slapcat
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
dn: dc=clint
objectClass: top
objectClass: dcObject
objectClass: organization
o: clint
dc: clint
structuralObjectClass: organization
entryUUID: d994cc7c-3c58-102c-85c2-b11cb9075ba5
...
objectClass: organizationalRole
objectClass: simpleSecurityObject
userPassword:: e1NTSEF9K0RPWUFDODFRbTBUSnp4bjNOU0ZIbUE3dytDSnR0QmY=
structuralObjectClass: organizationalRole
entryUUID: 34e06c68-3c5d-102c-94bd-b159500af7b9
creatorsName:
modifiersName:
createTimestamp: 20071211174946Z
modifyTimestamp: 20071211174946Z
entryCSN: 20071211174946Z#000001#00#000000
21:39:29
#vim config/config.php
142c142
< $ldapservers->SetValue($i,'login','string','uid=<username>,dc=clinika');
---
> $ldapservers->SetValue($i,'login','string','uid=<username>,dc=clint');
21:40:19
#vim config/config.php
21:41:28
#slappasswd
New password:
Re-enter new password:
Password values do not match
21:41:40
#/etc/init.d/slapd restart
Stopping OpenLDAP: slapd.
Starting OpenLDAP: slapd.
21:41:49
#/etc/init.d/slapd stop
Stopping OpenLDAP: slapd.
21:41:54
#vim config/config.php
21:44:10
#/etc/init.d/slapd start
Starting OpenLDAP: slapd.
21:44:15
#ldapsearch -x -b "dc=clint" "(cn=admini)"
# extended LDIF
#
# LDAPv3
# base <dc=clint> with scope subtree
# filter: (cn=admini)
# requesting: ALL
#
# search result
search: 2
result: 0 Success
# numResponses: 1
21:44:17
#ldapsearch -x -b "dc=clint" "(cn=admin)"
# extended LDIF
#
# LDAPv3
# base <dc=clint> with scope subtree
# filter: (cn=admin)
# requesting: ALL
#
# admin, clint
dn: cn=admin,dc=clint
objectClass: simpleSecurityObject
...
dn: cn=admin,ou=People,dc=clint
cn: admin
objectClass: top
objectClass: organizationalRole
objectClass: simpleSecurityObject
# search result
search: 2
result: 0 Success
# numResponses: 3
# numEntries: 2
21:44:30
#/etc/init.d/slapd stop
Stopping OpenLDAP: slapd.
21:45:33
#slapd -d 256
@(#) $OpenLDAP: slapd 2.3.30 (Mar  9 2007 05:43:02) $
        root@windlord:/tmp/buildd/openldap2.3-2.3.30/debian/build/servers/slapd
/etc/ldap/slapd.conf: line 102: rootdn is always granted unlimited privileges.
/etc/ldap/slapd.conf: line 119: rootdn is always granted unlimited privileges.
slapd starting
conn=0 fd=11 ACCEPT from IP=127.0.0.1:3346 (IP=0.0.0.0:389)
conn=0 op=0 BIND dn="" method=128
conn=0 op=0 RESULT tag=97 err=0 text=
conn=0 op=1 SRCH base="dc=clint" scope=2 deref=0 filter="(uid=admin)"
conn=0 op=1 SRCH attr=dn
<= bdb_equality_candidates: (uid) index_param failed (18)
conn=0 op=1 SEARCH RESULT tag=101 err=0 nentries=0 text=
conn=0 op=2 UNBIND
conn=0 fd=11 closed
daemon: shutdown requested and initiated.
slapd shutdown: waiting for 0 threads to terminate
slapd stopped.

Статистика

Время первой команды журнала19:59:31 2007-12-11
Время последней команды журнала21:45:33 2007-12-11
Количество командных строк в журнале100
Процент команд с ненулевым кодом завершения, %36.00
Процент синтаксически неверно набранных команд, % 0.00
Суммарное время работы с терминалом *, час 1.23
Количество командных строк в единицу времени, команда/мин 1.36
Частота использования команд
vim25|========================| 24.04%
ldappasswd21|====================| 20.19%
/etc/init.d/slapd12|===========| 11.54%
man6|=====| 5.77%
slapd5|====| 4.81%
slapcat5|====| 4.81%
grep4|===| 3.85%
cd3|==| 2.88%
netstat3|==| 2.88%
l3-agent2|=| 1.92%
slappasswd2|=| 1.92%
#2|=| 1.92%
ldapsearch2|=| 1.92%
df2|=| 1.92%
slaptest2|=| 1.92%
dpkg1|| 0.96%
/etc/init.d/apache21|| 0.96%
pwd1|| 0.96%
pkill1|| 0.96%
.1|| 0.96%
ls1|| 0.96%
mv1|| 0.96%
du1|| 0.96%
____
*) Интервалы неактивности длительностью 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$