Vous êtes sur la page 1sur 18

ClusteringQuickInstallationGuide

forPacketFenceversion5.5.0

ClusteringQuickInstallationGuide
byInverseInc.

Version5.5.0-Nov2015
Copyright2015Inverseinc.
Permissionisgrantedtocopy,distributeand/ormodifythisdocumentunderthetermsoftheGNUFreeDocumentationLicense,Version
1.2oranylaterversionpublishedbytheFreeSoftwareFoundation;withnoInvariantSections,noFront-CoverTexts,andnoBack-Cover
Texts.Acopyofthelicenseisincludedinthesectionentitled"GNUFreeDocumentationLicense".
ThefontsusedinthisguidearelicensedundertheSILOpenFontLicense,Version1.1.ThislicenseisavailablewithaFAQat:http://
scripts.sil.org/OFL
CopyrightukaszDziedzic,http://www.latofonts.com,withReservedFontName:"Lato".
CopyrightRaphLevien,http://levien.com/,withReservedFontName:"Inconsolata".

TableofContents
About this Guide .............................................................................................................. 1
Assumptions ..................................................................................................................... 2
Installation ....................................................................................................................... 3
Step1:Installthereplicateddatabase........................................................................ 3
Step2:Serverconfiguration..................................................................................... 9
Step3:Createanewcluster.................................................................................. 10
Step4:Connectaslavepacketfenceserver..............................................................11
Advanced configuration ................................................................................................... 13
Removingaserverfromthecluster.......................................................................... 13
Resynchronizingtheconfigurationmanually.............................................................. 13
Addingfilestothesynchronization...........................................................................14
haproxy dashboard .................................................................................................. 14
Unsupportedfeaturesinactive/active....................................................................... 15

Copyright2015Inverseinc.

iii

Chapter1

AboutthisGuide

Thisguidehasbeencreatedtogiveaquickstarttoinstallactive/activeclusteringinPacketFence
5+.Thisguidedoesnotincludeadvancedtroubleshootingoftheactive/activeclustering.Referto
thedocumentationofHAProxyandKeepaliveforadvancedfeatures.

Copyright2015Inverseinc.

AboutthisGuide

Chapter2

Assumptions

YouhaveatleasttwoserverswithafreshinstallofPacketFence5+
Bothserversareidenticalcopiesforthenetworkinterfaces
BothserversarerunningCentOS6
Bothservershaveaccesstothesamelayer2networkonalltheirnetworkinterfaces
Bothservershaveanempty,unformattedpartitionforthedatabase
BothservershostnamemustberesolvableviaaDNSresolution

Copyright2015Inverseinc.

Assumptions

Chapter3

Installation

Step1:Installthereplicateddatabase
Note
Inthisimplementation,thedatabaseisreplicatedinactive/passiveacrosstwoservers
thatarepartofthePacketFencecluster.Active/activereplicationisalsopossibleusing
MariaDBGaleraclusterbutthissubjectisnotcoveredinthisguide.

InstallingDRBD
CreationoftheDRBDpartition
DuringtheOSinstallation,reducethesizeofthemainpartitionandcreateanewone(thatwill
beusedforthereplicatedMySQLdatabase)of30G.Donotcreatethatpartitionduringtheinstall
process,wewilldoitlater.

Partitioning
After the install, you need to create the extra partition for drbd. Using fdisk, create your new
partitionandsavethetable.Youwillprobablyneedtorebootyourserverafterthisstep.

DRBDandLinux-HAInstallation
CentOS6
AddtherepositoryELRepo.
# rpm -Uvh http://www.elrepo.org/elrepo-release-6-6.el6.elrepo.noarch.rpm
EdittherepofiletodisableELRepobydefault:
/etc/yum.repos.d/elrepo.repo

Copyright2015Inverseinc.

Installation

Chapter3

