Saturday, 24 January 2015

RHEL 7 -- 2 node GFS2

Scenario

  • RHEL Workstation and Hypervisor
  • RHEL Workstation VM on private NAT network
  • Share an LVM volume between both workstations without using a network file server to slow things down.

Using

Prepare “Resilient Storage” Channel

The “Resilient Storage” channel is only available on the RHEL 7 Server base channel. I’m going to clone the “Resilient Storage” channel on my local Satellite server to the RHEL 7 Workstation base channel so my two workstations have access to the necessary packages. I may not have Red Hat support from this point forward ;-)

Subscribed both RHEL 7 Workstation systems to the cloned rhel-x86_64-server-rs-7 channel.

Install Software on each Node

On each node in the cluster, install the Red Hat High Availability Add-On software packages along with all available fence agents from the High Availability channel:

GFS2

yum install rgmanager lvm2-cluster gfs2-utils

Clustering:

yum install pcs fence-agents-all

Shared Block Device

Create the block device to be shared between both workstations. My case this is the laptop/hypervisor:

# lvcreate -n gfs2_docs -L 50G laptop500

Format the new block device. I am precreating 3 journals as I’m expecting this to be so successful that I will have a third VM using the same share before too long :-D

# mkfs.gfs2 -p lock_dlm -t laptop:docs -j 3 /dev/laptop500/gfs2_docs
/dev/laptop500/gfs2_docs is a symbolic link to /dev/dm-10
This will destroy any data on /dev/dm-10
Are you sure you want to proceed? [y/n]y
Device:                    /dev/laptop500/gfs2_docs
Block size:                4096
Device size:               50.00 GB (13107200 blocks)
Filesystem size:           50.00 GB (13107198 blocks)
Journals:                  3
Resource groups:           200
Locking protocol:          "lock_dlm"
Lock table:                "laptop:docs"
UUID:                      0fb834e7-0f8c-d4b6-f0fb-193b56b8299a

Configure Clustering

Initial Steps for all Nodes

Allow the clustering service to be accessed through the firewall:

# firewall-cmd --permanent --add-service=high-availability
success
# firewall-cmd --add-service=high-availability
success

Set the same password for clustering administration on each node:

# passwd hacluster
Changing password for user hacluster.
New password: 
Retype new password: 
passwd: all authentication tokens updated successfully.

Enable the pcsd daemon:

# 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'

Steps for One Node Only (any node)

Authenticate the hacluster user for each node in the cluster:

# pcs cluster auth reilly.spurrier.net.au rhel7desk.spurrier.net.au
Username: hacluster
Password: 
reilly.spurrier.net.au: Authorized
rhel7desk.spurrier.net.au: Authorized

Create the Cluster:

# pcs cluster setup --start --name laptop reilly.spurrier.net.au rhel7desk.spurrier.net.au
Shutting down pacemaker/corosync services...
Redirecting to /bin/systemctl stop  pacemaker.service
Redirecting to /bin/systemctl stop  corosync.service
Killing any remaining services...
Removing all cluster configuration files...
reilly.spurrier.net.au: Succeeded
reilly.spurrier.net.au: Starting Cluster...
rhel7desk.spurrier.net.au: Succeeded
rhel7desk.spurrier.net.au: Starting Cluster...

Enable Cluster services on all nodes at boot time:

pcs cluster enable --all

Check the Cluster’s status:

# pcs cluster status
Cluster Status:
 Last updated: Fri Feb 13 23:43:11 2015
 Last change: Fri Feb 13 23:40:21 2015 via crmd on reilly.spurrier.net.au
 Stack: corosync
 Current DC: reilly.spurrier.net.au (1) - partition WITHOUT quorum
 Version: 1.1.10-32.el7_0.1-368c726
 2 Nodes configured
 0 Resources configured

PCSD Status:
  reilly.spurrier.net.au: Online
  rhel7desk.spurrier.net.au: Online

Cluster Fencing Configuration

Maybe this is where the whole project comes to an end. Both the GFS2 and the High Availability Add-on - Administration manuals warn that fencing must be enabled. As this is my laptop with a desktop VM forming the cluster I don’t want them fencing each other!

I will ignore Fencing Devices for now and see how bad things get.

Configure Cluster for GFS2

Steps for One Node Only (any node)

Set the global Pacemaker parameter no_quorum_policy to freeze:

# pcs property set no-quorum-policy=freeze

Set up a dlm resource. This is a required dependency for clvmd and GFS2. I have changed the on-fail attribute to restart instead of the recommended value of fence.

# pcs resource create dlm ocf:pacemaker:controld op monitor interval=30s on-fail=restart clone interleave=true ordered=true

Steps for All Nodes

Enable clustered locking:

# /sbin/lvmconf --enable-cluster

Steps for One Node Only (any node)

Set up clvmd as a cluster resource. I have changed the on-fail attribute to restart instead of the recommended value of fence.

# pcs resource create clvmd ocf:heartbeat:clvm op monitor interval=30s on-fail=restart clone interleave=true ordered=true

Set up clvmd and dlm dependency and start up order. clvmd must start after dlm and must run on the same node as dlm:

# pcs constraint order start dlm-clone then clvmd-clone
Adding dlm-clone clvmd-clone (kind: Mandatory) (Options: first-action=start then-action=start)
# pcs constraint colocation add clvmd-clone with dlm-clone

Configure a clusterfs resource. I have changed the on-fail attribute to restart instead of the recommended value of fence.

# pcs resource create clusterfs Filesystem device="/dev/laptop500/gfs2_drew" directory="/home/drew/docs" fstype="gfs2" "options=noatime" op monitor interval=10s on-fail=restart clone interleave=true

Verify that GFS2 is mounted as expected:

mount | grep docs

Set up GFS2 and clvmd dependency and startup order.

# pcs constraint order start clvmd-clone then clusterfs-clone
# pcs constraint colocation add clusterfs-clone with clvmd-clone

not required

Mounting GFS2 File System

# mount -t gfs2 -o noatime /dev/laptop500/gfs2_docs /mnt/docs

Written with StackEdit.

Sunday, 18 January 2015

IPA Cluster with Windows Server 2012 Trust

Scenario

  • IPA cluster consists of 2 RHEL 6.6 servers
  • Windows Server 2012 will be used for the Active Directory component
  • IPA will manage a sub domain of the Active Directory domain (ipa.demo.net)
  • IPA realm is (IPA)
  • Active Directory domain is (demo.net)
  • Active Directory realm is (WINDOWS)
  • No existing DNS service is pre-existing

Using

  • RHEL 6.6
  • ipa-server 3.0.0

Build Master IPA Server

Fix the servers network identity

  • /etc/sysconfig/network
  • /etc/sysconfig/network-scripts/ifcfg-eth0
  • /etc/resolv.conf (DNS to resolve Red Hat Satellite service)
  • /etc/ntp.conf
  • /etc/hosts (no existing DNS so add an entry for this host)
    echo '192.168.1.53 ipa1.ipa.demo.net ipa1' >> /etc/hosts

Enable NTP

 [root@ipa1 ~]# chkconfig ntpdate on
 [root@ipa1 ~]# chkconfig ntpd on

Update software

 [root@ipa1 ~]# yum update

Reboot

 [root@ipa1 ~]# init 6

Log back in and make sure it is as you expect it to be:

[root@ipa1 ~]# hostname
[root@ipa1 ~]# ntpq -c lpeers
[root@ipa1 ~]# route -n

Install IPA

[root@ipa1 ~]# yum install ipa-server bind bind-dyndb-ldap
[root@ipa1 ~]# ipa-server-install --hostname=ipa1.ipa.demo.net -n ipa.demo.net -r IPA --setup-dns
The log file for this installation can be found in /var/log/ipaserver-install.log
==============================================================================
    This program will set up the IPA Server.

This includes:
  * Configure a stand-alone CA (dogtag) for certificate management
  * Configure the Network Time Daemon (ntpd)
  * Create and configure an instance of Directory Server
  * Create and configure a Kerberos Key Distribution Center (KDC)
  * Configure Apache (httpd)
  * Configure DNS (bind)

To accept the default shown in brackets, press the Enter key.

Existing BIND configuration detected, overwrite? [no]: yes
Enter the fully qualified domain name of the computer
on which you're setting up server software. Using the form
<hostname>.<domainname>
Example: master.example.com.


Server host name [ipa1.ipa.demo.net]: 

Warning: skipping DNS resolution of host ipa1.ipa.demo.net
Certain directory server operations require an administrative user.
This user is referred to as the Directory Manager and has full access
to the Directory for system management tasks and will be added to the
instance of directory server created for IPA.
The password must be at least 8 characters long.

Directory Manager password: 
Password (confirm): 

The IPA server requires an administrative user, named 'admin'.
This user is a regular system account used for IPA server administration.

IPA admin password: 
Password (confirm): 

Do you want to configure DNS forwarders? [yes]: 
Enter the IP address of DNS forwarder to use, or press Enter to finish.
Enter IP address for a DNS forwarder: 192.168.1.3
DNS forwarder 192.168.1.3 added
Enter IP address for a DNS forwarder: 
Do you want to configure the reverse zone? [yes]: 
Please specify the reverse zone name [1.168.192.in-addr.arpa.]: 
Using reverse zone 1.168.192.in-addr.arpa.

The IPA Master Server will be configured with:
Hostname:      ipa1.ipa.demo.net
IP address:    192.168.1.53
Domain name:   ipa.demo.net
Realm name:    IPA

BIND DNS server will be configured to serve IPA domain with:
Forwarders:    192.168.1.3
Reverse zone:  1.168.192.in-addr.arpa.

Continue to configure the system with these values? [no]: yes

The following operations may take some minutes to complete.
Please wait until the prompt is returned.

Configuring NTP daemon (ntpd)
  [1/4]: stopping ntpd
  [2/4]: writing configuration
  [3/4]: configuring ntpd to start on boot
  [4/4]: starting ntpd
Done configuring NTP daemon (ntpd).
Configuring directory server for the CA (pkids): Estimated time 30 seconds
  [1/3]: creating directory server user
  [2/3]: creating directory server instance
  [3/3]: restarting directory server
Done configuring directory server for the CA (pkids).
Configuring certificate server (pki-cad): Estimated time 3 minutes 30 seconds
  [1/21]: creating certificate server user
  [2/21]: creating pki-ca instance
  [3/21]: configuring certificate server instance
  [4/21]: disabling nonces
  [5/21]: creating CA agent PKCS#12 file in /root
  [6/21]: creating RA agent certificate database
  [7/21]: importing CA chain to RA certificate database
  [8/21]: fixing RA database permissions
  [9/21]: setting up signing cert profile
  [10/21]: set up CRL publishing
  [11/21]: set certificate subject base
  [12/21]: enabling Subject Key Identifier
  [13/21]: setting audit signing renewal to 2 years
  [14/21]: configuring certificate server to start on boot
  [15/21]: restarting certificate server
  [16/21]: requesting RA certificate from CA
  [17/21]: issuing RA agent certificate
  [18/21]: adding RA agent as a trusted user
  [19/21]: configure certificate renewals
  [20/21]: configure Server-Cert certificate renewal
  [21/21]: Configure HTTP to proxy connections
Done configuring certificate server (pki-cad).
Configuring directory server (dirsrv): Estimated time 1 minute
  [1/38]: creating directory server user
  [2/38]: creating directory server instance
  [3/38]: adding default schema
  [4/38]: enabling memberof plugin
  [5/38]: enabling winsync plugin
  [6/38]: configuring replication version plugin
  [7/38]: enabling IPA enrollment plugin
  [8/38]: enabling ldapi
  [9/38]: disabling betxn plugins
  [10/38]: configuring uniqueness plugin
  [11/38]: configuring uuid plugin
  [12/38]: configuring modrdn plugin
  [13/38]: enabling entryUSN plugin
  [14/38]: configuring lockout plugin
  [15/38]: creating indices
  [16/38]: enabling referential integrity plugin
  [17/38]: configuring ssl for ds instance
  [18/38]: configuring certmap.conf
  [19/38]: configure autobind for root
  [20/38]: configure new location for managed entries
  [21/38]: restarting directory server
  [22/38]: adding default layout
  [23/38]: adding delegation layout
  [24/38]: adding replication acis
  [25/38]: creating container for managed entries
  [26/38]: configuring user private groups
  [27/38]: configuring netgroups from hostgroups
  [28/38]: creating default Sudo bind user
  [29/38]: creating default Auto Member layout
  [30/38]: adding range check plugin
  [31/38]: creating default HBAC rule allow_all
  [32/38]: Upload CA cert to the directory
  [33/38]: initializing group membership
  [34/38]: adding master entry
  [35/38]: configuring Posix uid/gid generation
  [36/38]: enabling compatibility plugin
  [37/38]: tuning directory server
  [38/38]: configuring directory to start on boot
