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

Содержание

Журнал

Среда (03/10/10)

/dev/pts/0
13:37:54
#cd /var/downloads/ipvs/keepalived-1.1.19/

13:38:35
#make
make -C lib || exit 1;
make[1]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/lib'
make[1]: Цель `all' не требует выполнения команд.
make[1]: Leaving directory `/var/downloads/ipvs/keepalived-1.1.19/lib'
make -C keepalived
make[1]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived'
make[2]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived/core'
gcc -g -O2  -I/usr/src/linux-source-2.6.26/include -I../include -I../../lib -Wall -Wunused -Wstrict-prototypes -D_KRNL_2_6_ -D_WITH_LVS_ -D_WITH_VRRP_  -c main.c
make[2]: Leaving directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived/core'
make[2]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived/check'
...
Building ../bin/keepalived
strip ../bin/keepalived
Make complete
make[1]: Leaving directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived'
make -C genhash
make[1]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/genhash'
strip ../bin/genhash
Make complete
make[1]: Leaving directory `/var/downloads/ipvs/keepalived-1.1.19/genhash'
Make complete
13:38:38
#make install
make -C keepalived install
make[1]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived'
install -d /usr/sbin
install -m 700 ../bin/keepalived /usr/sbin/
install -d /usr/etc/rc.d/init.d
install -m 755 etc/init.d/keepalived.init /usr/etc/rc.d/init.d/keepalived
install -d /usr/etc/sysconfig
install -m 755 etc/init.d/keepalived.sysconfig /usr/etc/sysconfig/keepalived
install -d /usr/etc/keepalived/samples
install -m 644 etc/keepalived/keepalived.conf /usr/etc/keepalived/
...
install -m 644 ../doc/man/man5/keepalived.conf.5 /usr/share/man/man5
install -m 644 ../doc/man/man8/keepalived.8 /usr/share/man/man8
make[1]: Leaving directory `/var/downloads/ipvs/keepalived-1.1.19/keepalived'
make -C genhash install
make[1]: Entering directory `/var/downloads/ipvs/keepalived-1.1.19/genhash'
install -d /usr/bin
install -m 755 ../bin/genhash /usr/bin/
install -d /usr/share/man/man1
install -m 644 ../doc/man/man1/genhash.1 /usr/share/man/man1
make[1]: Leaving directory `/var/downloads/ipvs/keepalived-1.1.19/genhash'
13:38:41
#cd /var/downloads/ipvs/keepalived-1.1.19/
                             keepalived -v
Keepalived v1.1.19 (03/10,2010)
13:38:51
#ps ax|grep keep
 1513 ?        Ss     0:00 /usr/local/sbin/keepalived -d -l
 1515 ?        S      0:00 /usr/local/sbin/keepalived -d -l
 1516 ?        S      0:00 /usr/local/sbin/keepalived -d -l
13406 pts/1    S+     0:00 grep keep
13:39:06
#pkill keepalived

13:39:15
#ps ax|grep keep
13431 pts/1    S+     0:00 grep keep
13:39:16
#keepalived -D -d 9 -l
unexpected argument 9
13:39:28
#keepalived -D -d9 -l

