1) Определение и скачивание новой версии haproxy

Просмотреть все актуальные версии haproxy можно на странице:
http://www.haproxy.org/download/2.0/src/

Мы просто воспользуемся командой ниже и для удобства запишем в переменную крайнюю версию

LAST_HAPROXY=$(wget -qO-  http://www.haproxy.org/download/2.0/src/ | egrep -o "haproxy-2.[0-9]+.[0-9]+" | head -1)

Скачиваем и распаковываем архив с исходниками haproxy

cd /usr/src/
wget http://www.haproxy.org/download/2.0/src/${LAST_HAPROXY}.tar.gz
tar xzvf ${LAST_HAPROXY}.tar.gz

2) Подготовка окружения и установка

Установка необходимых пакетов для сборки haproxy

yum install gcc-c++ openssl-devel pcre-static pcre-devel systemd-devel -y

Сборка и установка haproxy

cd /usr/src/${LAST_HAPROXY}
make TARGET=linux-glibc USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 USE_CRYPT_H=1 USE_LIBCRYPT=1 USE_SYSTEMD=1
mkdir /etc/haproxy
make install

Создание systemd службы

cat > /usr/lib/systemd/system/haproxy.service << 'EOL'
[Unit]
Description=HAProxy Load Balancer
After=syslog.target network.target
[Service]
Environment="CONFIG=/etc/haproxy/haproxy.cfg" "PIDFILE=/run/haproxy.pid"
ExecStartPre=/usr/local/sbin/haproxy -f $CONFIG -c -q
ExecStart=/usr/local/sbin/haproxy -Ws -f $CONFIG -p $PIDFILE
ExecReload=/usr/local/sbin/haproxy -f $CONFIG -c -q
ExecReload=/bin/kill -USR2 $MAINPID
KillMode=mixed
Restart=always
SuccessExitStatus=143
Type=notify
[Install]
WantedBy=multi-user.target
EOL
systemctl daemon-reload

3) Создание конфига haproxy и запуск

Создадим конфиг с tcp пробросом 80 порта на localhost

cat > /etc/haproxy/haproxy.cfg << 'EOL'
global
 log /dev/log local0
 log /dev/log local1 notice
 daemon
defaults
 log global
defaults
 log global
 mode  http
 option httplog
 option dontlognull
listen AnyName
        bind *:80
        mode tcp
        server MyServer 127.0.0.1:80
EOL

Запуск haproxy

systemctl start haproxy

Проверяем статус службы

 systemctl status haproxy 

Готовый скрипт целиком

LAST_HAPROXY=$(wget -qO-  http://www.haproxy.org/download/2.0/src/ | egrep -o "haproxy-2.[0-9]+.[0-9]+" | head -1)
cd /usr/src/
wget http://www.haproxy.org/download/2.0/src/${LAST_HAPROXY}.tar.gz
tar xzvf ${LAST_HAPROXY}.tar.gz
yum install gcc-c++ openssl-devel pcre-static pcre-devel systemd-devel -y
cd /usr/src/${LAST_HAPROXY}
make TARGET=linux-glibc USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 USE_CRYPT_H=1 USE_LIBCRYPT=1 USE_SYSTEMD=1
mkdir /etc/haproxy
make install
cat > /usr/lib/systemd/system/haproxy.service << 'EOL'
[Unit]
Description=HAProxy Load Balancer
After=syslog.target network.target
[Service]
Environment="CONFIG=/etc/haproxy/haproxy.cfg" "PIDFILE=/run/haproxy.pid"
ExecStartPre=/usr/local/sbin/haproxy -f $CONFIG -c -q
ExecStart=/usr/local/sbin/haproxy -Ws -f $CONFIG -p $PIDFILE
ExecReload=/usr/local/sbin/haproxy -f $CONFIG -c -q
ExecReload=/bin/kill -USR2 $MAINPID
KillMode=mixed
Restart=always
SuccessExitStatus=143
Type=notify
[Install]
WantedBy=multi-user.target
EOL
cat > /etc/haproxy/haproxy.cfg << 'EOL'
global
 log /dev/log local0
 log /dev/log local1 notice
 daemon
defaults
 log global
 option dontlognull
 timeout connect 50000
 timeout client  50000
 timeout server  50000

listen AnyName
        bind *:80
        mode tcp
        server MyServer 127.0.0.1:80
EOL
systemctl start haproxy
systemctl status haproxy

Categories: CentosScripts

0 Comments

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *