企业自建私有云-openstack-负载keepalive+haproxy(容灾节点)

安装keepalived容灾节点

  1. 安装

    yum install -y keepalived
    
  2. 修改keepalived配置文件容灾节点

    vi /etc/keepalived/keepalived.conf
    ! Configuration File for keepalived
    
    global_defs {
       router_id LVS_OPENSTACK
       vrrp_iptables
    }
    vrrp_instance VI_1 {
        state MASTER(BACKUP)
        interface ens192
        virtual_router_id 192
        priority 100(备50)
        advert_int 1
        authentication {
            auth_type PASS
            auth_pass 192
        }
        virtual_ipaddress {
            192.168.188.20/24
        }
    }
    
  3. 启动keepalived容灾节点

    systemctl restart keepalived
    

    启动时会自动添加一个drop的防火墙规则,需要清空

    iptables -F
    systemctl status keepalived
    systemctl enable keepalived
    
  4. 查看vip

    ip add | grep 188.20
    

安装haproxy容灾节点

  1. 安装

    yum install -y haproxy
    
  2. 创建HAProxy记录日志文件并授权容灾节点

    mkdir /var/log/haproxy
    touch /var/log/haproxy/haproxy-info.log
    touch /var/log/haproxy/haproxy-err.log
    touch /var/log/haproxy/haproxy-notice.log
    chmod -R 777 /var/log/haproxy
    

    在rsyslog文件下修改以下字段

    vi /etc/rsyslog.conf
    module(load="imudp")
    input(type="imudp" port="514")
    module(load="imtcp")
    input(type="imtcp" port="514")
    #### GLOBAL DIRECTIVES ####
    		#在文件最后添加haproxy配置日志
    local0.=info    -/var/log/haproxy/haproxy-info.log
    local0.=err     -/var/log/haproxy/haproxy-err.log
    local0.notice;local0.!=err      -/var/log/haproxy/haproxy-notice.log
    

    重启rsyslog

    systemctl restart rsyslog
    
  3. 上传并修改配置文件容灾节点

    vi /etc/haproxy/haproxy.cfg
    #openstack高可用haproxy配置
    
    ###########全局配置#########
    global
        log		127.0.0.1 local2
        chroot      /var/lib/haproxy
        pidfile     /var/run/haproxy.pid
        maxconn     4000
        user        haproxy
        group       haproxy
        daemon
    	#线程数
        nbproc 16
        stats socket /var/lib/haproxy/stats
    ########默认配置############
    defaults
        #默认模式{ tcp|http|health }
        mode		tcp
        log			global
        #最大连接数
        maxconn		4000
        #连接超时
        timeout connect 	5m
        #客户端超时
        timeout client	1m
        #服务器超时
        timeout server 	31m
        #心跳检测超时
        timeout check	10s
        #负载均衡方式,轮询 
        balance		roundrobin
    
    ########haproxy监控页统计页面配置########
    listen stats  
        bind *:1080 
        mode http
        option httplog
        log 127.0.0.1 local0 err 
        stats refresh 30s
        #状态页面 http//ip:1080/admin访问
        stats uri /admin
        stats realm Haproxy\ Statistics
        #用户和密码:admin
        stats auth admin:admin
        #隐藏版本信息
        stats hide-version
        #设置手工启动/禁用
        stats admin if TRUE
        maxconn 10
    
    ########以下为基础服务高可用配置############
    # mysql服务;
    listen mysql_cluster_status
      bind *:3306
      balance  source
      mode    tcp
      server mysql-mgr01 节点ip:3306 check inter 2000 rise 2 fall 5
      server mysql-mgr02 节点ip:3306 backup check inter 2000 rise 2 fall 5
      server mysql-mgr03 节点ip:3306 backup check inter 2000 rise 2 fall 5
    # mysqlMGR服务;
    listen mysql_mgr_cluster_status
      bind *:33062
      balance  source
      mode    tcp
      server mysql-mgr01 节点ip:33062 check inter 2000 rise 2 fall 5
      server mysql-mgr02 节点ip:33062 backup check inter 2000 rise 2 fall 5
      server mysql-mgr03 节点ip:33062 backup check inter 2000 rise 2 fall 5
      
    #RabbitMQ
    listen RabbitMQ_Web_cluster
        bind *:15672
        mode tcp
        balance roundrobin
        option tcpka
        timeout client  3h
        timeout server  3h
        option  clitcpka
        server openstackcontroller01 节点ip:15672 check inter 5s rise 2 fall 3
        server openstackcontroller02 节点ip:15672 check inter 5s rise 2 fall 3
        server openstackcontroller03 节点ip:15672 check inter 5s rise 2 fall 3
    listen RabbitMQ_api_cluster_status
        bind *:5672
        mode tcp
        balance roundrobin
        option tcpka
        timeout client  3h
        timeout server  3h
        option  clitcpka
        server openstackcontroller01 节点ip:5672 check inter 5s rise 2 fall 3
        server openstackcontroller02 节点ip:5672 check inter 5s rise 2 fall 3
        server openstackcontroller03 节点ip:5672 check inter 5s rise 2 fall 3
    	
    #memcache
    listen memcache_api_cluster_status
        bind *:11211
        mode tcp
        balance roundrobin
        option tcpka
        timeout client  3h
        timeout server  3h
        option  clitcpka
        server openstackcontroller01 节点ip:11211 check inter 5s rise 2 fall 3
        server openstackcontroller02 节点ip:11211 check inter 5s rise 2 fall 3
        server openstackcontroller03 节点ip:11211 check inter 5s rise 2 fall 3
    	
    #etcd
    listen etcd_api_cluster_status
        bind *:2379
        mode tcp
        balance roundrobin
        option tcpka
        timeout client  3h
        timeout server  3h
        option  clitcpka
        server openstackcontroller01 节点ip:2379 check inter 5s rise 2 fall 3
        server openstackcontroller02 节点ip:2379 check inter 5s rise 2 fall 3
        server openstackcontroller03 节点ip:2379 check inter 5s rise 2 fall 3
    	
    ########以下为openstack高可用配置############
    ##################horizon服务
    listen dashboard_cluster  
        bind *:80
        balance  source  
        option  tcpka  
        option  httpchk  
        option  tcplog  
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:80 check port 80 inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:80 check port 80 inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:80 check port 80 inter 2000 rise 2 fall 5
    
    #################keystone服务
    #keystoneANDkeystone_admin_cluster、keystone_public_api
    listen keystone_public_api_cluster
        bind *:5000
        balance source
        option  tcpka
        option  httpchk 
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:5000 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:5000 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:5000 check inter 2000 rise 2 fall 5
    
    #################glance服务	
    #glance_api_cluster
    listen glance_api_cluster
        bind *:9292
    	mode tcp
        balance source
        option  tcpka
        option  httpchk
        option  tcplog
        timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:9292 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:9292 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:9292 check inter 2000 rise 2 fall 5
    #glance_registry_cluster
    listen glance_registry_cluster
        bind *:9191
    	mode tcp
        balance source
        option  tcpka
        option  httpchk
        option  tcplog
        timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:9191 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:9191 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:9191 check inter 2000 rise 2 fall 5
    	
    #################placement服务	
    #placement
    listen placement_cluster
        bind *:8778
        balance source
        option  tcpka
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:8778 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:8778 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:8778 check inter 2000 rise 2 fall 5
    
    #################nova服务	
    #nova_compute
    listen nova_compute_api_cluster
        bind *:8774
        balance source
        option  tcpka
        option  httpchk 
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:8774 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:8774 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:8774 check inter 2000 rise 2 fall 5
    #Nova-api-metadata
    listen Nova-api-metadata_cluster
        bind *:8775
        balance source
        option  tcpka
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:8775 check inter 2000 rise 2 fall 5
        server openstackcontroller01 节点ip:8775 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:8775 check inter 2000 rise 2 fall 5
    #nova_vncproxy
    listen nova_vncproxy_cluster
        bind *:6080
        balance source
        option  tcpka
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:6080 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:6080 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:6080 check inter 2000 rise 2 fall 5
    	
    #################Neutron服务	
    #Neutron_API
    listen Neutron_API_cluster
        bind *:9696
        balance source
        option  tcpka
        option  httpchk 
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:9696 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:9696 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:9696 check inter 2000 rise 2 fall 5
    
    #################Cinder服务	
    #Cinder_API_cluster
    listen Cinder_API_cluster
        bind *:8776
        balance source
        option  tcpka
        option  httpchk 
        option  tcplog
    	timeout client  3h
        timeout server  3h
        server openstackcontroller01 节点ip:8776 check inter 2000 rise 2 fall 5
        server openstackcontroller02 节点ip:8776 check inter 2000 rise 2 fall 5
        server openstackcontroller03 节点ip:8776 check inter 2000 rise 2 fall 5
    
  4. 启动haproxy容灾节点

    systemctl start haproxy
    systemctl status haproxy
    systemctl enable haproxy
    
  5. 访问haproxy网站观察服务部署情况

    http://vip:1080/admin
    用户名/密码:admin/admin

    企业自建私有云-openstack-负载keepalive+haproxy(容灾节点)_第1张图片

喜欢的亲可以关注点赞评论哦!以后每天都会更新的哦!本文为小编原创文章; 文章中用到的文件、安装包等可以加小编联系方式获得;
欢迎来交流小编联系方式VX:CXKLittleBrother 进入运维交流群

你可能感兴趣的:(openstack,私有云,openstack)