13:39:30
#ps ax|grep keep
13440 ?        Ss     0:00 keepalived -D -d 9 -l
13442 ?        S      0:00 keepalived -D -d 9 -l
13443 ?        S      0:00 keepalived -D -d 9 -l
13459 pts/1    S+     0:00 grep keep
13:39:33
#tail /var/log/syslog
Mar 10 12:39:28 gw Keepalived_healthcheckers:    lb_kind = NAT
Mar 10 12:39:28 gw Keepalived_healthcheckers: Using LinkWatch kernel netlink reflector...
Mar 10 12:39:29 gw Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) Entering MASTER STATE
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) setting protocol VIPs.
Mar 10 12:39:30 gw Keepalived_vrrp: Netlink: error: File exists, type=(20), seq=1268224769, pid=0
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.8.104
Mar 10 12:39:30 gw Keepalived: Starting Keepalived v1.1.19 (03/10,2010)
Mar 10 12:39:30 gw Keepalived: daemon is already running
Mar 10 12:39:35 gw Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.8.104
13:39:42
#tail /var/log/syslog
Mar 10 12:39:28 gw Keepalived_healthcheckers:    lb_kind = NAT
Mar 10 12:39:28 gw Keepalived_healthcheckers: Using LinkWatch kernel netlink reflector...
Mar 10 12:39:29 gw Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) Entering MASTER STATE
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) setting protocol VIPs.
Mar 10 12:39:30 gw Keepalived_vrrp: Netlink: error: File exists, type=(20), seq=1268224769, pid=0
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.8.104
Mar 10 12:39:30 gw Keepalived: Starting Keepalived v1.1.19 (03/10,2010)
Mar 10 12:39:30 gw Keepalived: daemon is already running
Mar 10 12:39:35 gw Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.8.104
13:39:57
#tail /var/log/messages
Mar 10 12:39:28 gw Keepalived_healthcheckers:    alpha is OFF, omega is OFF
Mar 10 12:39:28 gw Keepalived_healthcheckers:    quorum = 1, hysteresis = 0
Mar 10 12:39:28 gw Keepalived_healthcheckers:    lb_kind = NAT
Mar 10 12:39:28 gw Keepalived_healthcheckers: Using LinkWatch kernel netlink reflector...
Mar 10 12:39:29 gw Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) Entering MASTER STATE
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) setting protocol VIPs.
Mar 10 12:39:30 gw Keepalived_vrrp: Netlink: error: File exists, type=(20), seq=1268224769, pid=0
Mar 10 12:39:30 gw Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.8.104
Mar 10 12:39:35 gw Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.8.104
13:40:04
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.8.104:3128 rr persistent 600
13:40:13
#vim /etc/apt/sources.list
--- /tmp/l3-saved-4349.3334.7216	2010-03-10 12:42:14.000000000 +0000
+++ /etc/apt/sources.list	2010-03-10 12:42:27.000000000 +0000
@@ -1 +1,2 @@
-deb http://ftp.debian.org/debian lenny main
+deb http://ftp.debian.org/debian squeeze main
+# deb http://ftp.debian.org/debian lenny main
13:42:27
#au
Получено:1 http://ftp.debian.org squeeze Release.gpg [835B]
Получено:2 http://ftp.debian.org squeeze/main Translation-ru [483kB]
Получено:3 http://ftp.debian.org squeeze Release [89,5kB]
Получено:4 http://ftp.debian.org squeeze/main Packages [6188kB]
Получено 6762kБ за 18s (357kБ/c)
Чтение списков пакетов... Готово
13:42:55
#ai keepalived
Чтение списков пакетов... Готово
Построение дерева зависимостей
Чтение информации о состоянии... Готово
Пакеты, которые будут обновлены:
  keepalived
