[转]快速学习piranha

news/2024/7/10 3:03:22 标签: 负载均衡, 活动, web, 服务器, server, 测试

转自 http://space.itpub.net/21996817

 

实验目标:

快速撑握和理解Piranha方案,并利用15分钟构建WEB高可用负载均衡解决方案.


结构:

LVS-ACTIVE:192.168.1.210
LVS-BACKUP:192.168.1.211
LVS-VIP:192.168.1.212
Realsever:192.168.1.204,192.168.1.205

一.Piranha方案基本简绍.
1.Piranha方案优点:
1.1.1配置简洁高效:
配置简便一个lvs.conf配置文件即可搞定(keepalived方案.)

1.1.2WEB配置界面.
WEB配置对于那些不懂LVS配置的人员来说非常吸引力,你几乎只要花15分钟就可以配置好一个完美的负载均衡及高可用性方案.

1.1.3完整的功能:

主备LVS (Load Balancer)HeartbeatHA (pulse,send_arp)
LoadBalancerReal Server间进程服务的Heartbeat (nanny)
IPVS功能(lvsd)
IPVS管理(ipvsadm)

2.Piranha方案原理结构描述:
Piranha方案是基于LVS基础上设计的一套负载均衡高可用解决方案.
LVS运行在一对有相似配置的计算机上:
一个作为活动LVS Router(Active LVS Router)
一个作为备份LVS Router(Backup LVS Router)

活动LVS Router服务有两个角色:
*均衡负载到真实服务器上。
*检查真实服务器提供的服务是否正常。
备份LVS Router用来监控活动LVS Router,以备活动LVS Router失败时由备份LVS Router接管。


Pulse:
Pulse进程运行在活动LVS Router和备份LVS Router上。
在备份LVS Router上,pulse发送一个心跳(heartbeat)到活动LVS Router的公网接口上以检查活动LVS Router是否正常。
活动LVS Router上,pulse启动lvs进程并响应来自于备份LVS Router的心跳。

lvsd:
lvs进程调用ipvsadm工具去配置和维护IPVS路由表,并为每一个在真实服务器上的虚拟服务启动一个nanny进程。

nanny:
每一个nanny进程去检查真实服务器上的虚拟服务状态,并将故障情况通知lvs进程。假如一个故障被发现,lvs进程通知ipvsadm在IPVS路由表中将此节点删除。

send_arp:
如果备份LVS Router未收到来自于活动LVS Router的响应,
它将调用send_arp将虚拟IP地址再分配到备份LVS Router的公网接口上。
并在公网接口和局域网接口上分别发送一个命令去关掉活动LVS Router上的lvs进程。同时启动自己的lvs进程来调度客户端请求。

3.Piranha方案基本套件安装:

[Copy to clipboard] [-]
CODE:
#yum install ipvsadm modcluster piranha system-config-cluster php php-cli php-common




4.配置文件介绍:
/etc/sysconfig/ha/lvs.cf     //由http://ip:3636 web界面配置的配置文件写入此文件.
/etc/init.d/piranha-gui start  //启动piranha服务的WEB配置界面.
/etc/init.d/pulse           //启动piranha服务读取的就是/etc/sysconfig/ha/lvs.cf.

二.    Piranha配置
配置主LVS服务器.
# vi /etc/sysctl.conf找到下面行 //启用数据转发.
net.ipv4.ip_forward = 0将0 改成1,net.ipv4.ip_forward = 1
执行如下命令来应用:sysctl –p

通过WEB界面配置Piranha服务.
# /etc/init.d/piranha-gui start  //启动Piranha服务.
#/usr/sbin/piranha-passwd  //设置密码,请设置你的piranha服务WEB配置登陆密码.
http://192.168.1.210:3636/  输入用户名: piranha 及刚才设置的密码登陆.
登陆后,选择Global Settings 这是对LVS的配置
Primary server public IP 输入公网IP:192.168.1.210,应用后按ACCEPT按钮保存设置。
通过WEB配置主LVS的信息
1. 配置主份LVS

2.配置备份LVS


3. 配置添加LVS( VIP信息)

4.配置Realserver

点击”编辑”添加具体的Realsever信息.


5.启动LVS服务pulse

[Copy to clipboard] [-]
CODE:
# /etc/init.d/pulse start
Starting pulse:                                            [  OK  ]



如果不报错,表示启动成功!到此LVS的服务器已经配置完成了启动两个程序
1、piranha-gui  是用来配置LVS的
2、pulse       是用来启动LVS的
   
6.备份LVS安装与配置
备份LVS安装同主LVS安装方法同样.直接将lvs.conf拷贝到相应的目录下:
#scp  lvs.cfroot@192.168.1.211:/etc/sysconfig/ha/
# /etc/init.d/pulse start 启动服务即可.
7.配置Realserver
   
DR模式配置文件
……........

[Copy to clipboard] [-]
CODE:
       ifconfig lo:0 $WEB_VIP netmask 255.255.255.255 broadcast $WEB_VIP
       /sbin/route add -host $WEB_VIP dev lo:0
       echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
       echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
       echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
       echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
       sysctl -p >/dev/null 2>&1
       echo "RealServer Start OK"



      …………………….
Tunnel模式配置文件.
……………………………………

[Copy to clipboard] [-]
CODE:
    ifconfig tunl0 $WEB_VIP netmask 255.255.255.255 broadcast $WEB_VIP
       /sbin/route add -host $WEB_VIP dev tunl0
       echo "1" >/proc/sys/net/ipv4/conf/tunl0/arp_ignore
       echo "2" >/proc/sys/net/ipv4/conf/tunl0/arp_announce
       echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
       echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
       sysctl -p >/dev/null 2>&1



………………………………………….