Done configuring directory server (dirsrv).
Configuring Kerberos KDC (krb5kdc): Estimated time 30 seconds
  [1/10]: adding sasl mappings to the directory
  [2/10]: adding kerberos container to the directory
  [3/10]: configuring KDC
  [4/10]: initialize kerberos container
  [5/10]: adding default ACIs
  [6/10]: creating a keytab for the directory
  [7/10]: creating a keytab for the machine
  [8/10]: adding the password extension to the directory
  [9/10]: starting the KDC
  [10/10]: configuring KDC to start on boot
Done configuring Kerberos KDC (krb5kdc).
Configuring kadmin
  [1/2]: starting kadmin 
  [2/2]: configuring kadmin to start on boot
Done configuring kadmin.
Configuring ipa_memcached
  [1/2]: starting ipa_memcached 
  [2/2]: configuring ipa_memcached to start on boot
Done configuring ipa_memcached.
Configuring the web interface (httpd): Estimated time 1 minute
  [1/13]: setting mod_nss port to 443
  [2/13]: setting mod_nss password file
  [3/13]: enabling mod_nss renegotiate
  [4/13]: adding URL rewriting rules
  [5/13]: configuring httpd
  [6/13]: setting up ssl
  [7/13]: setting up browser autoconfig
  [8/13]: publish CA cert
  [9/13]: creating a keytab for httpd
  [10/13]: clean up any existing httpd ccache
  [11/13]: configuring SELinux for httpd
  [12/13]: restarting httpd
  [13/13]: configuring httpd to start on boot
Done configuring the web interface (httpd).
Applying LDAP updates
Restarting the directory server
Restarting the KDC
Configuring DNS (named)
  [1/9]: adding DNS container
  [2/9]: setting up our zone
  [3/9]: setting up reverse zone
  [4/9]: setting up our own record
  [5/9]: setting up kerberos principal
  [6/9]: setting up named.conf
  [7/9]: restarting named
  [8/9]: configuring named to start on boot
  [9/9]: changing resolv.conf to point to ourselves
Done configuring DNS (named).

Global DNS configuration in LDAP server is empty
You can use 'dnsconfig-mod' command to set global DNS options that
would override settings in local named.conf files

Restarting the web server
==============================================================================
Setup complete

Next steps:
        1. You must make sure these network ports are open:
                TCP Ports:
                  * 80, 443: HTTP/HTTPS
                  * 389, 636: LDAP/LDAPS
                  * 88, 464: kerberos
                  * 53: bind
                UDP Ports:
                  * 88, 464: kerberos
                  * 53: bind
                  * 123: ntp

        2. You can now obtain a kerberos ticket using the command: 'kinit admin'
           This ticket will allow you to use the IPA tools (e.g., ipa user-add)
           and the web user interface.

Be sure to back up the CA certificate stored in /root/cacert.p12
This file is required to create replicas. The password for this
file is the Directory Manager password

Login and Test IPA Master

Ensure your web browser can resolve the fully-qualified host name of the ipa1 server. Even if this means adding an entry to the hosts file.

Point a web browser to:

https://ipa1.ipa.demo.net
Username:  admin
Password:  <as typed during installation>

Build Replica IPA Server

On the Master IPA Server

Prepare the initialisation file for the Replica:

[root@ipa1 ~]# ipa-replica-prepare ipa2.ipa.demo.net --ip-address 192.168.122.54
Directory Manager (existing master) password: 

Preparing replica for ipa2.ipa.demo.net from ipa1.ipa.demo.net
Creating SSL certificate for the Directory Server
Creating SSL certificate for the dogtag Directory Server
Creating SSL certificate for the Web Server
Exporting RA certificate
Copying additional files
Finalizing configuration
Packaging replica information into /var/lib/ipa/replica-info-ipa2.ipa.demo.net.gpg
Adding DNS records for ipa2.ipa.demo.net
Using reverse zone 122.168.192.in-addr.arpa.

Written with StackEdit.