IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Linux离线部署haproxy及日志配置 -> 正文阅读

[系统运维]Linux离线部署haproxy及日志配置

1.下载地址

http://download.openpkg.org/components/cache/haproxy/

2.上传到服务器上面并且解压

下载2.4.0版本的haproxy
在这里插入图片描述

3.编译安装

#确认linux系统内核
uname -r  
3.10.0-957.el7.x86_64
#centos7内核的系统,对应linux31
make TARGET=linux31
#开始安装
make install PREFIX=/home/proxy

看到proxy家目录下如下
在这里插入图片描述./haproxy -v查看安装haproxy版本
在这里插入图片描述

4.创建启动关闭等脚本和目录

mkdir -p bin
mkdir -p etc
mkdir -p logs
mkdir -p temp

1.在etc目录下创建配置文件

创建后端转发规则配置文件
touch haproxy-api.conf

   global
    maxconn 20000                    # 限制单个进程的最大连接数
    #chroot  /home/proxy/haproxy
    daemon                          # 让进程作为守护进程在后台运行
    quiet
    nbproc  1                       # 指定作为守护进程运行时的进程数
    pidfile /home/proxy/haproxy-api.pid

defaults
    log             global
    mode            http
    option          httplog
    option          dontlognull #不记录空连接
    option          httpclose
    log             127.0.0.1 local0 info #日志级别[err warning info debug]
    #retries         0          # 设置在一个服务器上链接失败后的重连次数
    #option          redispatch # 在连接失败或断开的情况下,允许当前会话被重新分发
    maxconn         20000       # 可被发送到后端服务器的最大并发连接数
    contimeout      5000ms     # 设置等待连接到服务器成功的最大时间
    clitimeout      600000ms    # 设置客户端的最大超时时间
    srvtimeout      600000ms    # 设置服务器端的最大超时时间

frontend controller
    bind            0.0.0.0:10000
    mode            http
    log             global
    option          httplog
    option          dontlognull
    maxconn         20000
    clitimeout      600000
    srvtimeout      600000

    acl acl-controller-order path_beg /api/order
    use_backend order if acl-controller-order

    acl acl-controller-base path_beg /api/base
    use_backend base if acl-controller-base

    acl acl-controller-sec path_beg /api/sec
    use_backend sec if acl-controller-sec

    acl acl-controller-prod path_beg /api/prod
    use_backend prod if acl-controller-prod


backend order
    mode            http
    balance         roundrobin
    contimeout      5000
    clitimeout      600000
    srvtimeout      600000
    #redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-order01 10.1.207.227:10501 check inter 5000

backend base
    mode            http
    balance         roundrobin
    contimeout      5000
    clitimeout      600000
    srvtimeout      600000
    #redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-base01 10.1.207.227:10601 check inter 5000

backend sec
    mode            http
    balance         roundrobin
    contimeout      5000
    clitimeout      600000
    srvtimeout      600000
    #redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-sec01 10.1.207.227:10301 check inter 5000

backend prod
    mode            http
    balance         roundrobin
    contimeout      5000
    clitimeout      600000
    srvtimeout      600000
    #redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-prod01 10.1.207.227:10401 check inter 5000

frontend ftpgw
    bind            0.0.0.0:14004
    mode            http
    log             global
    option          httplog
    option          dontlognull
    maxconn         20000
    clitimeout      600000
    srvtimeout      600000

    acl acl-ftp-gateway path_beg /gateway
    use_backend ftp_gw if acl-ftp-gateway

backend ftp_gw
    mode            http
    balance         roundrobin
    contimeout      5000
    srvtimeout      600000
    redispatch
    retries         2
    #option          httpchk GET /probe

    server      web-node01-ftpgw01 10.1.208.227:14004 check inter 5000
listen manager
       bind 0.0.0.0:2000
       mode http
       balance roundrobin
       stats uri /status
       stats realm Global\ statistics
       stats auth admin:admin

2.在bin目录下添加启动脚本

touch start-api.sh
touch stop-api.sh

修改start-api.sh脚本
#!/bin/sh

../sbin/haproxy -f ../etc/haproxy-api.conf

修改stop-api.sh脚本
#!/bin/sh

ps -ef | grep haproxy-api | grep -v grep | awk '{print $2}' | xargs kill -9

5.启动报错

haproxy 2.1后面版本相关配置修改了
在这里插入图片描述

6.修改对应版本ha的配置文件关键字

   global
    maxconn 20000                    # 限制单个进程的最大连接数
    #chroot  /home/proxy/haproxy
    daemon                          # 让进程作为守护进程在后台运行
    quiet
    nbproc  1                       # 指定作为守护进程运行时的进程数
    pidfile /home/proxy/haproxy-api.pid