обновлено 1, установлено 0 новых пакетов, для удаления отмечено 0 пакетов, и 252 пакетов не обновлено.
Необходимо скачать 139kБ архивов.
После данной операции, объём занятого дискового пространства возрастёт на 16,4kB.
Получено:1 http://ftp.debian.org squeeze/main keepalived 1.1.17-2 [139kB]
Получено 139kБ за 0s (229kБ/c)
(Чтение базы данных... на данный момент установлено 20235 файлов и каталогов.)
Подготовка к замене пакета keepalived 1.1.15-1 (используется файл .../keepalived_1.1.17-2_amd64.deb)...
Stopping keepalived: keepalived.
Распаковывается замена для пакета keepalived ...
Обрабатываются триггеры для man-db ...
Настраивается пакет keepalived (1.1.17-2) ...
Starting keepalived: keepalived.
13:43:11
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
13:43:18
#/etc/init.d/keepalived start
Starting keepalived: keepalived.
13:43:23
#keepalived -v
Keepalived v1.1.17 (05/28,2009)
13:43:26
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.8.104:3128 rr persistent 600
13:43:31
#tail /var/log/syslog
Mar 10 12:43:23 gw Keepalived_vrrp: Opening file '/etc/keepalived/keepalived.conf'.
Mar 10 12:43:23 gw Keepalived_healthcheckers: Using MII-BMSR NIC polling thread...
Mar 10 12:43:23 gw Keepalived_healthcheckers: Registering Kernel netlink reflector
Mar 10 12:43:23 gw Keepalived_healthcheckers: Registering Kernel netlink command channel
Mar 10 12:43:23 gw Keepalived_healthcheckers: Opening file '/etc/keepalived/keepalived.conf'.
Mar 10 12:43:23 gw Keepalived_vrrp: Configuration is using : 65158 Bytes
Mar 10 12:43:23 gw Keepalived_healthcheckers: Configuration is using : 11951 Bytes
Mar 10 12:43:24 gw Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE
Mar 10 12:43:25 gw Keepalived_vrrp: VRRP_Instance(VI_1) Entering MASTER STATE
Mar 10 12:43:25 gw Keepalived_vrrp: Netlink: error: File exists, type=(20), seq=1268225004, pid=0
13:43:38
#dpkg-reconfigure keepalived
Stopping keepalived: keepalived.
Starting keepalived: keepalived.
13:44:13
#tail /var/log/syslog
Mar 10 12:44:12 gw Keepalived_vrrp: Opening file '/etc/keepalived/keepalived.conf'.
Mar 10 12:44:12 gw Keepalived_healthcheckers: Using MII-BMSR NIC polling thread...
Mar 10 12:44:12 gw Keepalived_healthcheckers: Registering Kernel netlink reflector
Mar 10 12:44:12 gw Keepalived_healthcheckers: Registering Kernel netlink command channel
Mar 10 12:44:12 gw Keepalived_healthcheckers: Opening file '/etc/keepalived/keepalived.conf'.
Mar 10 12:44:12 gw Keepalived_vrrp: Configuration is using : 65158 Bytes
Mar 10 12:44:12 gw Keepalived_healthcheckers: Configuration is using : 11951 Bytes
Mar 10 12:44:13 gw Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE
Mar 10 12:44:14 gw Keepalived_vrrp: VRRP_Instance(VI_1) Entering MASTER STATE
Mar 10 12:44:14 gw Keepalived_vrrp: Netlink: error: File exists, type=(20), seq=1268225053, pid=0
13:44:23
#grep -v "^#" /etc/keepalived/keepalived.conf
 global_defs {
   # Определим параметры e-mail для извещения о работе
   # health-checker - это полезно, при падении одного
   # из каналов вам придет письмо с новостью об этом
      notification_email {
        amel@sperco.com.ua
      }
      notification_email_from amel@sperco.com.ua
      smtp_server 192.168.8.100
      smtp_connect_timeout 30
...
                 status_code 200
               }
                connect_timeout 10
                connect_port 80
                nb_get_retry 3
                delay_before_retry 800
           }
       }
   }
   # Аналогично для третьего Real-server
13:44:48
#grep -v "^ #" /etc/keepalived/keepalived.conf
 global_defs {
      notification_email {
        amel@sperco.com.ua
      }
      notification_email_from amel@sperco.com.ua
      smtp_server 192.168.8.100
      smtp_connect_timeout 30
   }
   vrrp_instance VI_1 {
       state MASTER
...
#               path http://ya.ru
#                 path /white.html
#                 status_code 200
#               }
#               connect_timeout 10
#               nb_get_retry 3
#               delay_before_retry 8
#           }
#       }
#   }
13:45:12
#vim /etc/keepalived/keepalived.conf
--- /tmp/l3-saved-4349.32737.14181	2010-03-10 12:45:56.000000000 +0000
+++ /etc/keepalived/keepalived.conf	2010-03-10 12:46:10.000000000 +0000
@@ -80,7 +80,7 @@
                }
    # Время на установление соединения (сек.)
                connect_timeout 10
-		connect_port 80
+#		connect_port 80
    # Количество попыток соединиться (сек.)
                nb_get_retry 3
    # Соответственно задержка между попытками (сек.)
@@ -100,7 +100,7 @@
                  status_code 200
                }
                	connect_timeout 10
-		connect_port 80
+#		connect_port 80
 	        nb_get_retry 3
          	delay_before_retry 800
            }
13:46:10
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
13:46:16
#ip addr sh
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:21 brd ff:ff:ff:ff:ff:ff
    inet 192.168.8.250/24 brd 192.168.8.255 scope global eth0
    inet 192.168.8.104/32 scope global eth0
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:22 brd ff:ff:ff:ff:ff:ff
    inet 192.168.10.1/24 brd 192.168.10.255 scope global eth1
...
17: imq11: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
18: imq12: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
19: imq13: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
20: imq14: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
21: imq15: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
13:46:24
#ip addr del 192.168.8.104
Not enough information: "dev" argument is required.
13:46:38
#ip addr del 192.168.8.104 dev eth0
Warning: Executing wildcard deletion to stay compatible with old scripts.
         Explicitly specify the prefix length (192.168.8.104/32) to avoid this warning.
         This special behaviour is likely to disappear in further releases,
         fix your scripts!
13:46:42
#ip addr del 192.168.8.104/32 dev eth0
RTNETLINK answers: Cannot assign requested address
13:46:50
#ip addr sh
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:21 brd ff:ff:ff:ff:ff:ff
    inet 192.168.8.250/24 brd 192.168.8.255 scope global eth0
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:22 brd ff:ff:ff:ff:ff:ff
    inet 192.168.10.1/24 brd 192.168.10.255 scope global eth1
4: eth2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
...
17: imq11: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
18: imq12: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
19: imq13: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
20: imq14: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
21: imq15: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
13:46:53
#/etc/init.d/keepalived start
Starting keepalived: keepalived.
13:47:01
#tail /var/log/syslog
Mar 10 12:47:01 gw Keepalived_healthcheckers: Configuration is using : 11919 Bytes
Mar 10 12:47:01 gw Keepalived_vrrp: Registering Kernel netlink reflector
Mar 10 12:47:01 gw Keepalived_vrrp: Registering Kernel netlink command channel
Mar 10 12:47:01 gw Keepalived_vrrp: Registering gratutious ARP shared channel
Mar 10 12:47:01 gw Keepalived_vrrp: Initializing ipvs 2.6
Mar 10 12:47:01 gw Keepalived_vrrp: Opening file '/etc/keepalived/keepalived.conf'.
Mar 10 12:47:01 gw Keepalived_vrrp: Configuration is using : 65126 Bytes
Mar 10 12:47:02 gw Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE
Mar 10 12:47:03 gw Keepalived_vrrp: VRRP_Instance(VI_1) Entering MASTER STATE
Mar 10 12:47:03 gw Keepalived_vrrp: Netlink: skipping nl_cmd msg...
13:47:09
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.8.104:3128 rr persistent 600
13:47:17
#nc 192.168.8.104 3128
get (UNKNOWN) [192.168.8.104] 3128 (?) : Connection refused
13:47:30
#get http://ru.ru

13:47:35
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.8.104:3128 rr persistent 600
13:47:49
#ipvsadm -l -n -c
IPVS connection entries
pro expire state       source             virtual            destination
13:47:52
#vim /etc/keepalived/keepalived.conf
--- /tmp/l3-saved-4349.31613.17473	2010-03-10 12:50:25.000000000 +0000
+++ /etc/keepalived/keepalived.conf	2010-03-10 12:50:42.000000000 +0000
@@ -25,7 +25,7 @@
 #           auth_pass 1111
 #       }
        virtual_ipaddress {
-           192.168.8.104
+           192.168.8.250
        }
    }
 
@@ -38,7 +38,7 @@
    # адреса, слушаемые Squid
 
    # Далее описывается этот виртуальный сервер и 2 реальных
