/l3/users/gw.local/root :1 :2 :3 :4 :5 :6 :7 :8 :9 :10 :11 :12 :13 :14 :15 :16 :17 :18 :19 |
|
#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 |
#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' |
#cd /var/downloads/ipvs/keepalived-1.1.19/
keepalived -v Keepalived v1.1.19 (03/10,2010) |
#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 |
#pkill keepalived
|
#ps ax|grep keep
13431 pts/1 S+ 0:00 grep keep |
#keepalived -D -d 9 -l
unexpected argument 9 |
#keepalived -D -d9 -l
|
#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 |
#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 |
#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 |
#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 |
#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 |
#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 |
#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) Чтение списков пакетов... Готово |
#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. |
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived. |
#/etc/init.d/keepalived start
Starting keepalived: keepalived. |
#keepalived -v
Keepalived v1.1.17 (05/28,2009) |
#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 |
#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 |
#dpkg-reconfigure keepalived
Stopping keepalived: keepalived. Starting keepalived: keepalived. |
#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 |
#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 |
#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 # } # } # } |
#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 } |
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived. |
#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 |
#ip addr del 192.168.8.104
Not enough information: "dev" argument is required. |
#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! |
#ip addr del 192.168.8.104/32 dev eth0
RTNETLINK answers: Cannot assign requested address |
#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 |
#/etc/init.d/keepalived start
Starting keepalived: keepalived. |
#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... |
#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 |
#nc 192.168.8.104 3128
get (UNKNOWN) [192.168.8.104] 3128 (?) : Connection refused |
#get http://ru.ru
|
#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 |
#ipvsadm -l -n -c
IPVS connection entries pro expire state source virtual destination |
#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 |
#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 |
#ip addr del 192.168.8.104/32 dev eth0
RTNETLINK answers: Cannot assign requested address |
#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 |
#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) |
#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 |
#ifconfig eth0 down
|
#ifconfig eth0 192.168.8.250 up
|
#ifconfig eth0 down
|
#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 |
#keepalived -d9 -D -l
|
#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 |
#ipvsadm -a -t 192.168.18.250:3128 -r 192.168.30.2:3128 -m
|
#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 |
#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 |
#vim /etc/keepalived/keepalived.conf
|
#vim /etc/keepalived/keepalived.conf.ext
|
#: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 |
#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 |
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived. |
#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 |
#ipvsadm -a -t 192.168.18.250:3128 -r 192.168.30.2:3128 -m
d |
#ipvsadm -D -t 192.168.18.250:3128
|
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived. |
#keepalived -v
Keepalived v1.1.19 (03/10,2010) |
#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 |
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived. |
#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 |
#pkill keepalived
|
#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 |
#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 |
#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 |
#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 |
#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 |
#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 |
#traceroute 192.168.8.100
traceroute to 192.168.8.100 (192.168.8.100), 30 hops max, 40 byte packets^C |
#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 |
#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 |
#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 |
#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 |
#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> |
#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 |
#vim /etc/keepalived/keepalived.conf
|
#vim /etc/keepalived/keepalived.conf.100120
|
#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 { |
#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 |
#/etc/init.d/keepalived stop
Stopping keepalived: keepalived. |
#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 |
#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 |
#keepalived -v
Keepalived v1.1.19 (03/10,2010) |
#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 |
#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 |
#ipvsadm -l -n -c
IPVS connection entries pro expire state source virtual destination |
#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 |
#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 |
#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 |
#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 |
#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 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду w. В поле WHAT, соответствующем текущему терминалу, должна быть указана программа script.
Команды, при наборе которых были допущены синтаксические ошибки, выводятся перечёркнутым текстом:
$ l s-l bash: l: command not found |
Если код завершения команды равен нулю, команда была выполнена без ошибок. Команды, код завершения которых отличен от нуля, выделяются цветом.
$ test 5 -lt 4 |
Команды, ход выполнения которых был прерван пользователем, выделяются цветом.
$ 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 |
Команды, выполненные с привилегиями суперпользователя, выделяются слева красной чертой.
# id uid=0(root) gid=0(root) Gruppen=0(root) |
Изменения, внесённые в текстовый файл с помощью редактора, запоминаются и показываются в журнале в формате ed. Строки, начинающиеся символом "<", удалены, а строки, начинающиеся символом ">" -- добавлены.
$ vi ~/.bashrc
|
Для того чтобы изменить файл в соответствии с показанными в диффшоте изменениями, можно воспользоваться командой patch. Нужно скопировать изменения, запустить программу patch, указав в качестве её аргумента файл, к которому применяются изменения, и всавить скопированный текст:
$ patch ~/.bashrc |
Для того чтобы получить краткую справочную информацию о команде, нужно подвести к ней мышь. Во всплывающей подсказке появится краткое описание команды.
Если справочная информация о команде есть, команда выделяется голубым фоном, например: vi. Если справочная информация отсутствует, команда выделяется розовым фоном, например: notepad.exe. Справочная информация может отсутствовать в том случае, если (1) команда введена неверно; (2) если распознавание команды LiLaLo выполнено неверно; (3) если информация о команде неизвестна LiLaLo. Последнее возможно для редких команд.
Большие, в особенности многострочные, всплывающие подсказки лучше всего показываются браузерами KDE Konqueror, Apple Safari и Microsoft Internet Explorer. В браузерах Mozilla и Firefox они отображаются не полностью, а вместо перевода строки выводится специальный символ.
Время ввода команды, показанное в журнале, соответствует времени начала ввода командной строки, которое равно тому моменту, когда на терминале появилось приглашение интерпретатора
Имя терминала, на котором была введена команда, показано в специальном блоке. Этот блок показывается только в том случае, если терминал текущей команды отличается от терминала предыдущей.
Вывод не интересующих вас в настоящий момент элементов журнала, таких как время, имя терминала и других, можно отключить. Для этого нужно воспользоваться формой управления журналом вверху страницы.
Небольшие комментарии к командам можно вставлять прямо из командной строки. Комментарий вводится прямо в командную строку, после символов #^ или #v. Символы ^ и v показывают направление выбора команды, к которой относится комментарий: ^ - к предыдущей, v - к следующей. Например, если в командной строке было введено:
$ whoami
user
$ #^ Интересно, кто я?в журнале это будет выглядеть так:
$ whoami
user
Интересно, кто я? |
Если комментарий содержит несколько строк, его можно вставить в журнал следующим образом:
$ whoami
user
$ cat > /dev/null #^ Интересно, кто я?
Программа whoami выводит имя пользователя, под которым мы зарегистрировались в системе. - Она не может ответить на вопрос о нашем назначении в этом мире.В журнале это будет выглядеть так:
$ whoami user
|
Комментарии, не относящиеся непосредственно ни к какой из команд, добавляются точно таким же способом, только вместо симолов #^ или #v нужно использовать символы #=
1 2 3 4Группы команд, выполненных на разных терминалах, разделяются специальной линией. Под этой линией в правом углу показано имя терминала, на котором выполнялись команды. Для того чтобы посмотреть команды только одного сенса, нужно щёкнуть по этому названию.
LiLaLo (L3) расшифровывается как Live Lab Log.
Программа разработана для повышения эффективности обучения Unix/Linux-системам.
(c) Игорь Чубин, 2004-2008