[elrepo]
name=ELRepo.org Community Enterprise Linux Repository - el6
baseurl=http://elrepo.org/linux/elrepo/el6/$basearch/
mirrorlist=http://elrepo.org/mirrors-elrepo.el6
enabled=0
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-elrepo.org
protect=0
InstallnowthepackageDRBDv8.4enabling.
yum install kmod-drbd84 --enablerepo=elrepo

DRBDConfigurationandsetup
Caution
Initializing,configuringandtroubleshootingDRBDisnotstraightforward!Westrongly
recommendthatyoureadtheonlinedocumentationavailableonDRBDwebsiteso
youhaveabetterideaabouthowitworks.
Hereweassumethenameofthepartitionismysql.
LoadtheDRBDkernelmodule:
modprobe drbd
Edit/etc/drbd.d/global_common.confandputthefollowingcontent:
global {
usage-count yes;
}
common {
protocol C;
startup {
degr-wfc-timeout 120;
}
syncer {
rate 100M;
al-extents 257;
}
disk {
on-io-error
}

detach;

Copyright2015Inverseinc.

Installation

Chapter3
Createthefile/etc/drbd.d/mysql.reswiththefollowingcontent:
resource mysql {
on <pf1_server_name> {
device /dev/drbd0;
disk <storage_device>;
meta-disk internal;
address <ha_interface_ip_address_1>:7788;
}
on <pf2_server_name> {
device /dev/drbd0;
disk <storage_device>;
meta-disk internal;
address <ha_interface_ip_address_2>:7788;
}
handlers {
split-brain "/usr/lib/drbd/notify-split-brain.sh alert@acme.com";
}
}
where:
mysqlisthenameofthepartitionyoucreatedwheninstallingtheOS
pf1_server_nameandpf2_server_namebytherealservernames(FQDN)
ha_interface_ip_address_1 and ha_interface_ip_address_2 by the IP addresses of the
managementinterfaceonbothservers.
storage_deviceisthedevicetousefortheMySQLpartition(ie./dev/sda2)
Theninitializethepartition:
[root@pf1 ~]# drbdadm create-md mysql
Writing meta data...
initializing activity log
NOT initialized bitmap
New drbd meta data block successfully created.
success
StartDRBDonbothservers:
# /etc/init.d/drbd start
Youshouldseesomethingsimilartothiswhentypingcat/proc/drbd:
...
0: cs:Connected ro:Secondary/Secondary ds:Inconsistent/Inconsistent C r---ns:0 nr:0 dw:0 dr:0 al:0 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:b oos:30702640

Note
Ifyougetconnectivityissuesmakesureyouriptablesaredisabled.

Copyright2015Inverseinc.

Installation

Chapter3
Synchronizetheserversbyforcingonetobecometheprimary.Soonpf1do:
# drbdadm primary --force mysql
Afterissuingthiscommand,theinitialfullsynchronizationwillstart.Youwillbeabletomonitorits
progressvia/proc/drbd.Itmaytakesometimedependingonthesizeofthedevice.Waituntil
itcompletes.
Whenthesynciscomplete,createthefilesystemontheprimarynodeonly:
# mkfs.ext4 /dev/drbd0
MakesureDRBDisstartedatboottime:
# chkconfig --level 2345 drbd on
Restartbothservers.
Whendone,lookin/proc/drbdandmakesureyousee:
...
0: cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate C r--ns:0 nr:0 dw:0 dr:0 al:0 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:b oos:0

MySQLConfiguration
Note
BydefaultMySQLputsitsdatain/var/lib/mysql.Inordertoreplicatedatabetween
thetwoservers,wemounttheDRBDpartitionunder/var/lib/mysql.
WhenfirststartingMySQL,thepartitionmustbemounted.
Inordertodoso:
Onthemasterserver(theserveryouareworkingon),tellDRBDtobecometheprimarynodewith:
# drbdadm primary mysql
mysqlbeingthenameoftheDRBDpartition.
Thecommandcat /proc/drbdshoulddisplaysomethinglike:
...
0: cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate C r---ns:145068 nr:4448 dw:149516 dr:10490 al:31 bm:14 lo:0 pe:0 ua:0 ap:0 ep:1
wo:d oos:0

Copyright2015Inverseinc.

Installation

Chapter3
StopandbackuppreviousMySQLdata
# service mysqld stop
# mkdir /var/lib/mysql.bak
# mv /var/lib/mysql/* /var/lib/mysql.bak/
Mountthepartitionwith:
# mount /dev/drbd0 /var/lib/mysql
StartMySQL
# service mysqld start
Executethesecureinstallationscriptinordertosettherootpassword,removethetestdatabases
andanonymoususercreatedbydefault:
# /usr/bin/mysql_secure_installation
MakesureMySQLdoesnotstartatboottime:
# chkconfig --level 2345 mysqld off

Heartbeatconfiguration
InstalltheEPELrepository
# rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epelrelease-6-8.noarch.rpm
In/etc/yum.repos.d/epel.repo,disabletherepository
[epel]
name=Extra Packages for Enterprise Linux 6 - $basearch
#baseurl=http://download.fedoraproject.org/pub/epel/6/$basearch
mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch
failovermethod=priority
enabled=0
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
NowinstallHeartbeat
# yum install heartbeat --enablerepo=epel
Create/etc/ha.d/ha.cfwiththefollowingcontent:

Copyright2015Inverseinc.

Installation

Chapter3

bcast eth0
keepalive 2
warntime 30
deadtime 60
auto_failback off
initdead 120
node pf1.example.com
node pf2.example.com
use_logd yes
logfile /var/log/ha-log
HereweassumethattheconnectionfortheHeartbeatbetweenthe2serversisoneth0.Make
sureyouchangepf1.example.comandpf2.example.comtothehostnamesofyourservers.
Create/etc/ha.d/haresourceswiththefollowingcontent:
pf1.example.com drbddisk::mysql Filesystem::/dev/drbd0::/var/lib/mysql::ext4 \
mysqld
Create/etc/ha.d/authkeyswiththefollowingcontent:
auth 1
1 sha1 10abf064f24a3e807dde7b945d0303392f10777d
andchangeitsrightslikethis:
# chmod 600 /etc/ha.d/authkeys

Note
Makesureport694isopened(throughiptables)onbothservers
StartHeartbeat:
# service heartbeat start
LookatHeartbeatlogfile/var/log/ha-logtomakesurethateverythingisfine.
EnableHBautomaticstart
# chkconfig --level 345 heartbeat on

MySQLnetworkconfiguration
InorderforyourPacketFenceclustertocommunicateproperlywiththeMySQLdatabase,youneed
tohaveMySQLbindonthemanagementIPaddress.
AdjustyourMySQLconfigurationin/etc/my.cnfonbothserversandmakesurethebind_address
lineis:

Copyright2015Inverseinc.

Installation

Chapter3

bind_address=<management_ip_address>

Step2:Serverconfiguration
YouwillneedtoconfiguretheserversotheservicescanbindonIPaddressestheydontcurrently
haveconfigured.Thisallowsfasterfailoveroftheservices.
OnCentOS,addthefollowinglinein/etc/sysctl.confandthenreloadwithsysctl-p
net.ipv4.ip_nonlocal_bind = 1
Createthepemthatcombinesthekeyandcertificateforthehttpservices.Adapttoyourownpaths
ifyouareusingdifferentcertificates.
# cd /usr/local/pf/conf/ssl
# cat server.key server.crt > server.pem

MySQLconfiguration
InorderforPacketFencetocommunicateproperlywithyourMySQLcluster,youneedtochange
thefollowing.
Inconf/pf.conf:
[database]
host=127.0.0.1
[monitoring]
db_host=127.0.0.1
....
Inconf/pfconfig.conf:
[mysql]
host=127.0.0.1
....
MakesureyourestartMySQL,packetfence-configandpacketfence
# service mysqld restart
# service packetfence-config restart
# service packetfence restart
Next,youneedtoremovetheemptyusersfromyourMySQLdatabase

Copyright2015Inverseinc.

Installation

Chapter3

# mysql
mysql> delete from mysql.user where user = '' ;
mysql> flush privileges;

Step3:Createanewcluster
Inordertocreateanewcluster,theonlythingneededistoconfigure/usr/local/pf/conf/cluster.conf
Youwillneedtoconfigureitwithyourserverhostname.Togetituse:hostnameinacommandline.
Inthecaseofthisexampleitwillbepf1.example.com.
TheCLUSTERsectionrepresentsthevirtualIPaddressesofyourclusterthatwillbesharedbyyour
servers.
Inthisexample,eth0isthemanagementinterface,eth1.2istheregistrationinterfaceandeth1.3
istheisolationinterface.
Createaconfigurationsimilartothis:
[CLUSTER]
management_ip=192.168.1.10
[CLUSTER interface eth0]
ip=192.168.1.10
type=management,high-availability
[CLUSTER interface eth1.2]
ip=192.168.2.10
type=internal
[CLUSTER interface eth1.3]
ip=192.168.3.10
type=internal

Copyright2015Inverseinc.

Installation

10

Chapter3

[pf1.example.com]
management_ip=192.168.1.5
[pf1.example.com interface eth0]
ip=192.168.1.5
type=management,high-availability
mask=255.255.255.0
[pf1.example.com interface eth1.2]
enforcement=vlan
ip=192.168.2.5
type=internal
mask=255.255.255.0
[pf1.example.com interface eth1.3]
enforcement=vlan
ip=192.168.3.5
type=internal
mask=255.255.255.0
Oncethisconfigurationisdone,restartPacketFencetohaveitapplied.Ifdoneproperlythisshould
starttwoadditionnalservices:haproxyandkeepalived
YoushouldnowhaveserviceontheIPaddressesdefinedintheCLUSTERsections

Additionnalsteps
Itishighlyrecommendedtomodifythekeepalivesharedsecretinyourclustertopreventattacks.
In the administration interface, go in Configuration/Clustering and change the Shared KEY. Make
sureyourestartkeepaliveonyourserverusing/usr/local/pf/bin/pfcmd service keepalived
restart

Step4:Connectaslavepacketfenceserver
First,connecttheservertothedatabaseclusterusingtheinstructionsabove
OnCentOS,addthefollowinglinein/etc/sysctl.confandthenreloadwithsysctl-p
net.ipv4.ip_nonlocal_bind = 1
Gothroughtheconfiguratortosetuptheinterfacesandthenstop
GetthewebservicesuserandpasswordonthemasternodeinConfiguration/WebServicesIftheres
none,settheuser,passwordandthenrestarthttpd.webservices
Do(andmakesureitdoesitwithoutanyerrors):

Copyright2015Inverseinc.

Installation

11

Chapter3

# /usr/local/pf/bin/cluster/sync --from=192.168.1.5 --api-user=packet --apipassword=fence

Where:
192.168.1.5isthemanagementIPoftheotherPacketFencenode
packetisthewebservicesusernameonthemasternode
fenceisthewebservicespasswordonthemasternode
Edit/usr/local/pf/conf/cluster.confandcreatetheserversconfigurationusingtheothernodeas
anexample.
Reloadtheconfiguationandstartthewebservicesonthenewserver
#
#
#
#

service packetfence-config restart


/usr/local/pf/bin/pfcmd configreload
/usr/local/pf/bin/pfcmd service haproxy restart
/usr/local/pf/bin/pfcmd service httpd.webservices restart

Makesurethatthisserverisbindingtoitsownmanagementaddress.Ifitsnot,verifythe/usr/
local/pf/conf/cluster.confmanagementinterfaceconfiguration.
# netstat -nlp | grep 9090
Nowreplicatethisserverconfigurationtotheothernodesinthecluster
# /usr/local/pf/bin/cluster/sync --as-master
Makesureatleast/usr/local/pf/conf/cluster.confwasreplicatedtotheotherservers
Now restart packetfence on each cluster server keeping the new node as the last one to be
restarted.

Copyright2015Inverseinc.

Installation

12

Chapter4

Advancedconfiguration

Removingaserverfromthecluster
Note
RemovingaserverfromtheclusterrequiresarestartofthePacketFenceserviceon
allnodes.
First,youwillneedtostopPacketFenceonyourserverandputitoffline.
# service packetfence stop
# shutdown -h 0
Thenyouneedtoremovealltheconfigurationassociatedtotheserverfrom/usr/local/pf/conf/
cluster.confononeoftheremainingnodes.Configurationforaserverisalwaysprefixedbythe
servershostname.
Once you have removed the configuration, you need to reload it and synchronize it with the
remainingnodesinthecluster.
# /usr/local/pf/bin/pfcmd configreload hard
# /usr/local/pf/bin/cluster/sync --as-master
NowrestartPacketFenceonalltheserverssothattheremovednodeisnotpartoftheclustering
configuration.

Resynchronizingtheconfigurationmanually
Ifyoudidamanualchangeinaconfigurationfile,anadditionnalstepisnowneeded.
Inordertobesuretheconfigurationisproperlysynchedonallnodes,youwillneedtoenterthis
commandonthepreviouslyselectedmasternode.
# /usr/local/pf/bin/cluster/sync --as-master

Copyright2015Inverseinc.

Advancedconfiguration

13

Chapter4

Addingfilestothesynchronization
Intheeventthatyoudomodificationstonon-synchronizedfileslikeswitchmodules,filesinraddb/,
etc,youcanaddthosefilestobesynchronizedwhenusing/usr/local/pf/bin/cluster/sync.
Ononeofthenodes,create/usr/local/pf/conf/cluster-files.txt
Addtheadditionnalfilesoneperlineinthisfile.Weadviseyouaddthisfiletothesynchronization
too.
Example:
/usr/local/pf/conf/cluster-files.txt
/usr/local/pf/raddb/modules/mschap

haproxydashboard
Youhavethepossibilitytoconfigurethehaproxydashboardwhichwillgiveyoustatisticsaboutthe
currentstateofyourcluster.
Inordertoactiveituncommentthefollowinglinesfrom/usr/local/pf/conf/haproxy.conf
listen stats %%active_active_ip%%:1025
mode http
timeout connect 10s
timeout client 1m
timeout server 1m
stats enable
stats uri /stats
stats realm HAProxy\ Statistics
stats auth admin:packetfence

Note
Westronglyadviseyouchangetheusernameandpasswordtosomethingelsethan
admin/packetfencealthoughaccesstothisdashboarddoesntcompromisetheserver.
Next,uncommentthefollowinglinefrom/usr/local/pf/conf/iptables.conf

Caution
Ifyoureupgradingfromaversionpriorto5.0,thelinemaynotbethere.Additclose
totheothermanagementrules

Copyright2015Inverseinc.

Advancedconfiguration

14

Chapter4

-A input-management-if --protocol tcp --match tcp --dport 1025 --jump ACCEPT


Nowrestarthaproxyandiptablesinordertocompletetheconfiguration
# /usr/local/pf/bin/pfcmd service haproxy restart
# /usr/local/pf/bin/pfcmd service iptables restart
YoushouldnowbeabletoconnecttothedashboardonthefollowingURL:http://pf.local:1025/
stats

Unsupportedfeaturesinactive/active
Thefollowingfeaturesarenotsupportedwhenusingactive/activeclustering.
SwitchesusingSNMPbasedenforcement(port-security,linkup/down,)
SNMProamingwiththeAerohivecontroller.(4.7+includessupportforaccountingroaming)

Copyright2015Inverseinc.

Advancedconfiguration

15