adding v 0.1 of LB script
This commit is contained in:
parent
ca8462aa12
commit
39d19e9e19
146
setup-lb.sh
Normal file
146
setup-lb.sh
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# echo script to set up load balancing on cluster nodes
|
||||||
|
# for use in CKA courses by Sander van Vugt
|
||||||
|
# version 0.1 - may be buggy!
|
||||||
|
# currently only supporting CentOS 7.x
|
||||||
|
# run this AFTER running setup-docker.sh and setup-kubetools.sh
|
||||||
|
# read and try to udnerstand before running this!
|
||||||
|
|
||||||
|
# install required software
|
||||||
|
yum install haproxy keepalived -y
|
||||||
|
|
||||||
|
# create keepalived config
|
||||||
|
# change IP address to anything that works in your environment!
|
||||||
|
cat << EOF >> /etc/keepalived/check_apiserver.sh
|
||||||
|
APISERVER_VIP=192.168.4.100
|
||||||
|
APISERVER_DEST_PORT=6443
|
||||||
|
|
||||||
|
errorExit() {
|
||||||
|
echo "* * * $*" 1>&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
curl --silent --max-time 2 --insecure https://localhost:${APISERVER_DEST_PORT}/ -o /dev/null || errorExit "Error GET https://localhost:${APISERVER_DEST_PORT}/"
|
||||||
|
if ip addr | grep -q ${APISERVER_VIP}; then
|
||||||
|
curl --silent --max-time 2 --insecure https://${APISERVER_VIP}:${APISERVER_DEST_PORT}/ -o /dev/null || errorExit "Error GET https://${APISERVER_VIP}:${APISERVER_DEST_PORT}/"
|
||||||
|
EOF
|
||||||
|
|
||||||
|
#### creating second script, make sure to change IP addresses!
|
||||||
|
|
||||||
|
cat << EOF >> /etc/keepalived/keepalived.conf
|
||||||
|
! /etc/keepalived/keepalived.conf
|
||||||
|
! Configuration File for keepalived
|
||||||
|
global_defs {
|
||||||
|
router_id LVS_DEVEL
|
||||||
|
}
|
||||||
|
vrrp_script check_apiserver {
|
||||||
|
script "/etc/keepalived/check_apiserver.sh"
|
||||||
|
interval 3
|
||||||
|
weight -2
|
||||||
|
fall 10
|
||||||
|
rise 2
|
||||||
|
}
|
||||||
|
|
||||||
|
vrrp_instance VI_1 {
|
||||||
|
state MASTER
|
||||||
|
interface ens33
|
||||||
|
virtual_router_id 151
|
||||||
|
priority 255
|
||||||
|
authentication {
|
||||||
|
auth_type PASS
|
||||||
|
auth_pass Password
|
||||||
|
}
|
||||||
|
virtual_ipaddress {
|
||||||
|
192.168.4.100/24
|
||||||
|
}
|
||||||
|
track_script {
|
||||||
|
check_apiserver
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chmod +x /etc/keepalived/check_apiserver.sh
|
||||||
|
|
||||||
|
### setting up haproxy
|
||||||
|
echo > /etc/haproxy/haproxy.cfg
|
||||||
|
cat << EOF >> /etc/haproxy/haproxy.cfg
|
||||||
|
|
||||||
|
# /etc/sysconfig/syslog
|
||||||
|
#
|
||||||
|
# local2.* /var/log/haproxy.log
|
||||||
|
#
|
||||||
|
log 127.0.0.1 local2
|
||||||
|
|
||||||
|
chroot /var/lib/haproxy
|
||||||
|
pidfile /var/run/haproxy.pid
|
||||||
|
maxconn 4000
|
||||||
|
user haproxy
|
||||||
|
group haproxy
|
||||||
|
daemon
|
||||||
|
|
||||||
|
# turn on stats unix socket
|
||||||
|
stats socket /var/lib/haproxy/stats
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# common defaults that all the 'listen' and 'backend' sections will
|
||||||
|
# use if not designated in their block
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
defaults
|
||||||
|
mode http
|
||||||
|
log global
|
||||||
|
option httplog
|
||||||
|
option dontlognull
|
||||||
|
option http-server-close
|
||||||
|
option forwardfor except 127.0.0.0/8
|
||||||
|
option redispatch
|
||||||
|
retries 3
|
||||||
|
timeout http-request 10s
|
||||||
|
timeout queue 1m
|
||||||
|
timeout connect 10s
|
||||||
|
timeout client 1m
|
||||||
|
timeout server 1m
|
||||||
|
timeout http-keep-alive 10s
|
||||||
|
timeout check 10s
|
||||||
|
maxconn 3000
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# main frontend which proxys to the backends
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# apiserver frontend which proxys to the masters
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
frontend apiserver
|
||||||
|
bind *:8443
|
||||||
|
mode tcp
|
||||||
|
option tcplog
|
||||||
|
default_backend apiserver
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# round robin balancing for apiserver
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
backend apiserver
|
||||||
|
option httpchk GET /healthz
|
||||||
|
http-check expect status 200
|
||||||
|
mode tcp
|
||||||
|
option ssl-hello-chk
|
||||||
|
balance roundrobin
|
||||||
|
server control1 192.168.4.87:6443 check
|
||||||
|
server control2 192.168.4.88:6443 check
|
||||||
|
server control3 192.168.4.89:6443 check
|
||||||
|
EOF
|
||||||
|
|
||||||
|
echo enter IP address of second HA node
|
||||||
|
read SECONDNODE
|
||||||
|
|
||||||
|
echo enter IP address of third HA node
|
||||||
|
read THIRDNODE
|
||||||
|
|
||||||
|
systemctl enable keepalived --now
|
||||||
|
systemctl enable haproxy --now
|
||||||
|
|
||||||
|
echo now edit the keepalived.conf file on $SECONDNODE and $THIRDNODE
|
||||||
|
echo change "state MASTER" to "state SLAVE"
|
||||||
|
echo set priority to 254 on $SECONDNODE and 253 on $THIRDNODE
|
||||||
|
echo and use systemctl to enable --now keepalived and haproxy services
|
||||||
|
echo I will automate this in a later version of this script
|
||||||
|
for i in $SECONDNODE $THIRDNODE; do scp /etc/keepalived/check_apiserver.sh /etc/keepalived/keepalived.conf root@$i:/etc/keepalived; scp /etc/haproxy/haproxy.cfg root@$i:/etc/haproxy; done
|
||||||
Loading…
Reference in New Issue
Block a user