Anvil! Tutorial 3
| Alteeve Wiki :: How To :: Anvil! Tutorial 3 | 
|  | Warning: This tutorial is built on Red Hat's Enterprise Linux 7 beta. Red Hat never confirms what a future release will contain until it is actually released, so there is a real chance that what is in the beta will not be in the final release. | 
This is the third AN!Cluster tutorial built on Red Hat's Enterprise Linux 7. It improves on the RHEL 5, RHCS stable 2 and RHEL 6, RHCS stable3 tutorials.
As with the previous tutorials, the end goal of this tutorial is a 2-node cluster providing a platform for high-availability virtual servers. It's design attempts to remove all single points of failure from the system. Power and networking are made fully redundant in this version, along with minimizing the node failures which would lead to service interruption. This tutorial also covers the AN!Utilities; AN!Cluster Dashboard, AN!Cluster Monitor and AN!Safe Cluster Shutdown.
As it the previous tutorial, KVM will be the hypervisor used for facilitating virtual machines. The old cman and rgmanager tools are replaced in favour of pacemaker for resource management.
Before We Begin
This tutorial does not require prior cluster experience, but it does expect familiarity with Linux and a low-intermediate understanding of networking. Where possible, steps are explained in detail and rationale is provided for why certain decisions are made.
For those with cluster experience;
Please be careful not to skip too much. There are some major and some subtle changes from previous tutorials.
OS Setup
|  | Warning: We are using the RHEL 7 beta OS. | 
Post OS Install
Enable the eth0 interface on boot.
sed -i.bak 's/ONBOOT=.*/ONBOOT="yes"/' /etc/sysconfig/network-scripts/ifcfg-eth0 
diff -U0 /etc/sysconfig/network-scripts/ifcfg-eth0.bak /etc/sysconfig/network-scripts/ifcfg-eth0
--- /etc/sysconfig/network-scripts/ifcfg-eth0.bak	2014-01-23 16:15:45.008085032 -0500
+++ /etc/sysconfig/network-scripts/ifcfg-eth0	2014-01-23 16:15:25.573009623 -0500
@@ -11 +11 @@
-ONBOOT=no
+ONBOOT="yes"
If you want to make any other changes, like configuring the interface to have a static IP, do so now. Once you're done editing;
nmcli connection reload
systemctl restart NetworkManager.service
ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 52:54:00:a7:9d:17 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.201/24 scope global eth0
       valid_lft forever preferred_lft forever
    inet6 fe80::5054:ff:fea7:9d17/64 scope link 
       valid_lft forever preferred_lft forever
The interface should now start on boot properly.
Configure the DVD Repo
|  | Note: The minimal install does not include rsync, so here we download the ISO using curl from a server on my network. You could simply mount a physical DVD ROM if you have one instead. | 
While using the RHEL 7 beta, there are no public repos. So we need to configure the install DVD as the repo we'll install from.
Create a mount point:
mkdir /mnt/dvd
cd ~
curl -O http://10.255.255.250/rhel7/x86_64/iso/rhel-7-public-beta-x86_64-dvd.iso
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100 4476M  100 4476M    0     0  88.2M      0  0:00:50  0:00:50 --:--:-- 98.4M
Add the ISO to /etc/fstab and then mount the ISO.
echo "/root/rhel-7-public-beta-x86_64-dvd.iso /mnt/dvd auto loop 0 0" >> /etc/fstab 
mount /mnt/dvd
mount: /dev/loop0 is write-protected, mounting read-only
Create the repo file:
vi /etc/yum.repos.d/dvd.repo
[dvd]
baseurl=file:///mnt/dvd/
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta
Clean the yum cache
yum clean all
Loaded plugins: product-id, subscription-manager
This system is not registered to Red Hat Subscription Management. You can use subscription-manager to register.
Repository 'dvd' is missing name in configuration, using id
Cleaning repos: dvd
Cleaning up everything
Done.
Install
Not all of these are required, but most are used at one point or another in this tutorial.
|  | Note: The fence-agents-virsh package is not available in RHEL 7 beta. Further, it's only needed if you're building your cluster using VMs. | 
yum install bridge-utils corosync net-tools ntp pacemaker pcs rsync syslinux \
            wget fence-agents-all fence-agents-virsh gpm man vim screen mlocate \
            syslinux
If you want to use your mouse at the node's terminal, run the following;
systemctl enable gpm.service
systemctl start gpm.service
Setting the Hostname
Fedora 19 is very different from EL6.
|  | Note: The '--pretty' line currently doesn't work as there is a bug (rhbz#895299) with single-quotes. | 
|  | Note: The '--static' option is currently needed to prevent the '.' from being removed. See this bug (rhbz#896756). | 
Use a format that works for you. For the tutorial, node names are based on the following;
- A two-letter prefix identifying the company/user (an, for "Alteeve's Niche!")
- A sequential cluster ID number in the form of cXX (c01 for "Cluster 01", c02 for Cluster 02, etc)
- A sequential node ID number in the form of nYY
In my case, this is my third cluster and I use the company prefix an, so my two nodes will be;
- an-c03n01 - node 1
- an-c03n02 - node 2
Folks who've read my earlier tutorials will note that this is a departure in naming. I find this method spans and scales much better. Further, it the simply required in order to use the AN! Cluster Dashboard.
hostnamectl set-hostname an-c03n01.alteeve.ca --static
hostnamectl set-hostname --pretty "Alteeve's Niche! - Cluster 03, Node 01"
If you want the new host name to take effect immediately, you can use the traditional hostname command:
hostname an-c03n01.alteeve.ca
Alternatively
If you have trouble with those commands, you can directly edit the files that contain the host names.
The host name is stored in /etc/hostname:
echo an-c03n01.alteeve.ca > /etc/hostname 
cat /etc/hostname
an-c03n01.alteeve.ca
The "pretty" host name is stored in /etc/machine-info as the unquoted value for the PRETTY_HOSTNAME value.
vim /etc/machine-info
PRETTY_HOSTNAME=Alteeves Niche! - Cluster 01, Node 01
If you can't get the hostname command to work for some reason, you can reboot to have the system read the new values.
Optional - Video Problems
On my servers, Fedora 19 doesn't detect or use the video card properly. To resolve this, I need to add nomodeset to the kernel line when installing and again after the install is complete.
Once installed
Edit the /etc/default/grub and append nomodeset to the end of the GRUB_CMDLINE_LINUX variable.
vim /etc/default/grub
GRUB_TIMEOUT=5
GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc/system-release)"
GRUB_DEFAULT=saved
GRUB_CMDLINE_LINUX="nomodeset rd.md=0 rd.lvm=0 rd.dm=0 $([ -x /usr/sbin/rhcrashkernel-param ] && /usr/sbin/rhcrashkernel-param || :) rd.luks=0 vconsole.keymap=us nomodeset"
GRUB_DISABLE_RECOVERY="true"
GRUB_THEME="/boot/grub2/themes/system/theme.txt"
Save that. and then rewrite the grub2 configuration file.
grub2-mkconfig -o /boot/grub2/grub.cfg
Next time you reboot, you should get a stock 80x25 character display. It's not much, but it will work on esoteric video cards or weird monitors.
What Security?
|  | Note: The final version of this tutorial will use the firewall and selinux. It's disabled to simplify debugging during the development stage of the tutorial only. | 
This section will be re-added at the end. For now;
setenforce 0
sed -i 's/SELINUX=.*/SELINUX=disabled/' /etc/selinux/config
systemctl disable firewalld.service
systemctl stop firewalld.service
Network
We want static, named network devices. Follow this;
Then, use these configuration files;
Build the bridge;
vim /etc/sysconfig/network-scripts/ifcfg-ifn-vbr1
# Internet-Facing Network - Bridge
DEVICE="ifn-vbr1"
TYPE="Bridge"
BOOTPROTO="none"
IPADDR="10.255.10.1"
NETMASK="255.255.0.0"
GATEWAY="10.255.255.254"
DNS1="8.8.8.8"
DNS2="8.8.4.4"
DEFROUTE="yes"
Now build the bonds;
vim /etc/sysconfig/network-scripts/ifcfg-ifn-bond1
# Internet-Facing Network - Bond
DEVICE="ifn-bond1"
BRIDGE="ifn-vbr1"
BOOTPROTO="none"
NM_CONTROLLED="no"
ONBOOT="yes"
BONDING_OPTS="mode=1 miimon=100 use_carrier=1 updelay=120000 downdelay=0 primary=ifn1"
vim /etc/sysconfig/network-scripts/ifcfg-sn-bond1
# Storage Network - Bond
DEVICE="sn-bond1"
BOOTPROTO="none"
NM_CONTROLLED="no"
ONBOOT="yes"
BONDING_OPTS="mode=1 miimon=100 use_carrier=1 updelay=120000 downdelay=0 primary=sn1"
IPADDR="10.10.10.1"
NETMASK="255.255.0.0"
vim /etc/sysconfig/network-scripts/ifcfg-bcn-bond1
# Back-Channel Network - Bond
DEVICE="bcn-bond1"
BOOTPROTO="none"
NM_CONTROLLED="no"
ONBOOT="yes"
BONDING_OPTS="mode=1 miimon=100 use_carrier=1 updelay=120000 downdelay=0 primary=bcn1"
IPADDR="10.20.10.1"
NETMASK="255.255.0.0"
Now tell the interfaces to be slaves to their bonds;
Internet-Facing Network;
vim /etc/sysconfig/network-scripts/ifcfg-ifn1
# Internet-Facing Network - Link 1
DEVICE="ifn1"
NM_CONTROLLED="no"
BOOTPROTO="none"
ONBOOT="yes"
SLAVE="yes"
MASTER="ifn-bond1"
vim /etc/sysconfig/network-scripts/ifcfg-ifn2
# Back-Channel Network - Link 2
DEVICE="ifn2"
NM_CONTROLLED="no"
BOOTPROTO="none"
ONBOOT="yes"
SLAVE="yes"
MASTER="ifn-bond1"
Storage Network;
vim /etc/sysconfig/network-scripts/ifcfg-sn1
# Storage Network - Link 1
DEVICE="sn1"
NM_CONTROLLED="no"
BOOTPROTO="none"
ONBOOT="yes"
SLAVE="yes"
MASTER="sn-bond1"
vim /etc/sysconfig/network-scripts/ifcfg-sn2
# Storage Network - Link 1
DEVICE="sn2"
NM_CONTROLLED="no"
BOOTPROTO="none"
ONBOOT="yes"
SLAVE="yes"
MASTER="sn-bond1"
Back-Channel Network
vim /etc/sysconfig/network-scripts/ifcfg-bcn1
# Back-Channel Network - Link 1
DEVICE="bcn1"
NM_CONTROLLED="no"
BOOTPROTO="none"
ONBOOT="yes"
SLAVE="yes"
MASTER="bcn-bond1"
vim /etc/sysconfig/network-scripts/ifcfg-bcn2
# Storage Network - Link 1
DEVICE="bcn2"
NM_CONTROLLED="no"
BOOTPROTO="none"
ONBOOT="yes"
SLAVE="yes"
MASTER="bcn-bond1"
Now restart the network, confirm that the bonds and bridge are up and you are ready to proceed.
Setup The hosts File
You can use DNS if you prefer. For now, lets use /etc/hosts for node name resolution.
vim /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
# AN!Cluster 01, Node 01
10.255.10.1     an-c01n01.ifn
10.10.10.1      an-c01n01.sn
10.20.10.1      an-c01n01.bcn an-c01n01 an-c01n01.alteeve.ca
10.20.11.1      an-c01n01.ipmi
# AN!Cluster 01, Node 02
10.255.10.2     an-c01n02.ifn
10.10.10.2      an-c01n02.sn
10.20.10.2      an-c01n02.bcn an-c01n02 an-c01n02.alteeve.ca
10.20.11.2      an-c01n02.ipmi
# Foundation Pack
10.20.2.7       an-p03 an-p03.alteeve.ca
Setup SSH
Same as before.
Populating And Pushing ~/.ssh/known_hosts
Same as before.
ssh root@an-c03n01.alteeve.ca
The authenticity of host 'an-c03n01.alteeve.ca (10.20.30.1)' can't be established.
RSA key fingerprint is 7b:dd:0d:aa:c5:f5:9e:a6:b6:4d:40:69:d6:80:4d:09.
Are you sure you want to continue connecting (yes/no)?
Type yes
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'an-c03n01.alteeve.ca,10.20.30.1' (RSA) to the list of known hosts.
Last login: Thu Feb 14 15:18:33 2013 from 10.20.5.100
You will now be logged into the an-c03n01 node, which in this case is the same machine on a new session in the same terminal.
[root@an-c03n01 ~]#
You can logout by typing exit.
exit
logout
Connection to an-c03n01.alteeve.ca closed.
Now we have to repeat the steps for all the other variations on the names of the hosts. This is annoying and tedious, sorry.
ssh root@an-c03n01
ssh root@an-c03n01.bcn
ssh root@an-c03n01.sn
ssh root@an-c03n01.ifn
ssh root@an-c03n02.alteeve.ca
ssh root@an-c03n02
ssh root@an-c03n02.bcn
ssh root@an-c03n02.sn
ssh root@an-c03n02.ifn
Your ~/.ssh/known_hosts file will now be populated with both nodes' ssh fingerprints. Copy it over to the second node to save all that typing a second time.
rsync -av ~/.ssh/known_hosts root@an-c03n02:/root/.ssh/
Keeping Time in Sync
It's not as critical as it used to be to keep the clocks on the nodes in sync, but it's still a good idea.
systemctl start ntpd.service
systemctl enable ntpd.service
Configuring IPMI
F19 specifics based on the IPMI tutorial.
yum -y install ipmitools OpenIPMI
systemctl start ipmi.service
systemctl enable ipmi.service
ln -s '/usr/lib/systemd/system/ipmi.service' '/etc/systemd/system/multi-user.target.wants/ipmi.service'
Our servers use lan channel 2, yours might be 1 or something else. Experiment.
ipmitool lan print 2
Set in Progress         : Set Complete
Auth Type Support       : NONE MD5 PASSWORD 
Auth Type Enable        : Callback : NONE MD5 PASSWORD 
                        : User     : NONE MD5 PASSWORD 
                        : Operator : NONE MD5 PASSWORD 
                        : Admin    : NONE MD5 PASSWORD 
                        : OEM      : NONE MD5 PASSWORD 
IP Address Source       : BIOS Assigned Address
IP Address              : 10.20.51.1
Subnet Mask             : 255.255.0.0
MAC Address             : 00:19:99:9a:d8:e8
SNMP Community String   : public
IP Header               : TTL=0x40 Flags=0x40 Precedence=0x00 TOS=0x10
Default Gateway IP      : 10.20.255.254
802.1q VLAN ID          : Disabled
802.1q VLAN Priority    : 0
RMCP+ Cipher Suites     : 0,1,2,3,6,7,8,17
Cipher Suite Priv Max   : OOOOOOOOXXXXXXX
                        :     X=Cipher Suite Unused
                        :     c=CALLBACK
                        :     u=USER
                        :     o=OPERATOR
                        :     a=ADMIN
                        :     O=OEM
I need to set the IPs to 10.20.31.1/16 and 10.20.31.2/16 for nodes 1 and 2, respectively. I also want to set the password to secret for the admin user.
Node 01 IP;
ipmitool lan set 2 ipsrc static
ipmitool lan set 2 ipaddr 10.20.31.
ipmitool lan set 2 netmask 255.255.0.0
ipmitool lan set 2 defgw ipaddr 10.20.255.254
ipmitool lan print 2
Set in Progress         : Set Complete
Auth Type Support       : NONE MD5 PASSWORD 
Auth Type Enable        : Callback : NONE MD5 PASSWORD 
                        : User     : NONE MD5 PASSWORD 
                        : Operator : NONE MD5 PASSWORD 
                        : Admin    : NONE MD5 PASSWORD 
                        : OEM      : NONE MD5 PASSWORD 
IP Address Source       : Static Address
IP Address              : 10.20.31.1
Subnet Mask             : 255.255.0.0
MAC Address             : 00:19:99:9a:d8:e8
SNMP Community String   : public
IP Header               : TTL=0x40 Flags=0x40 Precedence=0x00 TOS=0x10
Default Gateway IP      : 10.20.255.254
802.1q VLAN ID          : Disabled
802.1q VLAN Priority    : 0
RMCP+ Cipher Suites     : 0,1,2,3,6,7,8,17
Cipher Suite Priv Max   : OOOOOOOOXXXXXXX
                        :     X=Cipher Suite Unused
                        :     c=CALLBACK
                        :     u=USER
                        :     o=OPERATOR
                        :     a=ADMIN
                        :     O=OEM
Node 01 IP;
ipmitool lan set 2 ipsrc static
ipmitool lan set 2 ipaddr 10.20.31.2
ipmitool lan set 2 netmask 255.255.0.0
ipmitool lan set 2 defgw ipaddr 10.20.255.254
ipmitool lan print 2
Set in Progress         : Set Complete
Auth Type Support       : NONE MD5 PASSWORD 
Auth Type Enable        : Callback : NONE MD5 PASSWORD 
                        : User     : NONE MD5 PASSWORD 
                        : Operator : NONE MD5 PASSWORD 
                        : Admin    : NONE MD5 PASSWORD 
                        : OEM      : NONE MD5 PASSWORD 
IP Address Source       : Static Address
IP Address              : 10.20.31.2
Subnet Mask             : 255.255.0.0
MAC Address             : 00:19:99:9a:b1:78
SNMP Community String   : public
IP Header               : TTL=0x40 Flags=0x40 Precedence=0x00 TOS=0x10
Default Gateway IP      : 10.20.255.254
802.1q VLAN ID          : Disabled
802.1q VLAN Priority    : 0
RMCP+ Cipher Suites     : 0,1,2,3,6,7,8,17
Cipher Suite Priv Max   : OOOOOOOOXXXXXXX
                        :     X=Cipher Suite Unused
                        :     c=CALLBACK
                        :     u=USER
                        :     o=OPERATOR
                        :     a=ADMIN
                        :     O=OEM
Set the password.
ipmitool user list 2
ID  Name	     Callin  Link Auth	IPMI Msg   Channel Priv Limit
1                    true    true       true       Unknown (0x00)
2   admin            true    true       true       OEM
Get User Access command failed (channel 2, user 3): Unknown (0x32)
(ignore the error, it's harmless... *BOOM*)
We want to set admin's password, so we do:
|  | Note: The 2 below is the ID number, not the LAN channel. | 
ipmitool user set password 2 secret
Done!
Configuring the Cluster
Now we're getting down to business!
For this section, we will be working on an-c03n01 and using ssh to perform tasks on an-c03n02.
|  | Note: TODO: explain what this is and how it works. | 
Enable the pcs Daemon
|  | Note: Most of this section comes more or less verbatim from the main Clusters from Scratch tutorial. | 
We will use pcs, the Pacemaker Configuration System, to configure our cluster.
systemctl start pcsd.service
systemctl enable pcsd.service
ln -s '/usr/lib/systemd/system/pcsd.service' '/etc/systemd/system/multi-user.target.wants/pcsd.service'
Now we need to set a password for the hacluster user. This is the account used by pcs on one node to talk to the pcs daemon on the other node. For this tutorial, we will use the password secret. You will want to use a stronger password, of course.
echo secret | passwd --stdin hacluster
Changing password for user hacluster.
passwd: all authentication tokens updated successfully.
Initializing the Cluster
One of the biggest reasons we're using the pcs tool, over something like crm, is that it has been written to simplify the setup of clusters on Red Hat style operating systems. It will configure corosync automatically.
First, we need to know what hostname we will need to use for pcs.
Node 01:
hostname
an-c03n01.alteeve.ca
Node 02:
hostname
an-c03n02.alteeve.ca
Next, authenticate against the cluster nodes.
Both nodes:
pcs cluster auth an-c03n01.alteeve.ca an-c03n02.alteeve.ca -u hacluster
This will ask you for the user name and password. The default user name is hacluster and we set the password to secret.
Password: 
an-c03n02.alteeve.ca: Authorized
Do this on one node only:
Now to initialize the cluster's communication and membership layer.
pcs cluster setup --name an-cluster-03 an-c03n01.alteeve.ca an-c03n02.alteeve.ca
an-c03n01.alteeve.ca: Succeeded
an-c03n02.alteeve.ca: Succeeded
This will create the corosync configuration file /etc/corosync/corosync.conf;
cat /etc/corosync/corosync.conf
totem {
version: 2
secauth: off
cluster_name: an-cluster-03
transport: udpu
}
nodelist {
  node {
        ring0_addr: an-c03n01.alteeve.ca
        nodeid: 1
       }
  node {
        ring0_addr: an-c03n02.alteeve.ca
        nodeid: 2
       }
}
quorum {
provider: corosync_votequorum
}
logging {
to_syslog: yes
}
Start the Cluster For the First Time
This starts the cluster communication and membership layer for the first time.
On one node only;
pcs cluster start --all
an-c03n01.alteeve.ca: Starting Cluster...
an-c03n02.alteeve.ca: Starting Cluster...
After a few moments, you should be able to check the status;
pcs status
Cluster name: an-cluster-03
WARNING: no stonith devices and stonith-enabled is not false
Last updated: Mon Jun 24 23:28:29 2013
Last change: Mon Jun 24 23:28:10 2013 via crmd on an-c03n01.alteeve.ca
Current DC: NONE
2 Nodes configured, unknown expected votes
0 Resources configured.
Node an-c03n01.alteeve.ca (1): UNCLEAN (offline)
Node an-c03n02.alteeve.ca (2): UNCLEAN (offline)
Full list of resources:
The other node should show almost the identical output.
The two main things here are errors about stonith being unconfigured. We will fix this very shortly, but for just this moment, we will disable it and quorum.
pcs property set stonith-enabled=false
pcs status
Cluster name: an-cluster-03
Last updated: Tue Jun 25 00:12:21 2013
Last change: Tue Jun 25 01:42:04 2013 via cibadmin on an-c03n01.alteeve.ca
Stack: corosync
Current DC: an-c03n02.alteeve.ca (2) - partition with quorum
Version: 1.1.10-3.1670.377aefd.git.el7-377aefd
2 Nodes configured, unknown expected votes
0 Resources configured.
Online: [ an-c03n01.alteeve.ca an-c03n02.alteeve.ca ]
Full list of resources:
Disabling Quorum
|  | Note: Show the math. | 
With quorum enabled, a two node cluster will lose quorum once either node fails. So we have to disable quorum.
By default, pacemaker uses quorum. You don't see this initially though;
pcs property
Cluster Properties:
 dc-version: 1.1.9-0.1318.a7966fb.git.fc18-a7966fb
 cluster-infrastructure: corosync
To disable it, we set no-quorum-policy=ignore.
pcs property set no-quorum-policy=ignore
pcs property
Cluster Properties:
 dc-version: 1.1.9-0.1318.a7966fb.git.fc18-a7966fb
 cluster-infrastructure: corosync
 no-quorum-policy: ignore
Enabling and Configuring Fencing
We will use IPMI and PDU based fence devices for redundancy.
You can see the list of available fence agents here. You will need to find the one for your hardware fence devices.
pcs stonith list
fence_alom - Fence agent for Sun ALOM
fence_apc - Fence agent for APC over telnet/ssh
fence_apc_snmp - Fence agent for APC over SNMP
fence_baytech - I/O Fencing agent for Baytech RPC switches in combination with a Cyclades Terminal
                Server
fence_bladecenter - Fence agent for IBM BladeCenter
fence_brocade - Fence agent for Brocade over telnet
fence_bullpap - I/O Fencing agent for Bull FAME architecture controlled by a PAP management console.
fence_cisco_mds - Fence agent for Cisco MDS
fence_cisco_ucs - Fence agent for Cisco UCS
fence_cpint - I/O Fencing agent for GFS on s390 and zSeries VM clusters
fence_drac - fencing agent for Dell Remote Access Card
fence_drac5 - Fence agent for Dell DRAC CMC/5
fence_eaton_snmp - Fence agent for Eaton over SNMP
fence_egenera - I/O Fencing agent for the Egenera BladeFrame
fence_eps - Fence agent for ePowerSwitch
fence_hpblade - Fence agent for HP BladeSystem
fence_ibmblade - Fence agent for IBM BladeCenter over SNMP
fence_idrac - Fence agent for IPMI over LAN
fence_ifmib - Fence agent for IF MIB
fence_ilo - Fence agent for HP iLO
fence_ilo2 - Fence agent for HP iLO
fence_ilo3 - Fence agent for IPMI over LAN
fence_ilo_mp - Fence agent for HP iLO MP
fence_imm - Fence agent for IPMI over LAN
fence_intelmodular - Fence agent for Intel Modular
fence_ipdu - Fence agent for iPDU over SNMP
fence_ipmilan - Fence agent for IPMI over LAN
fence_kdump - Fence agent for use with kdump
fence_ldom - Fence agent for Sun LDOM
fence_lpar - Fence agent for IBM LPAR
fence_mcdata - I/O Fencing agent for McData FC switches
fence_rackswitch - fence_rackswitch - I/O Fencing agent for RackSaver RackSwitch
fence_rhevm - Fence agent for RHEV-M REST API
fence_rsa - Fence agent for IBM RSA
fence_rsb - I/O Fencing agent for Fujitsu-Siemens RSB
fence_sanbox2 - Fence agent for QLogic SANBox2 FC switches
fence_scsi - fence agent for SCSI-3 persistent reservations
fence_virsh - Fence agent for virsh
fence_vixel - I/O Fencing agent for Vixel FC switches
fence_vmware - Fence agent for VMWare
fence_vmware_soap - Fence agent for VMWare over SOAP API
fence_wti - Fence agent for WTI
fence_xcat - I/O Fencing agent for xcat environments
fence_xenapi - XenAPI based fencing for the Citrix XenServer virtual machines.
fence_zvm - I/O Fencing agent for GFS on s390 and zSeries VM clusters
We will use fence_ipmilan and fence_apc_snmp.
Configuring IPMI Fencing
Every fence agent has a possibly unique subset of options that can be used. You can see a brief description of these options with the pcs stonith describe fence_X command. Let's look at the options available for fence_ipmilan.
pcs stonith describe fence_ipmilan
Stonith options for: fence_ipmilan
  auth: IPMI Lan Auth type (md5, password, or none)
  ipaddr: IPMI Lan IP to talk to
  passwd: Password (if required) to control power on IPMI device
  passwd_script: Script to retrieve password (if required)
  lanplus: Use Lanplus
  login: Username/Login (if required) to control power on IPMI device
  action: Operation to perform. Valid operations: on, off, reboot, status, list, diag, monitor or metadata
  timeout: Timeout (sec) for IPMI operation
  cipher: Ciphersuite to use (same as ipmitool -C parameter)
  method: Method to fence (onoff or cycle)
  power_wait: Wait X seconds after on/off operation
  delay: Wait X seconds before fencing is started
  privlvl: Privilege level on IPMI device
  verbose: Verbose mode
One of the nice things about pcs is that it allows us to create a test file to prepare all our changes in. Then, when we're happy with the changes, merge them into the running cluster. So let's make a copy called stonith_cfg
pcs cluster cib stonith_cfg
Now add IPMI fencing.
#                  unique name    fence agent   target node                           device addr             options
pcs stonith create fence_n01_ipmi fence_ipmilan pcmk_host_list="an-c03n01.alteeve.ca" ipaddr="an-c03n01.ipmi" action="reboot" login="admin" passwd="secret" delay=15 op monitor interval=60s
pcs stonith create fence_n02_ipmi fence_ipmilan pcmk_host_list="an-c03n02.alteeve.ca" ipaddr="an-c03n02.ipmi" action="reboot" login="admin" passwd="secret" op monitor interval=60s
Note that fence_n01_ipmi has a delay=15 set but fence_n02_ipmi does not. If the network connection breaks between the two nodes, they will both try to fence each other at the same time. If acpid is running, the slower node will not die right away. It will continue to run for up to four more seconds, ample time for it to also initiate a fence against the faster node. The end result is that both nodes get fenced. The ten-second delay protects against this by causing an-c03n02 to pause for 10 seconds before initiating a fence against an-c03n01. If both nodes are alive, an-c03n02 will power off before the 10 seconds pass, so it will never fence an-c03n01. However, if an-c03n01 really is dead, after the ten seconds have elapsed, fencing will proceed as normal.
Next, add the PDU fencing. This requires distinct "off" and "on" actions for each outlet on each PDU. With two nodes, each with two PSUs, this translates to eight commands. The "off" commands will be monitored to alert us if the PDU fails for some reason. There is no reason to monitor the "on" actions (it would be redundant). Note also that we don't bother using a "delay". The IPMI fence method will go first, before the PDU actions, so the PDU is already delayed.
# Node 1 - off
pcs stonith create fence_n01_pdu1_off fence_apc_snmp pcmk_host_list="an-c03n01.alteeve.ca" ipaddr="an-p01" action="off" port="1" op monitor interval="60s"
pcs stonith create fence_n01_pdu2_off fence_apc_snmp pcmk_host_list="an-c03n01.alteeve.ca" ipaddr="an-p02" action="off" port="1" power_wait="5" op monitor interval="60s"
# Node 1 - on
pcs stonith create fence_n01_pdu1_on fence_apc_snmp pcmk_host_list="an-c03n01.alteeve.ca" ipaddr="an-p01" action="on" port="1"
pcs stonith create fence_n01_pdu2_on fence_apc_snmp pcmk_host_list="an-c03n01.alteeve.ca" ipaddr="an-p02" action="on" port="1"
# Node 2 - off
pcs stonith create fence_n02_pdu1_off fence_apc_snmp pcmk_host_list="an-c03n02.alteeve.ca" ipaddr="an-p01" action="off" port="2" op monitor interval="60s"
pcs stonith create fence_n02_pdu2_off fence_apc_snmp pcmk_host_list="an-c03n02.alteeve.ca" ipaddr="an-p02" action="off" port="2" power_wait="5" op monitor interval="60s"
# Node 2 - on
pcs stonith create fence_n02_pdu1_on fence_apc_snmp pcmk_host_list="an-c03n02.alteeve.ca" ipaddr="an-p01" action="on" port="2"
pcs stonith create fence_n02_pdu2_on fence_apc_snmp pcmk_host_list="an-c03n02.alteeve.ca" ipaddr="an-p02" action="on" port="2"
We can check the new configuration now;
pcs status
Cluster name: an-cluster-03
Last updated: Tue Jul  2 16:41:55 2013
Last change: Tue Jul  2 16:41:44 2013 via cibadmin on an-c03n01.alteeve.ca
Stack: corosync
Current DC: an-c03n01.alteeve.ca (1) - partition with quorum
Version: 1.1.9-3.fc19-781a388
2 Nodes configured, unknown expected votes
10 Resources configured.
Online: [ an-c03n01.alteeve.ca an-c03n02.alteeve.ca ]
Full list of resources:
 fence_n01_ipmi	(stonith:fence_ipmilan):	Started an-c03n01.alteeve.ca 
 fence_n02_ipmi	(stonith:fence_ipmilan):	Started an-c03n02.alteeve.ca 
 fence_n01_pdu1_off	(stonith:fence_apc_snmp):	Started an-c03n01.alteeve.ca 
 fence_n01_pdu2_off	(stonith:fence_apc_snmp):	Started an-c03n02.alteeve.ca 
 fence_n02_pdu1_off	(stonith:fence_apc_snmp):	Started an-c03n01.alteeve.ca 
 fence_n02_pdu2_off	(stonith:fence_apc_snmp):	Started an-c03n02.alteeve.ca 
 fence_n01_pdu1_on	(stonith:fence_apc_snmp):	Started an-c03n01.alteeve.ca 
 fence_n01_pdu2_on	(stonith:fence_apc_snmp):	Started an-c03n02.alteeve.ca 
 fence_n02_pdu1_on	(stonith:fence_apc_snmp):	Started an-c03n01.alteeve.ca 
 fence_n02_pdu2_on	(stonith:fence_apc_snmp):	Started an-c03n02.alteeve.ca
Before we proceed, we need to tell pacemaker to use fencing;
pcs property set stonith-enabled=true
pcs propertyCluster Properties:
Cluster Properties:
 cluster-infrastructure: corosync
 dc-version: 1.1.9-3.fc19-781a388
 no-quorum-policy: ignore
 stonith-enabled: trueExcellent!
Configuring Fence Levels
The goal of fence levels is to tell pacemaker that there are "fence methods" to try and to impose an order on those methods. Each method composes one or more fence primitives and, when 2 or more primitives are tied together, that all primitives must succeed for the overall method to succeed.
So in our case; the order we want is;
- IPMI -> PDUs
The reason is that when IPMI fencing succeeds, we can be very certain the node is truly fenced. When PDU fencing succeeds, it only confirms that the power outlets were cycled. If someone moved a node's power cables to another outlet, we'll get a false positive. On that topic, tie-down the node's PSU cables to the PDU's cable tray when possible, clearly label the power cables and wrap the fingers of anyone who might move them around.
The PDU fencing needs to be implemented using four steps;
- PDU 1, outlet X -> off
- PDU 2, outlet X -> off
- The power_wait="5" setting for the fence_n0X_pdu2_off primitives will cause a 5 second delay here, giving ample time to ensure the nodes lose power
 
- PDU 1, outlet X -> on
- PDU 2, outlet X -> on
This is to ensure that both outlets are off at the same time, ensuring that the node loses power. This works because fencing_topology acts serially.
Putting all this together, we issue this command;
pcs stonith level add 1 an-c03n01.alteeve.ca fence_n01_ipmi
pcs stonith level add 1 an-c03n02.alteeve.ca fence_n02_ipmiThe 1 tells pacemaker that this is our highest priority fence method. We can see that this was set using pcs;
pcs stonith level Node: an-c03n01.alteeve.ca
  Level 1 - fence_n01_ipmi
 Node: an-c03n02.alteeve.ca
  Level 1 - fence_n02_ipmiNow we'll tell pacemaker to use the PDUs as the second fence method. Here we tie together the two off calls and the two on calls into a single method.
pcs stonith level add 2 an-c03n01.alteeve.ca fence_n01_pdu1_off,fence_n01_pdu2_off,fence_n01_pdu1_on,fence_n01_pdu2_on
pcs stonith level add 2 an-c03n02.alteeve.ca fence_n02_pdu1_off,fence_n02_pdu2_off,fence_n02_pdu1_on,fence_n02_pdu2_onCheck again and we'll see that the new methods were added.
pcs stonith level Node: an-c03n01.alteeve.ca
  Level 1 - fence_n01_ipmi
  Level 2 - fence_n01_pdu1_off,fence_n01_pdu2_off,fence_n01_pdu1_on,fence_n01_pdu2_on
 Node: an-c03n02.alteeve.ca
  Level 1 - fence_n02_ipmi
  Level 2 - fence_n02_pdu1_off,fence_n02_pdu2_off,fence_n02_pdu1_on,fence_n02_pdu2_onFor those of us who are XML fans, this is what the cib looks like now:
cat /var/lib/pacemaker/cib/cib.xml<cib epoch="18" num_updates="0" admin_epoch="0" validate-with="pacemaker-1.2" cib-last-written="Thu Jul 18 13:15:53 2013" update-origin="an-c03n01.alteeve.ca" update-client="cibadmin" crm_feature_set="3.0.7" have-quorum="1" dc-uuid="1">
  <configuration>
    <crm_config>
      <cluster_property_set id="cib-bootstrap-options">
        <nvpair id="cib-bootstrap-options-dc-version" name="dc-version" value="1.1.9-dde1c52"/>
        <nvpair id="cib-bootstrap-options-cluster-infrastructure" name="cluster-infrastructure" value="corosync"/>
        <nvpair id="cib-bootstrap-options-no-quorum-policy" name="no-quorum-policy" value="ignore"/>
      </cluster_property_set>
    </crm_config>
    <nodes>
      <node id="1" uname="an-c03n01.alteeve.ca"/>
      <node id="2" uname="an-c03n02.alteeve.ca"/>
    </nodes>
    <resources>
      <primitive class="stonith" id="fence_n01_ipmi" type="fence_ipmilan">
        <instance_attributes id="fence_n01_ipmi-instance_attributes">
          <nvpair id="fence_n01_ipmi-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n01.alteeve.ca"/>
          <nvpair id="fence_n01_ipmi-instance_attributes-ipaddr" name="ipaddr" value="an-c03n01.ipmi"/>
          <nvpair id="fence_n01_ipmi-instance_attributes-action" name="action" value="reboot"/>
          <nvpair id="fence_n01_ipmi-instance_attributes-login" name="login" value="admin"/>
          <nvpair id="fence_n01_ipmi-instance_attributes-passwd" name="passwd" value="secret"/>
          <nvpair id="fence_n01_ipmi-instance_attributes-delay" name="delay" value="15"/>
        </instance_attributes>
        <operations>
          <op id="fence_n01_ipmi-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n02_ipmi" type="fence_ipmilan">
        <instance_attributes id="fence_n02_ipmi-instance_attributes">
          <nvpair id="fence_n02_ipmi-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n02.alteeve.ca"/>
          <nvpair id="fence_n02_ipmi-instance_attributes-ipaddr" name="ipaddr" value="an-c03n02.ipmi"/>
          <nvpair id="fence_n02_ipmi-instance_attributes-action" name="action" value="reboot"/>
          <nvpair id="fence_n02_ipmi-instance_attributes-login" name="login" value="admin"/>
          <nvpair id="fence_n02_ipmi-instance_attributes-passwd" name="passwd" value="secret"/>
        </instance_attributes>
        <operations>
          <op id="fence_n02_ipmi-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n01_pdu1_off" type="fence_apc_snmp">
        <instance_attributes id="fence_n01_pdu1_off-instance_attributes">
          <nvpair id="fence_n01_pdu1_off-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n01.alteeve.ca"/>
          <nvpair id="fence_n01_pdu1_off-instance_attributes-ipaddr" name="ipaddr" value="an-p01"/>
          <nvpair id="fence_n01_pdu1_off-instance_attributes-action" name="action" value="off"/>
          <nvpair id="fence_n01_pdu1_off-instance_attributes-port" name="port" value="1"/>
        </instance_attributes>
        <operations>
          <op id="fence_n01_pdu1_off-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n01_pdu2_off" type="fence_apc_snmp">
        <instance_attributes id="fence_n01_pdu2_off-instance_attributes">
          <nvpair id="fence_n01_pdu2_off-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n01.alteeve.ca"/>
          <nvpair id="fence_n01_pdu2_off-instance_attributes-ipaddr" name="ipaddr" value="an-p02"/>
          <nvpair id="fence_n01_pdu2_off-instance_attributes-action" name="action" value="off"/>
          <nvpair id="fence_n01_pdu2_off-instance_attributes-port" name="port" value="1"/>
          <nvpair id="fence_n01_pdu2_off-instance_attributes-power_wait" name="power_wait" value="5"/>
        </instance_attributes>
        <operations>
          <op id="fence_n01_pdu2_off-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n01_pdu1_on" type="fence_apc_snmp">
        <instance_attributes id="fence_n01_pdu1_on-instance_attributes">
          <nvpair id="fence_n01_pdu1_on-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n01.alteeve.ca"/>
          <nvpair id="fence_n01_pdu1_on-instance_attributes-ipaddr" name="ipaddr" value="an-p01"/>
          <nvpair id="fence_n01_pdu1_on-instance_attributes-action" name="action" value="on"/>
          <nvpair id="fence_n01_pdu1_on-instance_attributes-port" name="port" value="1"/>
        </instance_attributes>
        <operations>
          <op id="fence_n01_pdu1_on-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n01_pdu2_on" type="fence_apc_snmp">
        <instance_attributes id="fence_n01_pdu2_on-instance_attributes">
          <nvpair id="fence_n01_pdu2_on-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n01.alteeve.ca"/>
          <nvpair id="fence_n01_pdu2_on-instance_attributes-ipaddr" name="ipaddr" value="an-p02"/>
          <nvpair id="fence_n01_pdu2_on-instance_attributes-action" name="action" value="on"/>
          <nvpair id="fence_n01_pdu2_on-instance_attributes-port" name="port" value="1"/>
        </instance_attributes>
        <operations>
          <op id="fence_n01_pdu2_on-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n02_pdu1_off" type="fence_apc_snmp">
        <instance_attributes id="fence_n02_pdu1_off-instance_attributes">
          <nvpair id="fence_n02_pdu1_off-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n02.alteeve.ca"/>
          <nvpair id="fence_n02_pdu1_off-instance_attributes-ipaddr" name="ipaddr" value="an-p01"/>
          <nvpair id="fence_n02_pdu1_off-instance_attributes-action" name="action" value="off"/>
          <nvpair id="fence_n02_pdu1_off-instance_attributes-port" name="port" value="2"/>
        </instance_attributes>
        <operations>
          <op id="fence_n02_pdu1_off-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n02_pdu2_off" type="fence_apc_snmp">
        <instance_attributes id="fence_n02_pdu2_off-instance_attributes">
          <nvpair id="fence_n02_pdu2_off-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n02.alteeve.ca"/>
          <nvpair id="fence_n02_pdu2_off-instance_attributes-ipaddr" name="ipaddr" value="an-p02"/>
          <nvpair id="fence_n02_pdu2_off-instance_attributes-action" name="action" value="off"/>
          <nvpair id="fence_n02_pdu2_off-instance_attributes-port" name="port" value="2"/>
          <nvpair id="fence_n02_pdu2_off-instance_attributes-power_wait" name="power_wait" value="5"/>
        </instance_attributes>
        <operations>
          <op id="fence_n02_pdu2_off-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n02_pdu1_on" type="fence_apc_snmp">
        <instance_attributes id="fence_n02_pdu1_on-instance_attributes">
          <nvpair id="fence_n02_pdu1_on-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n02.alteeve.ca"/>
          <nvpair id="fence_n02_pdu1_on-instance_attributes-ipaddr" name="ipaddr" value="an-p01"/>
          <nvpair id="fence_n02_pdu1_on-instance_attributes-action" name="action" value="on"/>
          <nvpair id="fence_n02_pdu1_on-instance_attributes-port" name="port" value="2"/>
        </instance_attributes>
        <operations>
          <op id="fence_n02_pdu1_on-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
      <primitive class="stonith" id="fence_n02_pdu2_on" type="fence_apc_snmp">
        <instance_attributes id="fence_n02_pdu2_on-instance_attributes">
          <nvpair id="fence_n02_pdu2_on-instance_attributes-pcmk_host_list" name="pcmk_host_list" value="an-c03n02.alteeve.ca"/>
          <nvpair id="fence_n02_pdu2_on-instance_attributes-ipaddr" name="ipaddr" value="an-p02"/>
          <nvpair id="fence_n02_pdu2_on-instance_attributes-action" name="action" value="on"/>
          <nvpair id="fence_n02_pdu2_on-instance_attributes-port" name="port" value="2"/>
        </instance_attributes>
        <operations>
          <op id="fence_n02_pdu2_on-monitor-interval-60s" interval="60s" name="monitor"/>
        </operations>
      </primitive>
    </resources>
    <constraints/>
    <fencing-topology>
      <fencing-level devices="fence_n01_ipmi" id="fl-an-c03n01.alteeve.ca-1" index="1" target="an-c03n01.alteeve.ca"/>
      <fencing-level devices="fence_n02_ipmi" id="fl-an-c03n02.alteeve.ca-1" index="1" target="an-c03n02.alteeve.ca"/>
      <fencing-level devices="fence_n01_pdu1_off,fence_n01_pdu2_off,fence_n01_pdu1_on,fence_n01_pdu2_on" id="fl-an-c03n01.alteeve.ca-2" index="2" target="an-c03n01.alteeve.ca"/>
      <fencing-level devices="fence_n02_pdu1_off,fence_n02_pdu2_off,fence_n02_pdu1_on,fence_n02_pdu2_on" id="fl-an-c03n02.alteeve.ca-2" index="2" target="an-c03n02.alteeve.ca"/>
    </fencing-topology>
  </configuration>
</cib>Fencing using fence_virsh
|  | Note: To write this section, I used two virtual machines called pcmk1 and pcmk2. | 
If you are trying to learn fencing using KVM or Xen virtual machines, you can use the fence_virsh. You can also use fence_virtd, which is actually recommended by many, but I have found it to be rather unreliable.
To use fence_virsh, first install it.
yum -y install fence-agents-virshResolving Dependencies
--> Running transaction check
---> Package fence-agents-virsh.x86_64 0:4.0.3-1.fc19 will be installed
--> Processing Dependency: /usr/bin/virsh for package: fence-agents-virsh-4.0.3-1.fc19.x86_64
--> Running transaction check
---> Package libvirt-client.x86_64 0:1.0.5.5-1.fc19 will be installed
--> Processing Dependency: pm-utils for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: nc for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libnuma.so.1(libnuma_1.2)(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libnuma.so.1(libnuma_1.1)(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: gnutls-utils for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: cyrus-sasl-md5 for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libyajl.so.2()(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libwsman_curl_client_transport.so.1()(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libwsman_client.so.1()(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libwsman.so.1()(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Processing Dependency: libnuma.so.1()(64bit) for package: libvirt-client-1.0.5.5-1.fc19.x86_64
--> Running transaction check
---> Package cyrus-sasl-md5.x86_64 0:2.1.26-9.fc19 will be installed
---> Package gnutls-utils.x86_64 0:3.1.11-1.fc19 will be installed
---> Package libwsman1.x86_64 0:2.3.6-6.fc19 will be installed
---> Package nmap-ncat.x86_64 2:6.40-2.fc19 will be installed
---> Package numactl-libs.x86_64 0:2.0.8-4.fc19 will be installed
---> Package pm-utils.x86_64 0:1.4.1-24.fc19 will be installed
---> Package yajl.x86_64 0:2.0.4-2.fc19 will be installed
--> Finished Dependency Resolution
Dependencies Resolved
=========================================================================================================
 Package                        Arch               Version                     Repository           Size
=========================================================================================================
Installing:
 fence-agents-virsh             x86_64             4.0.3-1.fc19                updates             7.7 k
Installing for dependencies:
 cyrus-sasl-md5                 x86_64             2.1.26-9.fc19               updates              54 k
 gnutls-utils                   x86_64             3.1.11-1.fc19               fedora              261 k
 libvirt-client                 x86_64             1.0.5.5-1.fc19              updates             4.9 M
 libwsman1                      x86_64             2.3.6-6.fc19                fedora              120 k
 nmap-ncat                      x86_64             2:6.40-2.fc19               updates             198 k
 numactl-libs                   x86_64             2.0.8-4.fc19                fedora               28 k
 pm-utils                       x86_64             1.4.1-24.fc19               updates             139 k
 yajl                           x86_64             2.0.4-2.fc19                fedora               38 k
Transaction Summary
=========================================================================================================
Install  1 Package (+8 Dependent packages)
Total download size: 5.7 M
Installed size: 23 M
Downloading packages:
(1/9): fence-agents-virsh-4.0.3-1.fc19.x86_64.rpm                                 | 7.7 kB  00:00:01     
(2/9): cyrus-sasl-md5-2.1.26-9.fc19.x86_64.rpm                                    |  54 kB  00:00:01     
(3/9): libwsman1-2.3.6-6.fc19.x86_64.rpm                                          | 120 kB  00:00:01     
(4/9): numactl-libs-2.0.8-4.fc19.x86_64.rpm                                       |  28 kB  00:00:00     
(5/9): pm-utils-1.4.1-24.fc19.x86_64.rpm                                          | 139 kB  00:00:00     
(6/9): nmap-ncat-6.40-2.fc19.x86_64.rpm                                           | 198 kB  00:00:01     
(7/9): yajl-2.0.4-2.fc19.x86_64.rpm                                               |  38 kB  00:00:00     
(8/9): libvirt-client-1.0.5.5-1.fc19.x86_64.rpm                                   | 4.9 MB  00:00:12     
(9/9): gnutls-utils-3.1.11-1.fc19.x86_64.rpm                                      | 261 kB  00:01:28     
---------------------------------------------------------------------------------------------------------
Total                                                                     66 kB/s | 5.7 MB     01:28     
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction
Warning: RPMDB altered outside of yum.
  Installing : cyrus-sasl-md5-2.1.26-9.fc19.x86_64                                                   1/9 
  Installing : yajl-2.0.4-2.fc19.x86_64                                                              2/9 
  Installing : 2:nmap-ncat-6.40-2.fc19.x86_64                                                        3/9 
  Installing : libwsman1-2.3.6-6.fc19.x86_64                                                         4/9 
  Installing : numactl-libs-2.0.8-4.fc19.x86_64                                                      5/9 
  Installing : gnutls-utils-3.1.11-1.fc19.x86_64                                                     6/9 
  Installing : pm-utils-1.4.1-24.fc19.x86_64                                                         7/9 
  Installing : libvirt-client-1.0.5.5-1.fc19.x86_64                                                  8/9 
  Installing : fence-agents-virsh-4.0.3-1.fc19.x86_64                                                9/9 
  Verifying  : pm-utils-1.4.1-24.fc19.x86_64                                                         1/9 
  Verifying  : gnutls-utils-3.1.11-1.fc19.x86_64                                                     2/9 
  Verifying  : numactl-libs-2.0.8-4.fc19.x86_64                                                      3/9 
  Verifying  : libwsman1-2.3.6-6.fc19.x86_64                                                         4/9 
  Verifying  : 2:nmap-ncat-6.40-2.fc19.x86_64                                                        5/9 
  Verifying  : yajl-2.0.4-2.fc19.x86_64                                                              6/9 
  Verifying  : fence-agents-virsh-4.0.3-1.fc19.x86_64                                                7/9 
  Verifying  : libvirt-client-1.0.5.5-1.fc19.x86_64                                                  8/9 
  Verifying  : cyrus-sasl-md5-2.1.26-9.fc19.x86_64                                                   9/9 
Installed:
  fence-agents-virsh.x86_64 0:4.0.3-1.fc19                                                               
Dependency Installed:
  cyrus-sasl-md5.x86_64 0:2.1.26-9.fc19                gnutls-utils.x86_64 0:3.1.11-1.fc19              
  libvirt-client.x86_64 0:1.0.5.5-1.fc19               libwsman1.x86_64 0:2.3.6-6.fc19                  
  nmap-ncat.x86_64 2:6.40-2.fc19                       numactl-libs.x86_64 0:2.0.8-4.fc19               
  pm-utils.x86_64 0:1.4.1-24.fc19                      yajl.x86_64 0:2.0.4-2.fc19                       
Complete!Now test it from the command line. To do this, we need to know a few things;
- The VM host is at IP 192.168.122.1
- The username and password (-l and -p respectively) are the credentials used to log into VM host over SSH.
- The name of the target VM, as shown by virsh, is the node (-n) value
fence_virsh -a 192.168.122.1 -l root -p "secret" -n pcmk2 -o statusStatus: ONExcellent! Now to configure it in pacemaker;
pcs stonith create fence_pcmk1_virsh fence_virsh ipaddr="192.168.122.1" login="root" passwd="secret" port="pcmk1" delay="15" pcmk_host_list="pcmk1.alteeve.ca"
pcs stonith create fence_pcmk2_virsh fence_virsh ipaddr="192.168.122.1" login="root" passwd="secret" port="pcmk2" pcmk_host_list="pcmk2.alteeve.ca"
pcs statusCluster name: an-pcmk-01
Last updated: Mon Sep 30 12:08:30 2013
Last change: Sun Sep 29 22:18:40 2013 via cibadmin on pcmk2.alteeve.ca
Stack: corosync
Current DC: pcmk1.alteeve.ca (1) - partition with quorum
Version: 1.1.10-1.fc19-368c726
2 Nodes configured
4 Resources configured
Online: [ pcmk1.alteeve.ca pcmk2.alteeve.ca ]
Full list of resources:
 fence_pcmk1_virsh	(stonith:fence_virsh):	Started pcmk1.alteeve.ca 
 fence_pcmk2_virsh	(stonith:fence_virsh):	Started pcmk2.alteeve.caDRBD
We will use DRBD 8.4.
Install DRBD 8.4.4 From Source
At this time, no EPEL repo exists for RHEL7, and the Fedora RPMs don't work, so we will install DRBD 8.4.4 from source.
Install dependencies:
yum install gcc flex rpm-build wget kernel-devel<lots on install stuff>Download and extract:
wget -c http://oss.linbit.com/drbd/8.4/drbd-8.4.4.tar.gz--2013-12-23 11:55:21--  http://oss.linbit.com/drbd/8.4/drbd-8.4.4.tar.gz
Resolving oss.linbit.com (oss.linbit.com)... 212.69.161.111
Connecting to oss.linbit.com (oss.linbit.com)|212.69.161.111|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 707642 (691K) [application/x-gzip]
Saving to: ‘drbd-8.4.4.tar.gz’
100%[====================================================================>] 707,642      308KB/s   in 2.2s   
2013-12-23 11:55:24 (308 KB/s) - ‘drbd-8.4.4.tar.gz’ saved [707642/707642]tar -xvzf drbd-8.4.4.tar.gz<bunch of files extract>Compile and install:
cd drbd-8.4.4
./configure \
  --prefix=/usr \
  --localstatedir=/var \
  --sysconfdir=/etc \
  --with-km \
  --with-udev \
  --with-pacemaker \
  --with-bashcompletion \
  --with-utils \
  --without-xen \
  --without-heartbeatchecking for gcc... gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables... 
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether we are using the GNU C compiler... yes
checking whether gcc accepts -g... yes
checking for gcc option to accept ISO C89... none needed
checking whether ln -s works... yes
checking for sed... /usr/bin/sed
checking for grep... /usr/bin/grep
checking for flex... /usr/bin/flex
checking for rpmbuild... /usr/bin/rpmbuild
checking for xsltproc... /usr/bin/xsltproc
checking for tar... /usr/bin/tar
checking for git... no
checking for dpkg-buildpackage... no
checking for udevadm... /sbin/udevadm
checking for udevinfo... false
configure: WARNING: No dpkg-buildpackage found, building Debian packages is disabled.
configure: WARNING: Cannot update buildtag without git. You may safely ignore this warning when building from a tarball.
checking for /etc/gentoo-release... no
checking for /etc/redhat-release... yes
checking for /etc/slackware-version... no
checking for /etc/debian_version... no
checking for /etc/SuSE-release... no
configure: configured for Red Hat (includes Fedora, RHEL, CentOS).
checking for /etc/fedora-release... no
configure: creating ./config.status
config.status: creating Makefile
config.status: creating user/Makefile
config.status: creating user/legacy/Makefile
config.status: creating scripts/Makefile
config.status: creating documentation/Makefile
config.status: creating user/config.h
config.status: user/config.h is unchanged
config.status: creating user/legacy/config.h
config.status: user/legacy/config.h is unchangedmakemake -C drbd drbd_buildtag.c
make[1]: Entering directory `/root/drbd-8.4.4/drbd'
make[1]: Leaving directory `/root/drbd-8.4.4/drbd'
make[1]: Entering directory `/root/drbd-8.4.4/user'
cp ../drbd/drbd_buildtag.c drbd_buildtag.c
gcc -g -O2 -Wall -I../drbd -I../drbd/compat   -c -o drbd_buildtag.o drbd_buildtag.c
gcc -g -O2 -Wall -I../drbd -I../drbd/compat     -o drbdadm drbdadm_scanner.o drbdadm_parser.o drbdadm_main.o drbdadm_adjust.o drbdtool_common.o drbdadm_usage_cnt.o drbd_buildtag.o registry.o config_flags.o libgenl.o drbd_nla.o
gcc -g -O2 -Wall -I../drbd -I../drbd/compat     -o drbdmeta drbdmeta.o drbdmeta_scanner.o drbdtool_common.o drbd_buildtag.o
gcc -g -O2 -Wall -I../drbd -I../drbd/compat     -o drbdsetup libgenl.o registry.o drbdsetup.o drbdtool_common.o drbd_buildtag.o drbd_strings.o config_flags.o drbd_nla.o wrap_printf.o
make -C legacy
make[2]: Entering directory `/root/drbd-8.4.4/user/legacy'
cp ../../drbd/drbd_buildtag.c drbd_buildtag.c
gcc -g -O2 -Wall -I. -I../drbd -I../drbd/compat   -c -o drbd_buildtag.o drbd_buildtag.c
gcc -g -O2 -Wall -I. -I../drbd -I../drbd/compat     -o drbdadm-83 drbdadm_scanner.o drbdadm_parser.o drbdadm_main.o drbdadm_adjust.o drbdtool_common.o drbdadm_usage_cnt.o drbd_buildtag.o drbdadm_minor_table.o
gcc -g -O2 -Wall -I. -I../drbd -I../drbd/compat     -o drbdsetup-83 drbdsetup.o drbdtool_common.o drbd_buildtag.o drbd_strings.o
make[2]: Leaving directory `/root/drbd-8.4.4/user/legacy'
ln -f -s legacy/drbdadm-83
ln -f -s legacy/drbdsetup-83
make[1]: Leaving directory `/root/drbd-8.4.4/user'
make[1]: Entering directory `/root/drbd-8.4.4/scripts'
make[1]: Nothing to be done for `all'.
make[1]: Leaving directory `/root/drbd-8.4.4/scripts'
make[1]: Entering directory `/root/drbd-8.4.4/documentation'
To (re)make the documentation: make doc
make[1]: Leaving directory `/root/drbd-8.4.4/documentation'
	Userland tools build was successful.
make[1]: Entering directory `/root/drbd-8.4.4/drbd'
    Calling toplevel makefile of kernel source tree, which I believe is in
    KDIR=/lib/modules/3.10.0-54.0.1.el7.x86_64/build
make -C /lib/modules/3.10.0-54.0.1.el7.x86_64/build   SUBDIRS=/root/drbd-8.4.4/drbd  modules
make[2]: Entering directory `/usr/src/kernels/3.10.0-54.0.1.el7.x86_64'
  CHK     /root/drbd-8.4.4/drbd/compat.h
  UPD     /root/drbd-8.4.4/drbd/compat.h
  CC [M]  /root/drbd-8.4.4/drbd/drbd_buildtag.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_bitmap.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_proc.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_worker.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_receiver.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_req.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_actlog.o
  CC [M]  /root/drbd-8.4.4/drbd/lru_cache.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_main.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_strings.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_nl.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_interval.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_state.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_nla.o
  CC [M]  /root/drbd-8.4.4/drbd/drbd_sysfs.o
  LD [M]  /root/drbd-8.4.4/drbd/drbd.o
  Building modules, stage 2.
  MODPOST 1 modules
  CC      /root/drbd-8.4.4/drbd/drbd.mod.o
  LD [M]  /root/drbd-8.4.4/drbd/drbd.ko
make[2]: Leaving directory `/usr/src/kernels/3.10.0-54.0.1.el7.x86_64'
mv .drbd_kernelrelease.new .drbd_kernelrelease
Memorizing module configuration ... done.
make[1]: Leaving directory `/root/drbd-8.4.4/drbd'
	Module build was successful.make installmake[1]: Entering directory `/root/drbd-8.4.4/user'
install -d //usr/sbin
install -d //var/lib/drbd
install -d //var/lock
if getent group haclient > /dev/null 2> /dev/null ; then	\
	install -g haclient -m 4750 drbdsetup //usr/sbin ;	\
	install -g haclient -m 4750 drbdmeta //usr/sbin ;	\
	install -m 755 drbdadm //usr/sbin ;		\
else								\
	install -m 755 drbdsetup //usr/sbin ;		\
	install -m 755 drbdmeta //usr/sbin ;		\
	install -m 755 drbdadm //usr/sbin ;		\
fi
if test -d //sbin && \
 ! test //sbin -ef //usr/sbin ; then		\
	ln -sf /usr/sbin/drbdsetup //sbin ;		\
	ln -sf /usr/sbin/drbdmeta //sbin ;		\
	ln -sf /usr/sbin/drbdadm //sbin ;		\
fi
make -C legacy install
make[2]: Entering directory `/root/drbd-8.4.4/user/legacy'
install -d //var/lib/drbd
install -d //var/lock
install -d //lib/drbd/
if getent group haclient > /dev/null 2> /dev/null ; then		\
	install -g haclient -m 4750 drbdsetup-83 //lib/drbd/ ;	\
	install -m 755 drbdadm-83 //lib/drbd/ ;		\
else									\
	install -m 755 drbdsetup-83 //lib/drbd/ ;		\
	install -m 755 drbdadm-83 //lib/drbd/ ; 		\
fi
make[2]: Leaving directory `/root/drbd-8.4.4/user/legacy'
make[1]: Leaving directory `/root/drbd-8.4.4/user'
make[1]: Entering directory `/root/drbd-8.4.4/scripts'
install -d //etc/rc.d/init.d
install -m 755 drbd //etc/rc.d/init.d/
install -d //usr/lib/drbd
install -m 755 outdate-peer.sh //usr/lib/drbd
install -m 755 snapshot-resync-target-lvm.sh //usr/lib/drbd
install -m 755 notify.sh //usr/lib/drbd
install -m 755 stonith_admin-fence-peer.sh //usr/lib/drbd
( set -e ; cd //usr/lib/drbd ;\
  ln -s -f snapshot-resync-target-lvm.sh unsnapshot-resync-target-lvm.sh ;\
  ln -s -f notify.sh notify-split-brain.sh ;\
  ln -s -f notify.sh notify-io-error.sh ;\
  ln -s -f notify.sh notify-pri-on-incon-degr.sh ;\
  ln -s -f notify.sh notify-pri-lost.sh ;\
  ln -s -f notify.sh notify-pri-lost-after-sb.sh ;\
  ln -s -f notify.sh notify-emergency-reboot.sh ;\
  ln -s -f notify.sh notify-emergency-shutdown.sh ;\
  ln -s -f notify.sh notify-out-of-sync.sh; )
install -d //usr/sbin
install -m 755 drbd-overview.pl //usr/sbin/drbd-overview
Don't forget to run chkconfig
mkdir -p //etc/udev/rules.d
install -m 644 drbd.rules //etc/udev/rules.d/65-drbd.rules
install -d //usr/lib/drbd
install -m 755 crm-fence-peer.sh //usr/lib/drbd
( set -e ; cd //usr/lib/drbd ;\
  ln -s -f crm-fence-peer.sh crm-unfence-peer.sh ; )
mkdir -p //usr/lib/ocf/resource.d/linbit
install -m 755 drbd.ocf //usr/lib/ocf/resource.d/linbit/drbd
mkdir -p //etc/bash_completion.d
install -m 644 drbdadm.bash_completion //etc/bash_completion.d/drbdadm
make[1]: Leaving directory `/root/drbd-8.4.4/scripts'
make[1]: Entering directory `/root/drbd-8.4.4/documentation'
set -e; for f in drbdsetup.8 drbd.conf.5 drbd.8 drbdadm.8 drbdmeta.8 ; do \
	s=${f##*.}; \
	install -v -D -m 644 $f //usr/share/man/man$s/$f ; \
done
‘drbdsetup.8’ -> ‘//usr/share/man/man8/drbdsetup.8’
‘drbd.conf.5’ -> ‘//usr/share/man/man5/drbd.conf.5’
‘drbd.8’ -> ‘//usr/share/man/man8/drbd.8’
‘drbdadm.8’ -> ‘//usr/share/man/man8/drbdadm.8’
‘drbdmeta.8’ -> ‘//usr/share/man/man8/drbdmeta.8’
make[1]: Leaving directory `/root/drbd-8.4.4/documentation'
make -C drbd install
make[1]: Entering directory `/root/drbd-8.4.4/drbd'
install -d //lib/modules/3.10.0-54.0.1.el7.x86_64/updates
install -m 644 drbd.ko //lib/modules/3.10.0-54.0.1.el7.x86_64/updates
/sbin/depmod -a || /sbin/depmod -e drbd.ko 2>&1 >/dev/null || true
make[1]: Leaving directory `/root/drbd-8.4.4/drbd'Don't let DRBD start on boot (pacemaker will handle it for us).
systemctl disable drbd.servicedrbd.service is not a native service, redirecting to /sbin/chkconfig.
Executing /sbin/chkconfig drbd offDone.
Optional; Make RPMs
|  | Warning: I've not been able to get the RPMs genreated here to install yet. I'd recommend skipping this, unless you want to help sort out the problems. :) | 
After ./configure above, you can make RPMs instead of installing directly.
Dependencies:
yum install rpmdevtools redhat-rpm-config kernel-devel<install text>Setup RPM dev tree:
cd ~
rpmdev-setuptree
cd drbd-8.4.4
ls -lah ~/rpmbuild/total 4.0K
drwxr-xr-x. 7 root root   67 Dec 23 20:06 .
dr-xr-x---. 6 root root 4.0K Dec 23 20:06 ..
drwxr-xr-x. 2 root root    6 Dec 23 20:06 BUILD
drwxr-xr-x. 2 root root    6 Dec 23 20:06 RPMS
drwxr-xr-x. 2 root root    6 Dec 23 20:06 SOURCES
drwxr-xr-x. 2 root root    6 Dec 23 20:06 SPECS
drwxr-xr-x. 2 root root    6 Dec 23 20:06 SRPMSUserland tools:
make rpmchecking for presence of 8\.4\.4 in various changelog files
	debian/changelog needs update [ignored]
make -C drbd drbd_buildtag.c
make[1]: Entering directory `/root/drbd-8.4.4/drbd'
make[1]: Leaving directory `/root/drbd-8.4.4/drbd'
make -C documentation doc
make[1]: Entering directory `/root/drbd-8.4.4/documentation'
../user/drbdsetup xml-help new-resource > drbdsetup_xml-help_new-resource.xml
/usr/bin/xsltproc -o drbdsetup_new-resource.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_new-resource.xml
../user/drbdsetup xml-help new-minor > drbdsetup_xml-help_new-minor.xml
/usr/bin/xsltproc -o drbdsetup_new-minor.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_new-minor.xml
../user/drbdsetup xml-help del-resource > drbdsetup_xml-help_del-resource.xml
/usr/bin/xsltproc -o drbdsetup_del-resource.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_del-resource.xml
../user/drbdsetup xml-help del-minor > drbdsetup_xml-help_del-minor.xml
/usr/bin/xsltproc -o drbdsetup_del-minor.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_del-minor.xml
../user/drbdsetup xml-help attach > drbdsetup_xml-help_attach.xml
/usr/bin/xsltproc -o drbdsetup_attach.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_attach.xml
../user/drbdsetup xml-help connect > drbdsetup_xml-help_connect.xml
/usr/bin/xsltproc -o drbdsetup_connect.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_connect.xml
../user/drbdsetup xml-help disk-options > drbdsetup_xml-help_disk-options.xml
/usr/bin/xsltproc -o drbdsetup_disk-options.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_disk-options.xml
../user/drbdsetup xml-help net-options > drbdsetup_xml-help_net-options.xml
/usr/bin/xsltproc -o drbdsetup_net-options.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_net-options.xml
../user/drbdsetup xml-help resource-options > drbdsetup_xml-help_resource-options.xml
/usr/bin/xsltproc -o drbdsetup_resource-options.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_resource-options.xml
../user/drbdsetup xml-help disconnect > drbdsetup_xml-help_disconnect.xml
/usr/bin/xsltproc -o drbdsetup_disconnect.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_disconnect.xml
../user/drbdsetup xml-help detach > drbdsetup_xml-help_detach.xml
/usr/bin/xsltproc -o drbdsetup_detach.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_detach.xml
../user/drbdsetup xml-help primary > drbdsetup_xml-help_primary.xml
/usr/bin/xsltproc -o drbdsetup_primary.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_primary.xml
../user/drbdsetup xml-help secondary > drbdsetup_xml-help_secondary.xml
/usr/bin/xsltproc -o drbdsetup_secondary.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_secondary.xml
../user/drbdsetup xml-help verify > drbdsetup_xml-help_verify.xml
/usr/bin/xsltproc -o drbdsetup_verify.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_verify.xml
../user/drbdsetup xml-help invalidate > drbdsetup_xml-help_invalidate.xml
/usr/bin/xsltproc -o drbdsetup_invalidate.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_invalidate.xml
../user/drbdsetup xml-help invalidate-remote > drbdsetup_xml-help_invalidate-remote.xml
/usr/bin/xsltproc -o drbdsetup_invalidate-remote.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_invalidate-remote.xml
../user/drbdsetup xml-help down > drbdsetup_xml-help_down.xml
/usr/bin/xsltproc -o drbdsetup_down.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_down.xml
../user/drbdsetup xml-help wait-connect > drbdsetup_xml-help_wait-connect.xml
/usr/bin/xsltproc -o drbdsetup_wait-connect.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_wait-connect.xml
../user/drbdsetup xml-help wait-sync > drbdsetup_xml-help_wait-sync.xml
/usr/bin/xsltproc -o drbdsetup_wait-sync.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_wait-sync.xml
../user/drbdsetup xml-help role > drbdsetup_xml-help_role.xml
/usr/bin/xsltproc -o drbdsetup_role.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_role.xml
../user/drbdsetup xml-help cstate > drbdsetup_xml-help_cstate.xml
/usr/bin/xsltproc -o drbdsetup_cstate.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_cstate.xml
../user/drbdsetup xml-help dstate > drbdsetup_xml-help_dstate.xml
/usr/bin/xsltproc -o drbdsetup_dstate.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_dstate.xml
../user/drbdsetup xml-help resize > drbdsetup_xml-help_resize.xml
/usr/bin/xsltproc -o drbdsetup_resize.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_resize.xml
../user/drbdsetup xml-help check-resize > drbdsetup_xml-help_check-resize.xml
/usr/bin/xsltproc -o drbdsetup_check-resize.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_check-resize.xml
../user/drbdsetup xml-help pause-sync > drbdsetup_xml-help_pause-sync.xml
/usr/bin/xsltproc -o drbdsetup_pause-sync.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_pause-sync.xml
../user/drbdsetup xml-help resume-sync > drbdsetup_xml-help_resume-sync.xml
/usr/bin/xsltproc -o drbdsetup_resume-sync.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_resume-sync.xml
../user/drbdsetup xml-help outdate > drbdsetup_xml-help_outdate.xml
/usr/bin/xsltproc -o drbdsetup_outdate.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_outdate.xml
../user/drbdsetup xml-help show-gi > drbdsetup_xml-help_show-gi.xml
/usr/bin/xsltproc -o drbdsetup_show-gi.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_show-gi.xml
../user/drbdsetup xml-help get-gi > drbdsetup_xml-help_get-gi.xml
/usr/bin/xsltproc -o drbdsetup_get-gi.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_get-gi.xml
../user/drbdsetup xml-help show > drbdsetup_xml-help_show.xml
/usr/bin/xsltproc -o drbdsetup_show.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_show.xml
../user/drbdsetup xml-help events > drbdsetup_xml-help_events.xml
/usr/bin/xsltproc -o drbdsetup_events.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_events.xml
../user/drbdsetup xml-help suspend-io > drbdsetup_xml-help_suspend-io.xml
/usr/bin/xsltproc -o drbdsetup_suspend-io.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_suspend-io.xml
../user/drbdsetup xml-help resume-io > drbdsetup_xml-help_resume-io.xml
/usr/bin/xsltproc -o drbdsetup_resume-io.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_resume-io.xml
../user/drbdsetup xml-help new-current-uuid > drbdsetup_xml-help_new-current-uuid.xml
/usr/bin/xsltproc -o drbdsetup_new-current-uuid.xml xml-usage-to-docbook.xsl drbdsetup_xml-help_new-current-uuid.xml
/usr/bin/xsltproc \
--xinclude \
http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl drbdsetup.xml
Note: Writing drbdsetup.8
rm drbdsetup_xml-help_new-minor.xml drbdsetup_xml-help_invalidate.xml drbdsetup_xml-help_disk-options.xml drbdsetup_xml-help_resize.xml drbdsetup_xml-help_del-resource.xml drbdsetup_xml-help_suspend-io.xml drbdsetup_xml-help_primary.xml drbdsetup_xml-help_invalidate-remote.xml drbdsetup_xml-help_del-minor.xml drbdsetup_xml-help_resume-io.xml drbdsetup_xml-help_cstate.xml drbdsetup_xml-help_attach.xml drbdsetup_xml-help_events.xml drbdsetup_xml-help_down.xml drbdsetup_xml-help_show.xml drbdsetup_xml-help_check-resize.xml drbdsetup_xml-help_wait-connect.xml drbdsetup_xml-help_secondary.xml drbdsetup_xml-help_dstate.xml drbdsetup_xml-help_resume-sync.xml drbdsetup_xml-help_outdate.xml drbdsetup_xml-help_new-resource.xml drbdsetup_xml-help_connect.xml drbdsetup_xml-help_pause-sync.xml drbdsetup_xml-help_verify.xml drbdsetup_xml-help_net-options.xml drbdsetup_xml-help_role.xml drbdsetup_xml-help_get-gi.xml drbdsetup_xml-help_show-gi.xml drbdsetup_xml-help_new-current-uuid.xml drbdsetup_xml-help_resource-options.xml drbdsetup_xml-help_detach.xml drbdsetup_xml-help_wait-sync.xml drbdsetup_xml-help_disconnect.xml
make[1]: Leaving directory `/root/drbd-8.4.4/documentation'
test -e .filelist
ln -s -f drbd/linux/drbd_config.h drbd_config.h
rm -f drbd-8.4.4
ln -s . drbd-8.4.4
for f in $(<.filelist) ; do [ -e $f ] && continue ; echo missing: $f ; exit 1; done
grep debian .filelist >/dev/null 2>&1 && _DEB=-debian || _DEB="" ; \
tar --owner=0 --group=0 -czf - -T .filelist > drbd-8.4.4$_DEB.tar.gz
rm drbd-8.4.4
cp drbd-8.4.4.tar.gz `rpm -E "%_sourcedir"`
/usr/bin/rpmbuild -bb \
     \
    drbd.spec
warning: bogus date in %changelog: Fri Oct 15 2013 Lars Ellenberg <lars@linbit.com> - 8.4.4-3
warning: bogus date in %changelog: Wed Jul 15 2011 Philipp Reisner <phil@linbit.com> - 8.4.0-1
warning: bogus date in %changelog: Thu Jan 13 2010 Philipp Reisner <phil@linbit.com> - 8.3.7-1
warning: bogus date in %changelog: Thu Nov  8 2009 Philipp Reisner <phil@linbit.com> - 8.3.6-1
warning: bogus date in %changelog: Thu Oct 27 2009 Philipp Reisner <phil@linbit.com> - 8.3.5-1
warning: bogus date in %changelog: Thu Oct  6 2009 Philipp Reisner <phil@linbit.com> - 8.3.4-1
warning: bogus date in %changelog: Thu Oct  5 2009 Philipp Reisner <phil@linbit.com> - 8.3.3-1
warning: bogus date in %changelog: Thu Nov 12 2008 Philipp Reisner <phil@linbit.com> - 8.2.7-1
warning: bogus date in %changelog: Mon Mar 3 2007 Philipp Reisner <phil@linbit.com> - 8.0.1-1
Executing(%prep): /bin/sh -e /var/tmp/rpm-tmp.VL46Sg
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd /root/rpmbuild/BUILD
+ rm -rf drbd-8.4.4
+ /usr/bin/gzip -dc /root/rpmbuild/SOURCES/drbd-8.4.4.tar.gz
+ /usr/bin/tar -xf -
+ STATUS=0
+ '[' 0 -ne 0 ']'
+ cd drbd-8.4.4
+ /usr/bin/chmod -Rf a+rX,u+w,g-w,o-w .
+ exit 0
Executing(%build): /bin/sh -e /var/tmp/rpm-tmp.lsEd1t
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ CFLAGS='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic'
+ export CFLAGS
+ CXXFLAGS='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic'
+ export CXXFLAGS
+ FFLAGS='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -I/usr/lib64/gfortran/modules'
+ export FFLAGS
+ FCFLAGS='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -I/usr/lib64/gfortran/modules'
+ export FCFLAGS
+ LDFLAGS='-Wl,-z,relro '
+ export LDFLAGS
++ find . -name config.guess -o -name config.sub
+ ./configure --build=x86_64-redhat-linux-gnu --host=x86_64-redhat-linux-gnu --program-prefix= --disable-dependency-tracking --prefix=/usr --exec-prefix=/usr --bindir=/usr/bin --sbindir=/usr/sbin --sysconfdir=/etc --datadir=/usr/share --includedir=/usr/include --libdir=/usr/lib64 --libexecdir=/usr/libexec --localstatedir=/var --sharedstatedir=/var/lib --mandir=/usr/share/man --infodir=/usr/share/info --with-utils --without-km --with-initdir=/etc/rc.d/init.d
configure: WARNING: unrecognized options: --disable-dependency-tracking
checking for x86_64-redhat-linux-gnu-gcc... no
checking for gcc... gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables... 
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether we are using the GNU C compiler... yes
checking whether gcc accepts -g... yes
checking for gcc option to accept ISO C89... none needed
checking whether ln -s works... yes
checking for sed... /usr/bin/sed
checking for grep... /usr/bin/grep
checking for flex... /usr/bin/flex
checking for rpmbuild... /usr/bin/rpmbuild
checking for xsltproc... /usr/bin/xsltproc
checking for tar... /usr/bin/tar
checking for git... no
checking for dpkg-buildpackage... no
checking for udevadm... /sbin/udevadm
checking for udevinfo... false
configure: WARNING: No dpkg-buildpackage found, building Debian packages is disabled.
configure: WARNING: Cannot update buildtag without git. You may safely ignore this warning when building from a tarball.
checking for /etc/gentoo-release... no
checking for /etc/redhat-release... yes
checking for /etc/slackware-version... no
checking for /etc/debian_version... no
checking for /etc/SuSE-release... no
configure: configured for Red Hat (includes Fedora, RHEL, CentOS).
checking for /etc/fedora-release... no
configure: creating ./config.status
config.status: creating Makefile
config.status: creating user/Makefile
config.status: creating user/legacy/Makefile
config.status: creating scripts/Makefile
config.status: creating documentation/Makefile
config.status: creating user/config.h
config.status: creating user/legacy/config.h
configure: WARNING: unrecognized options: --disable-dependency-tracking
+ make -j4
make[1]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4'
make -C drbd drbd_buildtag.c
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/drbd'
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/drbd'
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/user'
flex -s -odrbdadm_scanner.c drbdadm_scanner.fl
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdadm_parser.o drbdadm_parser.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdadm_main.o drbdadm_main.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdadm_adjust.o drbdadm_adjust.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdtool_common.o drbdtool_common.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdadm_usage_cnt.o drbdadm_usage_cnt.c
cp ../drbd/drbd_buildtag.c drbd_buildtag.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o registry.o registry.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o config_flags.o config_flags.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat -DHAVE_CTRL_ATTR_VERSION -DHAVE_CTRL_ATTR_HDRSIZE -DHAVE_CTRL_ATTR_MCAST_GROUPS   -c -o libgenl.o libgenl.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbd_nla.o drbd_nla.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdmeta.o drbdmeta.c
flex -s -odrbdmeta_scanner.c drbdmeta_scanner.fl
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdsetup.o drbdsetup.c
cp ../drbd/drbd_strings.c drbd_strings.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o wrap_printf.o wrap_printf.c
drbdsetup.c: In function 'modprobe_drbd':
drbdsetup.c:2396:9: warning: ignoring return value of 'system', declared with attribute warn_unused_result [-Wunused-result]
   system("/sbin/modprobe drbd");
         ^
make -C legacy
make[3]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/user/legacy'
flex -s -odrbdadm_scanner.c drbdadm_scanner.fl
cp ../drbd_endian.h drbd_endian.h
cp ../../drbd/drbd_buildtag.c drbd_buildtag.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdadm_minor_table.o drbdadm_minor_table.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbd_strings.o drbd_strings.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdadm_scanner.o drbdadm_scanner.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdadm_parser.o drbdadm_parser.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdadm_scanner.o drbdadm_scanner.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbd_buildtag.o drbd_buildtag.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbdmeta_scanner.o drbdmeta_scanner.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat   -c -o drbd_strings.o drbd_strings.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat  -Wl,-z,relro   -Wl,-z,relro  -o drbdadm drbdadm_scanner.o drbdadm_parser.o drbdadm_main.o drbdadm_adjust.o drbdtool_common.o drbdadm_usage_cnt.o drbd_buildtag.o registry.o config_flags.o libgenl.o drbd_nla.o
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat  -Wl,-z,relro   -Wl,-z,relro  -o drbdsetup libgenl.o registry.o drbdsetup.o drbdtool_common.o drbd_buildtag.o drbd_strings.o config_flags.o drbd_nla.o wrap_printf.o
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdadm_main.o drbdadm_main.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I../drbd -I../drbd/compat  -Wl,-z,relro   -Wl,-z,relro  -o drbdmeta drbdmeta.o drbdmeta_scanner.o drbdtool_common.o drbd_buildtag.o
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdadm_adjust.o drbdadm_adjust.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdtool_common.o drbdtool_common.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdadm_usage_cnt.o drbdadm_usage_cnt.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbd_buildtag.o drbd_buildtag.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat   -c -o drbdsetup.o drbdsetup.c
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat  -Wl,-z,relro   -Wl,-z,relro  -o drbdsetup-83 drbdsetup.o drbdtool_common.o drbd_buildtag.o drbd_strings.o
gcc -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -grecord-gcc-switches  -m64 -mtune=generic -Wall -I. -I../drbd -I../drbd/compat  -Wl,-z,relro   -Wl,-z,relro  -o drbdadm-83 drbdadm_scanner.o drbdadm_parser.o drbdadm_main.o drbdadm_adjust.o drbdtool_common.o drbdadm_usage_cnt.o drbd_buildtag.o drbdadm_minor_table.o
make[3]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/user/legacy'
ln -f -s legacy/drbdadm-83
ln -f -s legacy/drbdsetup-83
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/user'
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/scripts'
make[2]: Nothing to be done for `all'.
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/scripts'
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/documentation'
To (re)make the documentation: make doc
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/documentation'
	Userland tools build was successful.
make[1]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4'
+ exit 0
Executing(%install): /bin/sh -e /var/tmp/rpm-tmp.jAHX2O
+ umask 022
+ cd /root/rpmbuild/BUILD
+ '[' /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64 '!=' / ']'
+ rm -rf /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
++ dirname /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
+ mkdir -p /root/rpmbuild/BUILDROOT
+ mkdir /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
+ cd drbd-8.4.4
+ rm -rf /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
+ make install DESTDIR=/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
make[1]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4'
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/user'
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/var/lib/drbd
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/var/lock
if getent group haclient > /dev/null 2> /dev/null ; then	\
	install -g haclient -m 4750 drbdsetup /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ;	\
	install -g haclient -m 4750 drbdmeta /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ;	\
	install -m 755 drbdadm /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ;		\
else								\
	install -m 755 drbdsetup /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ;		\
	install -m 755 drbdmeta /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ;		\
	install -m 755 drbdadm /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ;		\
fi
if test -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin && \
 ! test /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin -ef /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin ; then		\
	ln -sf /usr/sbin/drbdsetup /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin ;		\
	ln -sf /usr/sbin/drbdmeta /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin ;		\
	ln -sf /usr/sbin/drbdadm /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin ;		\
fi
make -C legacy install
make[3]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/user/legacy'
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/var/lib/drbd
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/var/lock
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/
if getent group haclient > /dev/null 2> /dev/null ; then		\
	install -g haclient -m 4750 drbdsetup-83 /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/ ;	\
	install -m 755 drbdadm-83 /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/ ;		\
else									\
	install -m 755 drbdsetup-83 /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/ ;		\
	install -m 755 drbdadm-83 /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/ ; 		\
fi
make[3]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/user/legacy'
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/user'
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/scripts'
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/rc.d/init.d
install -m 755 drbd /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/rc.d/init.d/
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
install -m 755 outdate-peer.sh /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
install -m 755 snapshot-resync-target-lvm.sh /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
install -m 755 notify.sh /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
install -m 755 stonith_admin-fence-peer.sh /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
( set -e ; cd /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd ;\
  ln -s -f snapshot-resync-target-lvm.sh unsnapshot-resync-target-lvm.sh ;\
  ln -s -f notify.sh notify-split-brain.sh ;\
  ln -s -f notify.sh notify-io-error.sh ;\
  ln -s -f notify.sh notify-pri-on-incon-degr.sh ;\
  ln -s -f notify.sh notify-pri-lost.sh ;\
  ln -s -f notify.sh notify-pri-lost-after-sb.sh ;\
  ln -s -f notify.sh notify-emergency-reboot.sh ;\
  ln -s -f notify.sh notify-emergency-shutdown.sh ;\
  ln -s -f notify.sh notify-out-of-sync.sh; )
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin
install -m 755 drbd-overview.pl /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin/drbd-overview
Don't forget to run chkconfig
mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/udev/rules.d
install -m 644 drbd.rules /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/udev/rules.d/65-drbd.rules
mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/xen/scripts
install -m 755 block-drbd /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/xen/scripts
mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/ha.d/resource.d
install -m 755 drbddisk /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/ha.d/resource.d
install -m 755 drbdupper /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/ha.d/resource.d
install -d /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
install -m 755 crm-fence-peer.sh /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd
( set -e ; cd /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/drbd ;\
  ln -s -f crm-fence-peer.sh crm-unfence-peer.sh ; )
mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/ocf/resource.d/linbit
install -m 755 drbd.ocf /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/lib/ocf/resource.d/linbit/drbd
mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/bash_completion.d
install -m 644 drbdadm.bash_completion /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/etc/bash_completion.d/drbdadm
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/scripts'
make[2]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/documentation'
set -e; for f in drbdsetup.8 drbd.conf.5 drbd.8 drbdadm.8 drbdmeta.8 drbddisk.8 ; do \
	s=${f##*.}; \
	install -v -D -m 644 $f /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man$s/$f ; \
done
install: creating directory '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share'
install: creating directory '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man'
install: creating directory '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man8'
'drbdsetup.8' -> '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man8/drbdsetup.8'
install: creating directory '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man5'
'drbd.conf.5' -> '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man5/drbd.conf.5'
'drbd.8' -> '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man8/drbd.8'
'drbdadm.8' -> '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man8/drbdadm.8'
'drbdmeta.8' -> '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man8/drbdmeta.8'
'drbddisk.8' -> '/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/man/man8/drbddisk.8'
make[2]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/documentation'
make[1]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4'
+ mkdir /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin/
+ cd /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/sbin/
+ ln -sv ../usr/sbin/drbdadm .
'./drbdadm' -> '../usr/sbin/drbdadm'
+ ln -sv ../usr/sbin/drbdmeta .
'./drbdmeta' -> '../usr/sbin/drbdmeta'
+ ln -sv ../usr/sbin/drbdsetup .
'./drbdsetup' -> '../usr/sbin/drbdsetup'
+ /usr/lib/rpm/find-debuginfo.sh --strict-build-id -m --run-dwz --dwz-low-mem-die-limit 10000000 --dwz-max-die-limit 110000000 /root/rpmbuild/BUILD/drbd-8.4.4
extracting debug info from /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin/drbdsetup
extracting debug info from /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin/drbdmeta
extracting debug info from /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/sbin/drbdadm
extracting debug info from /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/drbdsetup-83
extracting debug info from /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/lib/drbd/drbdadm-83
/usr/lib/rpm/sepdebugcrcfix: Updated 5 CRC32s, 0 CRC32s did match.
symlinked /usr/lib/debug/usr/sbin/drbdadm.debug to /usr/lib/debug/sbin/drbdadm.debug
symlinked /usr/lib/debug/usr/sbin/drbdmeta.debug to /usr/lib/debug/sbin/drbdmeta.debug
symlinked /usr/lib/debug/usr/sbin/drbdsetup.debug to /usr/lib/debug/sbin/drbdsetup.debug
2507 blocks
+ '[' '%{buildarch}' = noarch ']'
+ QA_CHECK_RPATHS=1
+ case "${QA_CHECK_RPATHS:-}" in
+ /usr/lib/rpm/check-rpaths
+ /usr/lib/rpm/check-buildroot
+ /usr/lib/rpm/redhat/brp-compress
+ /usr/lib/rpm/redhat/brp-strip-static-archive /usr/bin/strip
+ /usr/lib/rpm/brp-python-bytecompile /usr/bin/python 1
+ /usr/lib/rpm/redhat/brp-python-hardlink
+ /usr/lib/rpm/redhat/brp-java-repack-jars
Processing files: drbd-8.4.4-4.el7.x86_64
Executing(%doc): /bin/sh -e /var/tmp/rpm-tmp.VvkRyc
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ DOCDIR=/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-8.4.4
+ export DOCDIR
+ /usr/bin/mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-8.4.4
+ cp -pr COPYING /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-8.4.4
+ cp -pr ChangeLog /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-8.4.4
+ cp -pr README /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-8.4.4
+ exit 0
Provides: drbd = 8.4.4-4.el7 drbd(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Processing files: drbd-utils-8.4.4-4.el7.x86_64
Executing(%doc): /bin/sh -e /var/tmp/rpm-tmp.k1J1cA
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ DOCDIR=/root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-utils-8.4.4
+ export DOCDIR
+ /usr/bin/mkdir -p /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-utils-8.4.4
+ cp -pr scripts/drbd.conf.example /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-utils-8.4.4
+ cp -pr COPYING /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-utils-8.4.4
+ cp -pr ChangeLog /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-utils-8.4.4
+ cp -pr README /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64/usr/share/doc/drbd-utils-8.4.4
+ exit 0
Provides: config(drbd-utils) = 8.4.4-4.el7 drbd-utils = 8.4.4-4.el7 drbd-utils(x86-64) = 8.4.4-4.el7
Requires(interp): /bin/sh /bin/sh
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Requires(post): /bin/sh chkconfig
Requires(preun): /bin/sh chkconfig
Requires: /bin/bash /usr/bin/perl libc.so.6()(64bit) libc.so.6(GLIBC_2.11)(64bit) libc.so.6(GLIBC_2.14)(64bit) libc.so.6(GLIBC_2.16)(64bit) libc.so.6(GLIBC_2.2.5)(64bit) libc.so.6(GLIBC_2.3)(64bit) libc.so.6(GLIBC_2.3.4)(64bit) libc.so.6(GLIBC_2.4)(64bit) libc.so.6(GLIBC_2.7)(64bit) libc.so.6(GLIBC_2.8)(64bit) perl(strict) perl(warnings) rtld(GNU_HASH)
Conflicts: drbd < 8.3.6 drbd82 drbd83
Processing files: drbd-xen-8.4.4-4.el7.x86_64
Provides: drbd-xen = 8.4.4-4.el7 drbd-xen(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Requires: /bin/bash
Processing files: drbd-udev-8.4.4-4.el7.x86_64
Provides: config(drbd-udev) = 8.4.4-4.el7 drbd-udev = 8.4.4-4.el7 drbd-udev(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Processing files: drbd-pacemaker-8.4.4-4.el7.x86_64
Provides: drbd-pacemaker = 8.4.4-4.el7 drbd-pacemaker(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Requires: /bin/bash /bin/sh
Processing files: drbd-heartbeat-8.4.4-4.el7.x86_64
Provides: drbd-heartbeat = 8.4.4-4.el7 drbd-heartbeat(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Requires: /bin/bash
Processing files: drbd-bash-completion-8.4.4-4.el7.x86_64
Provides: config(drbd-bash-completion) = 8.4.4-4.el7 drbd-bash-completion = 8.4.4-4.el7 drbd-bash-completion(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1
Processing files: drbd-debuginfo-8.4.4-4.el7.x86_64
Provides: drbd-debuginfo = 8.4.4-4.el7 drbd-debuginfo(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 rpmlib(CompressedFileNames) <= 3.0.4-1
Checking for unpackaged file(s): /usr/lib/rpm/check-files /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-utils-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-xen-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-udev-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-pacemaker-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-heartbeat-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-bash-completion-8.4.4-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-debuginfo-8.4.4-4.el7.x86_64.rpm
Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.lctsa8
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ rm -rf /root/rpmbuild/BUILDROOT/drbd-8.4.4-4.el7.x86_64
+ exit 0
You have now:
/root/rpmbuild/RPMS/x86_64/drbd-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-utils-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-xen-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-udev-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-pacemaker-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-heartbeat-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-bash-completion-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-debuginfo-8.4.4-4.el7.x86_64.rpmKernel module:
make kmp-rpmchecking for presence of 8\.4\.4 in various changelog files
	debian/changelog needs update [ignored]
make -C drbd drbd_buildtag.c
make[1]: Entering directory `/root/drbd-8.4.4/drbd'
make[1]: Leaving directory `/root/drbd-8.4.4/drbd'
make -C documentation doc
make[1]: Entering directory `/root/drbd-8.4.4/documentation'
make[1]: Nothing to be done for `doc'.
make[1]: Leaving directory `/root/drbd-8.4.4/documentation'
test -e .filelist
ln -s -f drbd/linux/drbd_config.h drbd_config.h
rm -f drbd-8.4.4
ln -s . drbd-8.4.4
for f in $(<.filelist) ; do [ -e $f ] && continue ; echo missing: $f ; exit 1; done
grep debian .filelist >/dev/null 2>&1 && _DEB=-debian || _DEB="" ; \
tar --owner=0 --group=0 -czf - -T .filelist > drbd-8.4.4$_DEB.tar.gz
rm drbd-8.4.4
cp drbd-8.4.4.tar.gz `rpm -E "%_sourcedir"`
/usr/bin/rpmbuild -bb \
     --define "kernel_version `uname -r`" \
     \
    drbd-kernel.spec
cat: /root/rpmbuild/SOURCES/preamble-sles10: No such file or directory
cat: /root/rpmbuild/SOURCES/preamble-sles11: No such file or directory
cat: /root/rpmbuild/SOURCES/preamble-rhel5: No such file or directory
warning: bogus date in %changelog: Wed Nov 25 2010 Andreas Gruenbacher <agruen@linbit.com> - 8.3.9-1
Executing(%prep): /bin/sh -e /var/tmp/rpm-tmp.ojTAWZ
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd /root/rpmbuild/BUILD
+ rm -rf drbd-8.4.4
+ /usr/bin/gzip -dc /root/rpmbuild/SOURCES/drbd-8.4.4.tar.gz
+ /usr/bin/tar -xf -
+ STATUS=0
+ '[' 0 -ne 0 ']'
+ cd drbd-8.4.4
+ /usr/bin/chmod -Rf a+rX,u+w,g-w,o-w .
+ exit 0
Executing(%build): /bin/sh -e /var/tmp/rpm-tmp.IzMdDZ
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ rm -rf obj
+ mkdir obj
+ ln -s ../scripts obj/
+ for flavor in default
+ cp -r drbd obj/default
++ '[' default = default ']'
+ make -C obj/default -j4 all KDIR=/usr/src/kernels/3.10.0-54.0.1.el7.x86_64
make[1]: Entering directory `/root/rpmbuild/BUILD/drbd-8.4.4/obj/default'
    Calling toplevel makefile of kernel source tree, which I believe is in
    KDIR=/usr/src/kernels/3.10.0-54.0.1.el7.x86_64
make -C /usr/src/kernels/3.10.0-54.0.1.el7.x86_64   SUBDIRS=/root/rpmbuild/BUILD/drbd-8.4.4/obj/default  modules
make[2]: Entering directory `/usr/src/kernels/3.10.0-54.0.1.el7.x86_64'
  CHK     /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/compat.h
  UPD     /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/compat.h
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_buildtag.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_bitmap.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_proc.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_worker.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_receiver.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_req.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_actlog.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/lru_cache.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_main.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_strings.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_nl.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_interval.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_state.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_nla.o
  CC [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd_sysfs.o
  LD [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd.o
  Building modules, stage 2.
  MODPOST 1 modules
  CC      /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd.mod.o
  LD [M]  /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd.ko
make[2]: Leaving directory `/usr/src/kernels/3.10.0-54.0.1.el7.x86_64'
mv .drbd_kernelrelease.new .drbd_kernelrelease
Memorizing module configuration ... done.
make[1]: Leaving directory `/root/rpmbuild/BUILD/drbd-8.4.4/obj/default'
+ exit 0
Executing(%install): /bin/sh -e /var/tmp/rpm-tmp.FFy5To
+ umask 022
+ cd /root/rpmbuild/BUILD
+ '[' /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64 '!=' / ']'
+ rm -rf /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
++ dirname /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
+ mkdir -p /root/rpmbuild/BUILDROOT
+ mkdir /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
+ cd drbd-8.4.4
+ export INSTALL_MOD_PATH=/root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
+ INSTALL_MOD_PATH=/root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
+ export INSTALL_MOD_DIR=extra
+ INSTALL_MOD_DIR=extra
+ '[' extra = extra ']'
+ INSTALL_MOD_DIR=extra/drbd
+ for flavor in default
++ '[' default = default ']'
+ make -C /usr/src/kernels/3.10.0-54.0.1.el7.x86_64 modules_install M=/root/rpmbuild/BUILD/drbd-8.4.4/obj/default
make[1]: Entering directory `/usr/src/kernels/3.10.0-54.0.1.el7.x86_64'
  INSTALL /root/rpmbuild/BUILD/drbd-8.4.4/obj/default/drbd.ko
Can't read private key
  DEPMOD  3.10.0-54.0.1.el7.x86_64
depmod: WARNING: could not open /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/lib/modules/3.10.0-54.0.1.el7.x86_64/modules.order: No such file or directory
depmod: WARNING: /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/lib/modules/3.10.0-54.0.1.el7.x86_64/extra/drbd/drbd.ko needs unknown symbol crc32c
depmod: WARNING: could not open /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/lib/modules/3.10.0-54.0.1.el7.x86_64/modules.builtin: No such file or directory
make[1]: Leaving directory `/usr/src/kernels/3.10.0-54.0.1.el7.x86_64'
+++ '[' default = default ']'
++ cat /usr/src/kernels/3.10.0-54.0.1.el7.x86_64/include/config/kernel.release
+ kernelrelease=3.10.0-54.0.1.el7.x86_64
+ mv obj/default/.kernel.config.gz obj/k-config-3.10.0-54.0.1.el7.x86_64.gz
+ mkdir -p /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/etc/depmod.d
+ echo 'override drbd * weak-updates'
+ /usr/lib/rpm/find-debuginfo.sh --strict-build-id -m --run-dwz --dwz-low-mem-die-limit 10000000 --dwz-max-die-limit 110000000 /root/rpmbuild/BUILD/drbd-8.4.4
/usr/lib/rpm/sepdebugcrcfix: Updated 0 CRC32s, 0 CRC32s did match.
+ '[' '%{buildarch}' = noarch ']'
+ QA_CHECK_RPATHS=1
+ case "${QA_CHECK_RPATHS:-}" in
+ /usr/lib/rpm/check-rpaths
+ /usr/lib/rpm/check-buildroot
+ /usr/lib/rpm/redhat/brp-compress
+ /usr/lib/rpm/redhat/brp-strip-static-archive /usr/bin/strip
+ /usr/lib/rpm/brp-python-bytecompile /usr/bin/python 1
+ /usr/lib/rpm/redhat/brp-python-hardlink
+ /usr/lib/rpm/redhat/brp-java-repack-jars
Processing files: kmod-drbd-8.4.4_3.10.0_54.0.1-4.el7.x86_64
Executing(%doc): /bin/sh -e /var/tmp/rpm-tmp.crdtfP
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ DOCDIR=/root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/usr/share/doc/kmod-drbd-8.4.4_3.10.0_54.0.1
+ export DOCDIR
+ /usr/bin/mkdir -p /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/usr/share/doc/kmod-drbd-8.4.4_3.10.0_54.0.1
+ cp -pr COPYING /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/usr/share/doc/kmod-drbd-8.4.4_3.10.0_54.0.1
+ cp -pr ChangeLog /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/usr/share/doc/kmod-drbd-8.4.4_3.10.0_54.0.1
+ cp -pr obj/k-config-3.10.0-54.0.1.el7.x86_64.gz /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64/usr/share/doc/kmod-drbd-8.4.4_3.10.0_54.0.1
+ exit 0
Finding  Provides: /usr/lib/rpm/redhat/find-provides
Finding  Requires(interp): 
Finding  Requires(rpmlib): 
Finding  Requires(verify): 
Finding  Requires(pre): 
Finding  Requires(post): 
Finding  Requires(preun): 
Finding  Requires(postun): 
Finding  Requires(pretrans): 
Finding  Requires(posttrans): 
Finding  Requires: /usr/lib/rpm/redhat/find-requires
********************************************************************************
*********************** KERNEL ABI COMPATIBILITY WARNING ***********************
********************************************************************************
The kernel ABI reference files (provided by kabi-whitelists) were not found.
No compatibility check was performed. Please install the kABI reference files
and rebuild if you would like to verify compatibility with kernel ABI.
Provides: kernel-modules >= 3.10.0-54.0.1.el7.x86_64 drbd-kmod = 8.4.4-4.el7 kmod-drbd = 8.4.4_3.10.0_54.0.1-4.el7 kmod-drbd(x86-64) = 8.4.4_3.10.0_54.0.1-4.el7 modalias(block-major-147-*) = 8.4.4 ksym(drbd_conn_str) = 0x7730f22d ksym(drbd_disk_str) = 0xaf27bebf ksym(drbd_role_str) = 0x35131b36 ksym(drbd_set_st_err_str) = 0x127a5901
Requires(interp): /bin/sh /bin/sh /bin/sh
Requires(rpmlib): rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 rpmlib(CompressedFileNames) <= 3.0.4-1
Requires(post): /usr/sbin/depmod /bin/sh
Requires(preun): /bin/sh
Requires(postun): /usr/sbin/depmod /bin/sh
Requires: kernel(PDE_DATA) = 0xeb98c783 kernel(__alloc_skb) = 0x0ed920b0 kernel(__alloc_workqueue_key) = 0x43a53735 kernel(__bitmap_empty) = 0x6d27ef64 kernel(__bitmap_equal) = 0xc256e762 kernel(__bitmap_parse) = 0x4df119fa kernel(__dynamic_dev_dbg) = 0xc8592066 kernel(__fentry__) = 0xbdfb6dbb kernel(__free_pages) = 0x938f722e kernel(__genl_register_family_with_ops) = 0x943a9de2 kernel(__get_free_pages) = 0x93fca811 kernel(__init_waitqueue_head) = 0xf432dd3d kernel(__kmalloc) = 0xd2b09ce5 kernel(__list_add) = 0x0343a1a8 kernel(__list_add_rcu) = 0x1e579dc5 kernel(__list_del_entry) = 0x65e75cb6 kernel(__mutex_init) = 0x767218bd kernel(__per_cpu_offset) = 0x0d94cc09 kernel(__stack_chk_fail) = 0xf0fdf6cb kernel(__sw_hweight64) = 0x9f46ced8 kernel(__vmalloc) = 0xa9bd2676 kernel(__wake_up) = 0xcf21d241 kernel(_cond_resched) = 0xa1c76e0a kernel(_raw_read_lock) = 0x9b0c8220 kernel(_raw_spin_lock) = 0xd52bf1ce kernel(_raw_spin_lock_irq) = 0x43261dca kernel(_raw_spin_lock_irqsave) = 0x9327f5ce kernel(_raw_spin_unlock) = 0xda3e43d1 kernel(_raw_spin_unlock_irqrestore) = 0x08f64aa4 kernel(_raw_write_lock) = 0x13a1a61a kernel(_raw_write_lock_bh) = 0xd5dac574 kernel(_raw_write_lock_irq) = 0xa3a9637d kernel(_raw_write_unlock_bh) = 0x5bd6c1ee kernel(add_disk) = 0x732909d4 kernel(add_timer) = 0xbe2c0274 kernel(alloc_disk) = 0x8fd45429 kernel(alloc_pages_current) = 0x6eb3fdb9 kernel(autoremove_wake_function) = 0xc8b57c27 kernel(bdevname) = 0x3a43bc26 kernel(bdget) = 0x40a4d614 kernel(bdput) = 0x083a0328 kernel(bio_add_page) = 0x90e41399 kernel(bio_alloc_bioset) = 0xe0e3acba kernel(bio_clone_bioset) = 0x512934d9 kernel(bio_endio) = 0x5e2b4f24 kernel(bio_put) = 0x27acf9f3 kernel(bioset_create) = 0x5e1db8ce kernel(bioset_free) = 0x477aaccf kernel(blk_alloc_queue) = 0xec4fc4af kernel(blk_cleanup_queue) = 0xad42ba8f kernel(blk_queue_bounce_limit) = 0x37ee4812 kernel(blk_queue_flush) = 0x4680e87d kernel(blk_queue_logical_block_size) = 0x4ad272c8 kernel(blk_queue_make_request) = 0xa82be2cc kernel(blk_queue_max_hw_sectors) = 0x8436ff57 kernel(blk_queue_max_segments) = 0x000c3a81 kernel(blk_queue_merge_bvec) = 0xa487aed4 kernel(blk_queue_segment_boundary) = 0x13fa9b97 kernel(blk_queue_stack_limits) = 0x9f88553f kernel(blk_set_stacking_limits) = 0x15f571ec kernel(blkdev_get_by_path) = 0x66bb5a16 kernel(blkdev_issue_flush) = 0x8035fc36 kernel(blkdev_issue_zeroout) = 0x9f1bef73 kernel(blkdev_put) = 0x7410bfe8 kernel(call_usermodehelper) = 0xc5fdef94 kernel(capable) = 0xc6cbbc89 kernel(complete) = 0x4b06d2e7 kernel(complete_all) = 0x40256835 kernel(copy_page) = 0x33b84f74 kernel(cpu_number) = 0x54efb5d6 kernel(cpu_online_mask) = 0x930484aa kernel(cpu_possible_mask) = 0xc311ec22 kernel(crc32c) = 0x27000b29 kernel(crypto_alloc_base) = 0x58ed341c kernel(crypto_destroy_tfm) = 0x6c4b44c7 kernel(current_task) = 0x82a4b4d4 kernel(del_gendisk) = 0x11566f7a kernel(del_timer) = 0xc996d097 kernel(del_timer_sync) = 0xd5f2172f kernel(destroy_workqueue) = 0x8c03d20c kernel(dev_printk) = 0x5013490a kernel(dump_stack) = 0x6b2dc060 kernel(find_next_bit) = 0xc0a3d105 kernel(find_next_zero_bit) = 0x479c3c86 kernel(finish_wait) = 0xfa66f77c kernel(flush_signals) = 0xa39bd146 kernel(force_sig) = 0xa583ab79 kernel(free_cpumask_var) = 0xdbc34085 kernel(free_pages) = 0x4302d0eb kernel(fs_bio_set) = 0x1339346b kernel(generic_make_request) = 0xfccf196d kernel(genl_lock) = 0x2b9da7a4 kernel(genl_register_mc_group) = 0x61d7521d kernel(genl_unlock) = 0x2d140a58 kernel(genl_unregister_family) = 0x2eba7932 kernel(genlmsg_put) = 0xca29382a kernel(get_random_bytes) = 0x79aa04a2 kernel(idr_alloc) = 0x4fd5cfb9 kernel(idr_destroy) = 0x45c92723 kernel(idr_find_slowpath) = 0x6f36c782 kernel(idr_for_each) = 0xf5ce272b kernel(idr_get_next) = 0x4f94f1ba kernel(idr_init) = 0xb1b42470 kernel(idr_remove) = 0xcaef1b77 kernel(init_net) = 0x8855bf9f kernel(init_timer_key) = 0x0593a99b kernel(jiffies) = 0x7d11c268 kernel(kernel_accept) = 0x702e9286 kernel(kernel_sendmsg) = 0xc507efe2 kernel(kernel_sock_shutdown) = 0xafdf3542 kernel(kernel_stack) = 0x4c4fef19 kernel(kfree) = 0x037a0cba kernel(kfree_skb) = 0xeafcbd30 kernel(kmalloc_caches) = 0x81358b9c kernel(kmem_cache_alloc) = 0x6e637f3f kernel(kmem_cache_alloc_trace) = 0xc59770f2 kernel(kmem_cache_create) = 0x617aa944 kernel(kmem_cache_destroy) = 0x670ae049 kernel(kmem_cache_free) = 0xce7e7509 kernel(kobject_del) = 0x9ded188e kernel(kobject_get) = 0x75b1f1fb kernel(kobject_init_and_add) = 0xa2118a69 kernel(kobject_put) = 0x54554948 kernel(kobject_uevent) = 0x20f749f4 kernel(kstrdup) = 0xc499ae1e kernel(kthread_create_on_node) = 0xf72f3a76 kernel(list_del) = 0x0521445b kernel(memcmp) = 0x449ad0a7 kernel(memcpy) = 0x69acdf38 kernel(mempool_alloc) = 0xe9dff136 kernel(mempool_alloc_pages) = 0x53326531 kernel(mempool_alloc_slab) = 0x183fa88b kernel(mempool_create) = 0x3f71faa1 kernel(mempool_destroy) = 0xefba93e1 kernel(mempool_free) = 0x4aad52d7 kernel(mempool_free_pages) = 0xd985dc99 kernel(mempool_free_slab) = 0x8a99a016 kernel(memset) = 0xfb578fc5 kernel(mod_timer) = 0x8834396c kernel(module_layout) = 0xab4e56e5 kernel(module_put) = 0x3076711d kernel(mutex_lock) = 0xc3499b32 kernel(mutex_trylock) = 0x9ddc66b1 kernel(mutex_unlock) = 0x87c4a045 kernel(netlink_broadcast) = 0xdec63568 kernel(netlink_unicast) = 0xfa123fb8 kernel(nla_find) = 0xcd279169 kernel(nla_memcpy) = 0xf1db1704 kernel(nla_parse) = 0x4f391d0e kernel(nla_put) = 0x64a656ef kernel(nla_put_nohdr) = 0x30ddd583 kernel(nla_strlcpy) = 0x6b640864 kernel(nr_cpu_ids) = 0xfe7c4287 kernel(panic) = 0x7c1372e8 kernel(param_ops_bool) = 0x1976aa06 kernel(param_ops_int) = 0x15692c87 kernel(param_ops_string) = 0x4d405db8 kernel(param_ops_uint) = 0x6d044c26 kernel(paravirt_ticketlocks_enabled) = 0xd3719d59 kernel(part_round_stats) = 0xc2a4e8d7 kernel(phys_base) = 0x4c9d28b0 kernel(prandom_u32) = 0xa735db59 kernel(prepare_to_wait) = 0x5c8b5ce8 kernel(printk) = 0x27e1a049 kernel(proc_create_data) = 0x26fcb898 kernel(put_disk) = 0x0f94c605 kernel(put_page) = 0x326ca387 kernel(pv_irq_ops) = 0x78764f4e kernel(pv_lock_ops) = 0x784213a6 kernel(queue_work_on) = 0x2e0d2f7f kernel(rb_erase) = 0x4d9b652b kernel(rb_insert_color) = 0xa5526619 kernel(rb_next) = 0xca9360b5 kernel(register_blkdev) = 0x71a50dbc kernel(register_reboot_notifier) = 0x3517383e kernel(remove_proc_entry) = 0xdd986460 kernel(sched_setscheduler) = 0x24b3f152 kernel(schedule) = 0x01000e51 kernel(schedule_timeout) = 0xd62c833f kernel(schedule_timeout_interruptible) = 0x09c55cec kernel(schedule_timeout_uninterruptible) = 0xd0ee38b8 kernel(seq_lseek) = 0xe86b2356 kernel(seq_printf) = 0x074df1d4 kernel(seq_read) = 0x432ee59d kernel(set_cpus_allowed_ptr) = 0x64f23a12 kernel(set_disk_ro) = 0x2ae38025 kernel(sg_init_table) = 0xc897c382 kernel(single_open) = 0x88721dc0 kernel(single_release) = 0xd6c7e61f kernel(skb_trim) = 0x9a277fbe kernel(snprintf) = 0x28318305 kernel(sock_create_kern) = 0xf1380dc2 kernel(sock_recvmsg) = 0x46a87c0e kernel(sock_release) = 0x19cac26a kernel(sprintf) = 0x91715312 kernel(strchr) = 0x349cba85 kernel(strcmp) = 0xe2d5255a kernel(strcpy) = 0xe914e41e kernel(strlen) = 0x754d539c kernel(submit_bio) = 0x51fbafea kernel(synchronize_sched) = 0x0c2cdbf1 kernel(try_module_get) = 0x3ba9cdab kernel(unregister_blkdev) = 0xb5a459dc kernel(unregister_reboot_notifier) = 0xac1a55be kernel(vfree) = 0x999e8297 kernel(wait_for_completion) = 0x6d0aba34 kernel(wait_for_completion_interruptible_timeout) = 0x263122f8 kernel(wake_up_process) = 0x3eb4099d kernel(warn_slowpath_null) = 0x16305289 kernel(zalloc_cpumask_var) = 0x3e092b88
Processing files: drbd-kernel-debuginfo-8.4.4-4.el7.x86_64
Provides: drbd-kernel-debuginfo = 8.4.4-4.el7 drbd-kernel-debuginfo(x86-64) = 8.4.4-4.el7
Requires(rpmlib): rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 rpmlib(CompressedFileNames) <= 3.0.4-1
Checking for unpackaged file(s): /usr/lib/rpm/check-files /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
Wrote: /root/rpmbuild/RPMS/x86_64/kmod-drbd-8.4.4_3.10.0_54.0.1-4.el7.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/drbd-kernel-debuginfo-8.4.4-4.el7.x86_64.rpm
Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.Lxywid
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd drbd-8.4.4
+ rm -rf /root/rpmbuild/BUILDROOT/drbd-kernel-8.4.4-4.el7.x86_64
+ exit 0
You have now:
/root/rpmbuild/RPMS/x86_64/drbd-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-utils-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-xen-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-udev-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-pacemaker-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-heartbeat-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-bash-completion-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-debuginfo-8.4.4-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/kmod-drbd-8.4.4_3.10.0_54.0.1-4.el7.x86_64.rpm
/root/rpmbuild/RPMS/x86_64/drbd-kernel-debuginfo-8.4.4-4.el7.x86_64.rpmConfigure DRBD
Configure global-common.conf;
vim /etc/drbd.d/global_common.conf# These are options to set for the DRBD daemon sets the default values for
# resources.
global {
	# This tells DRBD that you allow it to report this installation to 
	# LINBIT for statistical purposes. If you have privacy concerns, set
	# this to 'no'. The default is 'ask' which will prompt you each time
	# DRBD is updated. Set to 'yes' to allow it without being prompted.
	usage-count no;
	# minor-count dialog-refresh disable-ip-verification
}
common {
	handlers {
		pri-on-incon-degr "/usr/lib/drbd/notify-pri-on-incon-degr.sh; /usr/lib/drbd/notify-emergency-reboot.sh; echo b > /proc/sysrq-trigger ; reboot -f";
		pri-lost-after-sb "/usr/lib/drbd/notify-pri-lost-after-sb.sh; /usr/lib/drbd/notify-emergency-reboot.sh; echo b > /proc/sysrq-trigger ; reboot -f";
		local-io-error "/usr/lib/drbd/notify-io-error.sh; /usr/lib/drbd/notify-emergency-shutdown.sh; echo o > /proc/sysrq-trigger ; halt -f";
		# split-brain "/usr/lib/drbd/notify-split-brain.sh root";
		# out-of-sync "/usr/lib/drbd/notify-out-of-sync.sh root";
		# before-resync-target "/usr/lib/drbd/snapshot-resync-target-lvm.sh -p 15 -- -c 16k";
		# after-resync-target /usr/lib/drbd/unsnapshot-resync-target-lvm.sh;
		
		# Hook into Pacemaker's fencing.
		fence-peer "/usr/lib/drbd/crm-fence-peer.sh";
	}
	startup {
		# wfc-timeout degr-wfc-timeout outdated-wfc-timeout wait-after-sb
	}
	options {
		# cpu-mask on-no-data-accessible
	}
	disk {
		# size max-bio-bvecs on-io-error fencing disk-barrier disk-flushes
		# disk-drain md-flushes resync-rate resync-after al-extents
                # c-plan-ahead c-delay-target c-fill-target c-max-rate
                # c-min-rate disk-timeout
                fencing resource-and-stonith;
	}
	net {
		# protocol timeout max-epoch-size max-buffers unplug-watermark
		# connect-int ping-int sndbuf-size rcvbuf-size ko-count
		# allow-two-primaries cram-hmac-alg shared-secret after-sb-0pri
		# after-sb-1pri after-sb-2pri always-asbp rr-conflict
		# ping-timeout data-integrity-alg tcp-cork on-congestion
		# congestion-fill congestion-extents csums-alg verify-alg
		# use-rle
		# Protocol "C" tells DRBD not to tell the operating system that
		# the write is complete until the data has reach persistent
		# storage on both nodes. This is the slowest option, but it is
		# also the only one that guarantees consistency between the
		# nodes. It is also required for dual-primary, which we will 
		# be using.
		protocol C;
		# Tell DRBD to allow dual-primary. This is needed to enable 
		# live-migration of our servers.
		allow-two-primaries yes;
		# This tells DRBD what to do in the case of a split-brain when
		# neither node was primary, when one node was primary and when
		# both nodes are primary. In our case, we'll be running
		# dual-primary, so we can not safely recover automatically. The
		# only safe option is for the nodes to disconnect from one
		# another and let a human decide which node to invalidate. Of 
		after-sb-0pri discard-zero-changes;
		after-sb-1pri discard-secondary;
		after-sb-2pri disconnect;
	}
}And now configure the first resource;
vim /etc/drbd.d/r0.res# This is the first DRBD resource. If will store the shared file systems and
# the servers designed to run on node 01.
resource r0 {
	# These options here are common to both nodes. If for some reason you
	# need to set unique values per node, you can move these to the
	# 'on <name> { ... }' section.
	
	# This sets the device name of this DRBD resouce.
	device /dev/drbd0;
	# This tells DRBD what the backing device is for this resource.
	disk /dev/sda5;
	# This controls the location of the metadata. When "internal" is used,
	# as we use here, a little space at the end of the backing devices is
	# set aside (roughly 32 MB per 1 TB of raw storage). External metadata
	# can be used to put the metadata on another partition when converting
	# existing file systems to be DRBD backed, when there is no extra space
	# available for the metadata.
	meta-disk internal;
	# NOTE: this is not required or even recommended with pacemaker. remove
	# 	this options as soon as pacemaker is setup.
	startup {
		# This tells DRBD to promote both nodes to 'primary' when this
		# resource starts. However, we will let pacemaker control this
		# so we comment it out, which tells DRBD to leave both nodes
		# as secondary when drbd starts.
		#become-primary-on both;
	}
	# NOTE: Later, make it an option in the dashboard to trigger a manual
	# 	verify and/or schedule periodic automatic runs
	net {
		# TODO: Test performance differences between sha1 and md5
		# This tells DRBD how to do a block-by-block verification of
		# the data stored on the backing devices. Any verification
		# failures will result in the effected block being marked
		# out-of-sync.
		verify-alg md5;
		# TODO: Test the performance hit of this being enabled.
		# This tells DRBD to generate a checksum for each transmitted
		# packet. If the data received data doesn't generate the same
		# sum, a retransmit request is generated. This protects against
		# otherwise-undetected errors in transmission, like 
		# bit-flipping. See:
		# http://www.drbd.org/users-guide/s-integrity-check.html
		data-integrity-alg md5;
	}
	# WARNING: Confirm that these are safe when the controller's BBU is
	#          depleted/failed and the controller enters write-through 
	#          mode.
	disk {
		# TODO: Test the real-world performance differences gained with
		#       these options.
		# This tells DRBD not to bypass the write-back caching on the
		# RAID controller. Normally, DRBD forces the data to be flushed
		# to disk, rather than allowing the write-back cachine to 
		# handle it. Normally this is dangerous, but with BBU-backed
		# caching, it is safe. The first option disables disk flushing
		# and the second disabled metadata flushes.
		disk-flushes no;
		md-flushes no;
	}
	# This sets up the resource on node 01. The name used below must be the
	# named returned by "uname -n".
	on an-c03n01.alteeve.ca {
		# This is the address and port to use for DRBD traffic on this
		# node. Multiple resources can use the same IP but the ports
		# must differ. By convention, the first resource uses 7788, the
		# second uses 7789 and so on, incrementing by one for each
		# additional resource. 
		address 10.10.30.1:7788;
	}
	on an-c03n02.alteeve.ca {
		address 10.10.30.2:7788;
	}
}Disable drbd from starting on boot.
systemctl disable drbd.servicedrbd.service is not a native service, redirecting to /sbin/chkconfig.
Executing /sbin/chkconfig drbd offLoad the config;
modprobe drbdNow check the config;
drbdadm dump  --==  Thank you for participating in the global usage survey  ==--
The server's response is:
you are the 69th user to install this version
/etc/drbd.d/r0.res:3: in resource r0:
become-primary-on is set to both, but allow-two-primaries is not set.Ignore that error. It has been reported and does not effect operation.
Create the metadisk;
drbdadm create-md r0Writing meta data...
initializing activity log
NOT initializing bitmap
New drbd meta data block successfully created.
successStart the DRBD resource on both nodes;
drbdadm up r0Once /proc/drbd shows both nodes connected, force one to primary and it will sync over the second.
drbdadm primary --force r0You should see the resource syncing now. Push both nodes to primary;
drbdadm primary r0DLM, Clustered LVM and GFS2
yum -y install dlm dlm-lib lvm2-cluster gfs2-utilsDisable dlm and clvmd from starting on boot.
systemctl disable clvmd.serviceclvmd.service is not a native service, redirecting to /sbin/chkconfig.
Executing /sbin/chkconfig clvmd offsystemctl disable dlm.servicerm '/etc/systemd/system/multi-user.target.wants/dlm.service'Edit lvm.conf;
diff -u /etc/lvm/lvm.conf.orig /etc/lvm/lvm.conf--- /etc/lvm/lvm.conf.orig	2013-07-08 16:38:45.603780083 -0500
+++ /etc/lvm/lvm.conf	2013-07-08 16:47:34.434591848 -0500
@@ -65,7 +65,7 @@
 
 
     # By default we accept every block device:
-    filter = [ "a/.*/" ]
+    filter = [ "a|/dev/drbd*|", "r/.*/" ]
 
     # Exclude the cdrom drive
     # filter = [ "r|/dev/cdrom|" ]
@@ -405,7 +405,7 @@
     # Type 3 uses built-in clustered locking.
     # Type 4 uses read-only locking which forbids any operations that might 
     # change metadata.
-    locking_type = 1
+    locking_type = 3
 
     # Set to 0 to fail when a lock request cannot be satisfied immediately.
     wait_for_locks = 1
@@ -421,7 +421,7 @@
     # to 1 an attempt will be made to use local file-based locking (type 1).
     # If this succeeds, only commands against local volume groups will proceed.
     # Volume Groups marked as clustered will be ignored.
-    fallback_to_local_locking = 1
+    fallback_to_local_locking = 0
 
     # Local non-LV directory that holds file-based locks while commands are
     # in progress.  A directory like /tmp that may get wiped on reboot is OK.
@@ -508,7 +508,7 @@
     #
     # If lvmetad has been running while use_lvmetad was 0, it MUST be stopped
     # before changing use_lvmetad to 1 and started again afterwards.
-    use_lvmetad = 1
+    use_lvmetad = 0
 
     # Full path of the utility called to check that a thin metadata device
     # is in a state that allows it to be used.
Disable lvmetad as it's not cluster-aware.
systemctl disable lvm2-lvmetad.service
systemctl disable lvm2-lvmetad.socket
systemctl stop lvm2-lvmetad.service|  | Note: This will be moved to pacemaker | 
Start DLM and clvmd;
systemctl start dlm.service
systemctl start clvmd.serviceCreate the PV, VG and the /shared LV;
pvcreate /dev/drbd0 
vgcreate an-c03n01_vg0 /dev/drbd0
lvcreate -L 40G -n shared an-c03n01_vg0Format the /dev/an-c03n01_vg0/shared;
mkfs.gfs2 -j 2 -p lock_dlm -t an-cluster-03:shared /dev/an-c03n01_vg0/shared/dev/an-c03n01_vg0/shared is a symlink to /dev/dm-0
This will destroy any data on /dev/dm-0.
It appears to contain: data
Are you sure you want to proceed? [y/n]y
Device:                    /dev/an-c03n01_vg0/shared
Blocksize:                 4096
Device Size                40.00 GB (10485760 blocks)
Filesystem Size:           40.00 GB (10485758 blocks)
Journals:                  2
Resource Groups:           160
Locking Protocol:          "lock_dlm"
Lock Table:                "an-cluster-03:shared"
UUID:                      e96dbbec-add4-c291-083b-381a866a773dCreate the mount points and mount the new file system on both nodes;
mkdir /shared
mount /dev/an-c03n01_vg0/shared /shared
Odds and Sods
This is a section for random notes. The stuff here will be integrated into the finished tutorial or removed.
Determine multicast Address
Useful if you need to ensure that your switch has persistent multicast addresses set.
corosync-cmapctl | grep mcastaddrtotem.interface.0.mcastaddr (str) = 239.192.122.199
Notes
Thanks
This list will certainly grow as this tutorial progresses;
- Olivier Allart, RCHE for doing a lot of the heavy lifting on the fencing_topology configuration.
| Any questions, feedback, advice, complaints or meanderings are welcome. | |||
| Alteeve's Niche! | Alteeve Enterprise Support | Community Support | |
| © 2025 Alteeve. Intelligent Availability® is a registered trademark of Alteeve's Niche! Inc. 1997-2025 | |||
| legal stuff: All info is provided "As-Is". Do not use anything here unless you are willing and able to take responsibility for your own actions. | |||