正确配置,并启动服务.
8.    测试与日志分析.
# ipvsadm –ln    //查看LVS连接状态.

[Copy to clipboard] [-]
CODE:
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddressort Scheduler Flags
  -> RemoteAddressort           Forward Weight ActiveConn InActConn
TCP  192.168.1.212:80 wrr persistent 30
-> 192.168.1.204:80             Route    1      0          0         
-> 192.168.1.205:80             Route    1      0          0     


# tail -f /var/log/messages

【注】服务切换测试:
停掉主LVS服务上的pulse查看master是否能正常接管.测试过程中多注
意分析日志.在Linuxtone网站编写heartbeat+lvs方案的时候还需要自己送一个arping命令告诉网关我的MAC发生变化了.
但是Piranha方案能自动送一个arp命令.

三.      LVS配置文件详解及相关技巧介绍
1.    lvs.conf 配置及详解:http://bbs.linuxtone.org/thread-1603-1-1.html
2.    修改Piranha登陆用户名及监听端口?
      启动/etc/init.d/piranha-gui,实际上是执行如下配置文件.
      /usr/sbin/piranha_gui -f /etc/sysconfig/ha/conf/httpd.conf
     #cd /etc/sysconfig/ha 下目录介绍.
     lvs.cf               //Piranha方案实现LVS核心配置文件.
     conf/{httpd.conf, piranha.passwd}   //apache及认证相关文件.
     web/              //此目录下存放WEB配置界面的PHP相关程序,
                             如果想对WEB界面美化,请修改文件.
     mdules/            //apache一些相关模块.
      
    # vi /etc/sysconfig/ha/conf/httpd.conf (将原端口3636改为81,你也可以自定义此端口)
   
     默认WEB界面是能过piranha账号登陆,如何创建自己定义的账号登陆呢?

[Copy to clipboard] [-]
CODE:
  # htpasswd -c /etc/sysconfig/ha/conf/lvs.pass netseek     


// 上述命令是添加用户netseek,并将账号信息写入lvs.pass这个文件.  
     # vi /etc/sysconfig/ha/conf/httpd.conf
      
     # /etc/init.d/piranha-gui restart 重启服务即可生效.
     上述技巧只是简单的抛砖引玉,你可以修改WEB服务的PHP相关程序,添加一些流量
     或者WEB连接状态监控的代码.还可以自己给apache添加一些你自己写的模块,
     总之你可以再现有的piranha上做很多的改造去实   现你想要的更完美的系统.
     更多技巧请实时关注:http://bbs.linuxtone.org/负载均衡版块.

  3.  如果启动/etc/init.d/piranha-gui start
若遇到以下错误提示:

[Copy to clipboard] [-]
CODE:
Starting piranha-gui: (13)Permission denied: make_sock: could not bind to address [::]:3636


关闭掉selinux跟firewall


http://www.niftyadmin.cn/n/1055225.html

相关文章

【codeforces 767A】Snacktower

【题目链接】:http://codeforces.com/contest/767/problem/A 【题意】 每天掉一个盘子下来;盘子有大小从1..n依次增大n个盘子; 然后让你叠盘子; 最底层为n,倒数第二层为n-1….最上层为1; 让你输出每天叠了哪些盘子; 【题解】 因为是要连续叠在一起的; 所以每一天其实都…

网络中心主要工作内容

<?xml:namespace prefix o ns "urn:schemas-microsoft-com:office:office" />一、服务器与存储管理与维护我在这方面的主要事情&#xff1a;1、 故障诊断的排除。服务器如果出现任何问题&#xff0c;想办法自己找出问题的大致出处&#xff0c;并进行解决。如…

Java性能优化之String字符串优化

1.字符串对象及其特点 Java中八大基本数据类型没有String类型&#xff0c;因为String类型是Java对char数组的进一步封装。 String类的实现主要由三部分组成&#xff1a;char数组&#xff0c;offset偏移量&#xff0c;String的长度。 String类型有三个基本特点&#xff1a; 不变…

Maven Install重新构建工程

更新了Redis的配置文件&#xff0c;发现服务起不来了&#xff0c;报错&#xff1a; Caused by: redis.clients.jedis.exceptions.JedisConnectionException: All sentinels down, cannot determine where is aln master is running... 折腾了一下午&#xff0c;发现是Maven没…

自动化运维工具-mussh工具安装配置及简单使用讲解

1、先决条件&#xff1a; 安装pssh工具的主机针对远程主机需要配置免秘钥认证&#xff1a; ssh-keygen -t rsa ssh-copy-id [remotehost] 2、下载mussh工具安装介质&#xff1a;https://jaist.dl.sourceforge.net/project/mussh/mussh/1.0/mussh-1.0.tgz 3、安装mussh mussh安装…

oracle根据a列中相同的值,获取将对应的B列中各个值合并的结果集

从A查询结果得到B查询结果&#xff1a; A --源表 table_t a b 广东 广州 广东 深圳 广西 南宁 广西 北海B--结果表 a b 广东 广州,深圳 广西 南宁,北海使用SQL select a,WMSYS.WMCONCAT…

windows 下wget的使用

https://www.cnblogs.com/hzdx/p/6432161.html wget的下载地址&#xff1a; http://www.interlog.com/~tcharron/wgetwin.html 下载然后加入系统路径即可转载于:https://www.cnblogs.com/mangmangbiluo/p/10019338.html

循环不变式证明算法的正确性

循环不变式证明算法的正确性循环不变式主要用来辅助我们理解算法的正确性&#xff0c;对于循环不变式&#xff0c;必须证明它的三个性质&#xff08;有些类似于数学归纳法的意味&#xff09;&#xff1a; 初始化&#xff1a;它在循环的第一轮迭代开始之前&#xff0c;应该是正确…