defaults
    log             global
    mode            http
    option          httplog
    option          dontlognull #不记录空连接
    option          httpclose
    log             127.0.0.1 local0 info #日志级别[err warning info debug]
    #retries         0          # 设置在一个服务器上链接失败后的重连次数
    #option          option redispatch # 在连接失败或断开的情况下,允许当前会话被重新分发
    maxconn         20000       # 可被发送到后端服务器的最大并发连接数
    timeout connect      5000ms     # 设置等待连接到服务器成功的最大时间
    timeout client      600000ms    # 设置客户端的最大超时时间
    timeout server      600000ms    # 设置服务器端的最大超时时间

frontend controller
    bind            0.0.0.0:10000
    mode            http
    log             global
    option          httplog
    option          dontlognull
    maxconn         20000
    timeout client      600000
    timeout server      600000

    acl acl-controller-order path_beg /api/order
    use_backend order if acl-controller-order

    acl acl-controller-base path_beg /api/base
    use_backend base if acl-controller-base

    acl acl-controller-sec path_beg /api/sec
    use_backend sec if acl-controller-sec

    acl acl-controller-prod path_beg /api/prod
    use_backend prod if acl-controller-prod


backend order
    mode            http
    balance         roundrobin
    timeout connect      5000
    timeout client      600000
    timeout server      600000
    #option redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-order01 10.1.207.227:10501 check inter 5000

backend base
    mode            http
    balance         roundrobin
    timeout connect      5000
    timeout client      600000
    timeout server      600000
    #option redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-base01 10.1.207.227:10601 check inter 5000

backend sec
    mode            http
    balance         roundrobin
    timeout connect      5000
    timeout client      600000
    timeout server      600000
    #option redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-sec01 10.1.207.227:10301 check inter 5000

backend prod
    mode            http
    balance         roundrobin
    timeout connect      5000
    timeout client      600000
    timeout server      600000
    #option redispatch
    retries         2
    option          httpchk GET /probe.jsp

    server      svc-node01-prod01 10.1.207.227:10401 check inter 5000

frontend ftpgw
    bind            0.0.0.0:14004
    mode            http
    log             global
    option          httplog
    option          dontlognull
    maxconn         20000
    timeout client      600000
    timeout server      600000

    acl acl-ftp-gateway path_beg /gateway
    use_backend ftp_gw if acl-ftp-gateway


backend ftp_gw
    mode            http
    balance         roundrobin
    timeout connect      5000
    timeout client      600000
    timeout server      600000
    #option redispatch
    retries         2
    #option          httpchk GET /probe
    server      web-node01-ftpgw01 10.1.208.227:14004 check inter 5000
listen manager
       bind 0.0.0.0:2000
       mode http
       balance roundrobin
       stats uri /status
       stats realm Global\ statistics
       stats auth admin:admin

7.进入管理页面并且输入配置的账号密码

在这里插入图片描述

8.探针安全检查服务正常

在这里插入图片描述

9.配置日志

1.修改rsyslog配置

vi /etc/rsyslog.conf  打开如下配置并且增加haproxy日志级别和haproxy的日志存放地址
# Provides UDP syslog reception
$ModLoad imudp
$UDPServerRun 514

# Save haproxy log
local3.*                                                /home/proxy/logs/haproxy.log


vi /etc/sysconfig/rsyslog 配置文件
# Options for rsyslogd
# Syslogd options are deprecated since rsyslog v3.
# If you want to use them, switch to compatibility mode 2 by "-c 2"# See rsyslogd(8) for more details
SYSLOGD_OPTIONS="-r -m 0 "

相关解释说明:
-r:打开接受外来日志消息的功能,其监控514 UDP端口;
-x:关闭自动解析对方日志服务器的FQDN信息,这能避免DNS不完整所带来的麻烦;
-m:修改syslog的内部mark消息写入间隔时间(0为关闭),例如240为每隔240分钟写入一次"--MARK--"信息;
-h:默认情况下,syslog不会发送从远端接受过来的消息到其他主机,而使用该选项,则把该开关打开,所有
接受到的信息都可根据syslog.conf中定义的@主机转发过去

2.修改haproxy.conf配置

vi /home/proxy/etc/haproxy-api.conf   配置haproxy日志级别
   log             127.0.0.1 local3  #日志级别[err warning info debug]

3.重启haproxy并且访问页面

http://10.1.208.228:2000/status 访问 即可查看到日志生成.访问一次即可看到haproxy日志多一行访问记录
在这里插入图片描述
在这里插入图片描述

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-12-23 16:04:59  更:2021-12-23 16:06:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 4:02:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码