-   virtual_server 192.168.8.104 3128 {
+   virtual_server 192.168.8.250 3128 {
 #   virtual_server fwmark 1 {
        delay_loop 6
     
13:50:49
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.8.250:3128 rr persistent 600
13:50:53
#ip addr del 192.168.8.104/32 dev eth0
RTNETLINK answers: Cannot assign requested address
13:51:28
#ip addr sh
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:21 brd ff:ff:ff:ff:ff:ff
    inet 192.168.8.250/24 brd 192.168.8.255 scope global eth0
    inet 192.168.8.250/32 scope global eth0
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:22 brd ff:ff:ff:ff:ff:ff
    inet 192.168.10.1/24 brd 192.168.10.255 scope global eth1
...
17: imq11: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
18: imq12: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
19: imq13: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
20: imq14: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
21: imq15: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
/dev/hvc0
13:52:38
#ifc
bash: ifc: команда не найдена
13:52:40
#ifconfig
eth0      Link encap:Ethernet  HWaddr 00:16:3e:40:aa:21
          inet addr:192.168.8.250  Bcast:0.0.0.0  Mask:255.255.255.255
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:338407 errors:0 dropped:0 overruns:0 frame:0
          TX packets:97669 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:35297681 (33.6 MiB)  TX bytes:16016983 (15.2 MiB)
          Interrupt:13
eth1      Link encap:Ethernet  HWaddr 00:16:3e:40:aa:22
          inet addr:192.168.10.1  Bcast:192.168.10.255  Mask:255.255.255.0
...
          collisions:0 txqueuelen:1000
          RX bytes:4794597 (4.5 MiB)  TX bytes:173053838 (165.0 MiB)
          Interrupt:16
lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:4 errors:0 dropped:0 overruns:0 frame:0
          TX packets:4 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:296 (296.0 B)  TX bytes:296 (296.0 B)
13:52:41
#ip addr sh
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:21 brd ff:ff:ff:ff:ff:ff
    inet 192.168.8.250/32 scope global eth0
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:16:3e:40:aa:22 brd ff:ff:ff:ff:ff:ff
    inet 192.168.10.1/24 brd 192.168.10.255 scope global eth1
4: eth2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
...
17: imq11: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
18: imq12: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
19: imq13: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
20: imq14: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
21: imq15: <NOARP> mtu 16000 qdisc noop state DOWN qlen 11000
    link/void
13:52:48
#ifconfig eth0 down

13:53:02
#ifconfig eth0 192.168.8.250 up

13:53:13
#ifconfig eth0 down

13:53:38
#vim /etc/keepalived/keepalived.conf
--- /tmp/l3-saved-14223.25321.21310	2010-03-10 12:53:53.000000000 +0000
+++ /etc/keepalived/keepalived.conf	2010-03-10 12:54:10.000000000 +0000
@@ -25,7 +25,7 @@
 #           auth_pass 1111
 #       }
        virtual_ipaddress {
-           192.168.8.250
+           192.168.18.250
        }
    }
 
@@ -38,7 +38,7 @@
    # адреса, слушаемые Squid
 
    # Далее описывается этот виртуальный сервер и 2 реальных
-   virtual_server 192.168.8.250 3128 {
+   virtual_server 192.168.18.250 3128 {
 #   virtual_server fwmark 1 {
        delay_loop 6
     
13:54:10
#keepalived -d9 -D -l

13:54:19
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
13:55:06
#ipvsadm -a -t 192.168.18.250:3128 -r 192.168.30.2:3128 -m

13:55:42
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      0          0
13:55:45
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      1          1
/dev/hvc0
13:56:58
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
13:57:10
#vim /etc/keepalived/keepalived.conf
13:57:10
#vim /etc/keepalived/keepalived.conf.ext
13:58:30
#:q
               nb_get_retry 3
-- INSERT --
   # Соответственно задержка между попытками (сек.)
               delay_before_retry 800
   # Воз}¼Ð¾Ð¶Ð½Ð¾, вы захотите использовать другие тайм-ауты
       }
   # Аналогично для второго Real-server
       real_server 192.168.30.3 3128 {
           weight 1
           HTTP_GET {
               url {
                 path http://yandex.ru/white.html
#                  path /
#                path http://ya.ru/
                 status_code 200
-- INSERT --
"/etc/keepalived/keepalived.conf" 128L, 5064C written
13:59:22
#route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.20.0    0.0.0.0         255.255.255.0   U     0      0        0 eth2
192.168.30.0    0.0.0.0         255.255.255.0   U     0      0        0 eth3
192.168.10.0    0.0.0.0         255.255.255.0   U     0      0        0 eth1
192.168.8.0     0.0.0.0         255.255.255.0   U     0      0        0 eth0
0.0.0.0         192.168.10.2    0.0.0.0         UG    0      0        0 eth1
14:00:58
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
14:01:10
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      1          0
14:01:17
#ipvsadm -a -t 192.168.18.250:3128 -r 192.168.30.2:3128 -m
                      d
14:01:54
#ipvsadm -D -t 192.168.18.250:3128

14:02:39
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
/dev/pts/1
14:03:57
#cd /var/downloads/

14:04:00
#keepalived -v
Keepalived v1.1.19 (03/10,2010)
14:04:03
#ps ax|grep keep
14377 ?        Ss     0:00 keepalived -d9 -D -l
14379 ?        S      0:00 keepalived -d9 -D -l
14380 ?        S      0:00 keepalived -d9 -D -l
14880 pts/2    S+     0:00 grep keep
14:04:10
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
14:04:20
#ps ax|grep keep
14377 ?        Ss     0:00 keepalived -d9 -D -l
14379 ?        S      0:00 keepalived -d9 -D -l
14380 ?        S      0:00 keepalived -d9 -D -l
14912 pts/2    S+     0:00 grep keep
14:04:22
#pkill keepalived

14:04:42
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
/dev/pts/1
14:05:21
#ls /usr/src/linux-source-2.6.26
arch           fs       MAINTAINERS     REPORTING-BUGS  version.Debian
block          include  Makefile        samples         virt
COPYING        init     mm              scripts         vmlinux
CREDITS        ipc      modules.order   security        vmlinux.o
crypto         Kbuild   Module.symvers  sound
Documentation  kernel   net             System.map
drivers        lib      README          usr
14:05:48
#ls /usr/src/linux-source-2.6.26/include/
acpi          asm-frv        asm-mips     asm-sparc    crypto    net     xen
asm           asm-generic    asm-mn10300  asm-sparc64  Kbuild    pcmcia
asm-alpha     asm-h8300      asm-parisc   asm-um       keys      rdma
asm-arm       asm-ia64       asm-powerpc  asm-v850     linux     rxrpc
asm-avr32     asm-m32r       asm-ppc      asm-x86      math-emu  scsi
asm-blackfin  asm-m68k       asm-s390     asm-xtensa   media     sound
asm-cris      asm-m68knommu  asm-sh       config       mtd       video
14:05:52
#ls /usr/src/linux-2.6.32.3/include/
acpi         asm-x86  drm     linux     mtd     rdma   sound  xen
asm          config   Kbuild  math-emu  net     rxrpc  trace
asm-generic  crypto   keys    media     pcmcia  scsi   video
14:06:02
#ls /usr/src/linux-source-2.6.26/include/net
9p            ieee80211_crypt.h        llc_c_ac.h       raw.h
act_api.h     ieee80211.h              llc_c_ev.h       rawv6.h
addrconf.h    ieee80211_radiotap.h     llc_conn.h       red.h
af_rxrpc.h    if_inet6.h               llc_c_st.h       request_sock.h
af_unix.h     inet6_connection_sock.h  llc.h            rose.h
ah.h          inet6_hashtables.h       llc_if.h         route.h
arp.h         inet_common.h            llc_pdu.h        rtnetlink.h
atmclip.h     inet_connection_sock.h   llc_s_ac.h       sch_generic.h
ax25.h        inet_ecn.h               llc_sap.h        scm.h
ax88796.h     inet_frag.h              llc_s_ev.h       sctp
...
dn_nsp.h      ip_fib.h                 netlink.h        udp.h
dn_route.h    ip.h                     net_namespace.h  udplite.h
dsfield.h     ipip.h                   netns            wext.h
dst.h         ipv6.h                   netrom.h         wireless.h
esp.h         ip_vs.h                  nexthop.h        x25device.h
fib_rules.h   ipx.h                    p8022.h          x25.h
flow.h        irda                     pkt_cls.h        xfrm.h
genetlink.h   iucv                     pkt_sched.h
gen_stats.h   iw_handler.h             protocol.h
icmp.h        lapb.h                   psnap.h
14:06:24
#ls /usr/src/linux-2.6.32.3/include/net
9p               garp.h                   iw_handler.h     protocol.h
act_api.h        genetlink.h              lapb.h           psnap.h
addrconf.h       gen_stats.h              lib80211.h       raw.h
af_ieee802154.h  icmp.h                   llc_c_ac.h       rawv6.h
af_rxrpc.h       ieee80211_radiotap.h     llc_c_ev.h       red.h
af_unix.h        ieee802154.h             llc_conn.h       regulatory.h
ah.h             ieee802154_netdev.h      llc_c_st.h       request_sock.h
arp.h            if_inet6.h               llc.h            rose.h
atmclip.h        inet6_connection_sock.h  llc_if.h         route.h
ax25.h           inet6_hashtables.h       llc_pdu.h        rtnetlink.h
...
dn_nsp.h         ipcomp.h                 netlink.h        transp_v6.h
dn_route.h       ipconfig.h               net_namespace.h  udp.h
dsa.h            ip_fib.h                 netns            udplite.h
dsfield.h        ip.h                     netrom.h         wext.h
dst.h            ipip.h                   nexthop.h        wimax.h
dst_ops.h        ipv6.h                   nl802154.h       wpan-phy.h
esp.h            ip_vs.h                  p8022.h          x25device.h
ethoc.h          ipx.h                    phonet           x25.h
fib_rules.h      irda                     pkt_cls.h        xfrm.h
flow.h           iucv                     pkt_sched.h
14:07:15
#traceroute 192.168.8.100
traceroute to 192.168.8.100 (192.168.8.100), 30 hops max, 40 byte packets^C
14:07:26
#traceroute 192.168.8.100 -n
traceroute to 192.168.8.100 (192.168.8.100), 30 hops max, 40 byte packets
 1  192.168.8.100  0.199 ms  0.174 ms  0.149 ms
14:07:28
#traceroute -n ya.ru
traceroute to ya.ru (213.180.204.8), 30 hops max, 40 byte packets
 1  192.168.10.2  0.196 ms  0.173 ms  0.219 ms
 2  192.168.8.106  2.994 ms  2.987 ms  2.970 ms^C
14:07:47
#traceroute -n ya.ru
traceroute to ya.ru (213.180.204.8), 30 hops max, 40 byte packets
 1  192.168.10.2  0.174 ms  0.191 ms  0.152 ms
 2  192.168.8.106  0.529 ms  0.487 ms  0.526 ms
 3  * * *
 4  10.50.19.42  92.325 ms  95.164 ms  95.879 ms
 5  * * *
 6  77.88.56.101  147.242 ms  149.371 ms  150.757 ms
 7  213.180.204.8  148.525 ms  149.208 ms  150.409 ms
14:07:53
#traceroute -n ya.ru
traceroute to ya.ru (77.88.21.8), 30 hops max, 40 byte packets
 1  192.168.10.2  0.156 ms  0.163 ms  0.151 ms
 2  192.168.8.106  0.405 ms  0.518 ms  0.627 ms
 3  * * *
 4  10.50.19.46  69.278 ms  70.920 ms  71.141 ms
 5  * * *
 6  87.250.233.118  124.998 ms  126.773 ms  129.257 ms
 7  87.250.233.126  128.464 ms  129.916 ms  131.788 ms
 8  87.250.228.136  129.202 ms  108.522 ms  108.577 ms
 9  77.88.21.8  112.517 ms  129.765 ms  129.994 ms
14:08:00
#nc 192.168.30.2 3128
get http://ru.ru
HTTP/1.0 301 Moved Permanently
Server: nginx/0.6.31
Date: Wed, 10 Mar 2010 11:10:52 GMT
Content-Type: text/html; charset=iso-8859-1
Location: http://ok.ru/
X-Cache: MISS from squid.local
Via: 1.0 squid.local (squid/3.0.STABLE24)
Proxy-Connection: close
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<HTML><HEAD>
<TITLE>301 Moved Permanently</TITLE>
</HEAD><BODY>
<H1>Moved Permanently</H1>
The document has moved <A HREF="http://ok.ru/">here</A>.<P>
</BODY></HTML>
14:08:26
#nc 192.168.30.2 3128
get http://ya.ru
HTTP/1.0 200 OK
Server: nginx
Date: Wed, 10 Mar 2010 11:11:02 GMT
Content-Type: text/html; charset=utf-8
Content-Length: 4962
Last-Modified: Tue, 12 Jan 2010 15:29:06 GMT
Accept-Ranges: bytes
X-Cache: MISS from squid.local
Via: 1.0 squid.local (squid/3.0.STABLE24)
Proxy-Connection: close
14:08:39
#vim /etc/keepalived/keepalived.conf
14:08:39
#vim /etc/keepalived/keepalived.conf.100120
14:09:17
#vim /etc/keepalived/keepalived.conf
--- /tmp/l3-saved-15048.2533.25256	2010-03-10 13:09:19.000000000 +0000
+++ /etc/keepalived/keepalived.conf	2010-03-10 13:10:14.000000000 +0000
@@ -25,7 +25,7 @@
 #           auth_pass 1111
 #       }
        virtual_ipaddress {
-           192.168.200.1
+           192.168.18.250
        }
    }
 
@@ -38,7 +38,7 @@
    # адреса, слушаемые Squid
 
    # Далее описывается этот виртуальный сервер и 2 реальных
-   virtual_server 192.168.200.1 3128 {
+   virtual_server 192.168.8.250 3128 {
 #   virtual_server fwmark 1 {
        delay_loop 6
     
@@ -63,8 +63,8 @@
        virtualhost ya.ru
    # Real-server - в нашем случае первый адрес, на котором 
    # слушает Squid
-#       real_server 192.168.10.2 3128 {
-       real_server 127.0.0.2 3128 {
+       real_server 192.168.30.2 3128 {
+#       real_server 127.0.0.2 3128 {
            weight 1
    # Для проверки будем слать HTTP GET-запрос и считать, 
    # что канал доступен, если через него пришел ответ 200 
@@ -89,8 +89,8 @@
        }
 
    # Аналогично для второго Real-server
-#       real_server 192.168.20.2 3128 {
-       real_server 127.0.0.3 3128 {
+       real_server 192.168.30.3 3128 {
+#       real_server 127.0.0.3 3128 {
            weight 1
            HTTP_GET {
                url {
14:10:14
#ps ax|grep keep
14947 ?        Ss     0:00 /usr/sbin/keepalived
14948 ?        S      0:00 /usr/sbin/keepalived
14950 ?        S      0:00 /usr/sbin/keepalived
15337 pts/2    S+     0:00 grep keep
14:10:20
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived.
14:10:32
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.8.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      0          0
  -> 192.168.30.3:3128            Masq    1      0          0
/dev/pts/1
14:12:42
#ipvsadm -l -n
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      0          0
  -> 192.168.30.3:3128            Masq    1      0          0
14:12:46
#keepalived -v
Keepalived v1.1.19 (03/10,2010)
14:13:20
#ipvsadm -l -n -c
IPVS connection entries
pro expire state       source             virtual            destination
TCP 01:26  TIME_WAIT   192.168.8.140:56054 192.168.18.250:3128 192.168.30.3:3128
TCP 09:19  NONE        192.168.8.140:0    192.168.18.250:3128 192.168.30.3:3128
TCP 07:53  NONE        192.168.8.140:0    192.168.8.250:3128 192.168.30.3:3128
TCP 00:00  TIME_WAIT   192.168.8.140:47985 192.168.8.250:3128 192.168.30.3:3128
14:13:32
#ipvsadm -l -n -c
IPVS connection entries
pro expire state       source             virtual            destination
TCP 06:00  NONE        192.168.8.140:0    192.168.18.250:3128 192.168.30.3:3128
TCP 04:34  NONE        192.168.8.140:0    192.168.8.250:3128 192.168.30.3:3128
14:16:51
#ipvsadm -l -n -c
IPVS connection entries
pro expire state       source             virtual            destination
прошла 21 минута
14:37:57
#ipvsadm -ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      1          0
  -> 192.168.30.3:3128            Masq    1      0          0
прошло 37 минут
15:15:04
#ipvsadm -ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      1          1
  -> 192.168.30.3:3128            Masq    1      0          0
15:15:22
#ipvsadm -ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.18.250:3128 rr persistent 600
  -> 192.168.30.2:3128            Masq    1      1          1
  -> 192.168.30.3:3128            Masq    1      1          1
15:17:18
#ipvsadm -lnc
IPVS connection entries
pro expire state       source             virtual            destination
TCP 01:35  FIN_WAIT    192.168.8.141:38499 192.168.18.250:3128 192.168.30.3:3128
TCP 00:00  TIME_WAIT   192.168.8.140:47116 192.168.18.250:3128 192.168.30.2:3128
TCP 07:51  NONE        192.168.8.140:0    192.168.18.250:3128 192.168.30.2:3128
TCP 08:57  NONE        192.168.8.141:0    192.168.18.250:3128 192.168.30.3:3128
15:17:21
#iptl
Chain INPUT (policy ACCEPT)
target     prot opt source               destination
Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination

Статистика

Время первой команды журнала13:37:54 2010- 3-10
Время последней команды журнала15:17:21 2010- 3-10
Количество командных строк в журнале101
Процент команд с ненулевым кодом завершения, % 5.94
Процент синтаксически неверно набранных команд, % 0.99
Суммарное время работы с терминалом *, час 1.04
Количество командных строк в единицу времени, команда/мин 1.62
Частота использования команд
ipvsadm23|=====================| 21.50%
/etc/init.d/keepalived9|========| 8.41%
vim9|========| 8.41%
grep8|=======| 7.48%
ip8|=======| 7.48%
ps6|=====| 5.61%
keepalived6|=====| 5.61%
tail6|=====| 5.61%
traceroute5|====| 4.67%
ls5|====| 4.67%
ifconfig4|===| 3.74%
cd3|==| 2.80%
nc3|==| 2.80%
pkill2|=| 1.87%
make2|=| 1.87%
iptl1|| 0.93%
ai1|| 0.93%
route1|| 0.93%
:q1|| 0.93%
dpkg-reconfigure1|| 0.93%
get1|| 0.93%
au1|| 0.93%
ifc1|| 0.93%
____
*) Интервалы неактивности длительностью 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$