Thanks for the links, I will add them to my reading list. Absolutely would read the docs before deploying ovirt in production and definitely would not use this storage configuration, this is purely to keep from wasting electricity.

Chris.

On 2017-02-11 19:18, Doug Ingham wrote:

On 11 February 2017 at 15:39, Bartosiak-Jentys, Chris <chris.bartosiak-jen...@certico.co.uk> wrote:

Thank you for your reply Doug,

I didn't use localhost as I was preparing to follow instructions (blog post: http://community.redhat.com/blog/2014/11/up-and-running-with-ovirt-3-5-part-two/) for setting up CTDB and had already created hostnames for the floating IP when I decided to ditch that and go with the hosts file hack. I already had the volumes mounted on those hostnames but you are absolutely right, simply using localhost would be the best option.

oVirt 3.5? 2014? That's oooold. Both oVirt & Gluster have moved on a lot since then. I would strongly recommend studying Gluster's documentation before implementing it in production. It's not complicated, but you have to have a good understanding of what you're doing & why if you want to protect the integrity of your data & avoid waking up one day to find everything in meltdown.

https://gluster.readthedocs.io/en/latest/

Red Hat's portal is also very good & full of detailed tips for tuning your setup, however their "stable" versions (which they have to support) are of course much older than the project's own latest stable, so keep this in mind when considering their advice.

https://access.redhat.com/documentation/en/red-hat-storage/

Likewise with their oVirt documentation, although their supported oVirt versions are much closer to the current stable release. It also features a lot of very good advice for configuring & tuning an oVirt (RHEV) & GlusterFS (RHGS) hyperconverged setup.

https://access.redhat.com/documentation/en/red-hat-virtualization/

For any other Gluster specific questions, you can usually get good & timely responses on their mailing list & IRC channel.

Thank you for your suggested outline of how to power up/down the cluster, I hadn't considered the fact that turning on two out of date nodes would clobber data on the new node. This is something I will need to be very careful to avoid. The setup is mostly for lab work so not really mission critical but I do run a few VM's (freeIPA, GitLab and pfSense) that I'd like to keep up 24/7. I make regular backups (outside of ovirt) of those just in case.

Thanks, I will do some reading on how gluster handles quorum and heal operations but your procedure sounds like a sensible way to operate this cluster.

Regards,

Chris.

On 2017-02-11 18:08, Doug Ingham wrote:

On 11 February 2017 at 13:32, Bartosiak-Jentys, Chris <chris.bartosiak-jen...@certico.co.uk> wrote:
Hello list,

Just wanted to get your opinion on my ovirt home lab setup. While this is not a production setup I would like it to run relatively reliably so please tell me if the following storage configuration is likely to result in corruption or just bat s**t insane.

I have a 3 node hosted engine setup, VM data store and engine data store are both replica 3 gluster volumes (one brick on each host). I do not want to run all 3 hosts 24/7 due to electricity costs, I only power up the larger hosts (2 Dell R710's) when I need additional resources for VM's.

I read about using CTDB and floating/virtual IP's to allow the storage mount point to transition between available hosts but after some thought decided to go about this another, simpler, way:

I created a common hostname for the storage mount points: gfs-data and gfs-engine

On each host I edited /etc/hosts file to have these hostnames resolve to each hosts IP i.e. on host1 gfs-data & gfs-engine --> host1 IP
on host2 gfs-data & gfs-engine --> host2 IP
etc.

In ovirt engine each storage domain is mounted as gfs-data:/data and gfs-engine:/engine My thinking is that this way no matter which host is up and acting as SPM it will be able to mount the storage as its only dependent on that host being up.

I changed gluster options for server-quorum-ratio so that the volumes remain up even if quorum is not met, I know this is risky but its just a lab setup after all.

So, any thoughts on the /etc/hosts method to ensure the storage mount point is always available? Is data corruption more or less inevitable with this setup? Am I insane ;) ?

Why not just use localhost? And no need for CTDB with a floating IP, oVirt uses libgfapi for Gluster which deals with that all natively.

As for the quorum issue, I would most definitely *not* run with quorum disabled when you're running more than one node. As you say you specifically plan for when the other 2 nodes of the replica 3 set will be active or not, I'd do something along the lines of the following...

Going from 3 nodes to 1 node:
- Put nodes 2 & 3 in maintenance to offload their virtual load;
- Once the 2 nodes are free of load, disable quorum on the Gluster volumes;
- Power down the 2 nodes.

Going from 1 node to 3 nodes:
- Power on *only* 1 of the pair of nodes (if you power on both & self-heal is enabled, Gluster will "heal" the files on the main node with the older files on the 2 nodes which were powered down);
- Allow Gluster some time to detect that the files are in split-brain;
- Tell Gluster to heal the files in split-brain based on modification time; - Once the 2 nodes are in sync, re-enable quorum & power on the last node, which will be resynchronised automatically;
- Take the 2 hosts out of maintenance mode.

If you want to power on the 2nd two nodes at the same time, make absolutely sure self-heal is disabled first! If you don't, Gluster will see the 2nd two nodes as in quorum & heal the data on your 1st node with the out-of-date data.

--
Doug

--

Chris Bartosiak-Jentys
Certico
Tel: 03333 444 884
Mob: 077 0246 8132
e-mail: ch...@certico.co.uk
www.certico.co.uk

-------------------------

Confidentiality Notice: the information contained in this email and any attachments may be legally privileged and confidential. If you are not an intended recipient, you are hereby notified that any dissemination, distribution, or copying of this e-mail is strictly prohibited. If you have received this e-mail in error, please notify the sender and permanently delete the e-mail and any attachments immediately. You should not retain, copy or use this e-mail or any attachments for any purpose, nor disclose all or any part of the contents to any other person. Certico is a trading name of "Certico Trading Limited" England & Wales registered company no. 5819172.

--
Doug

On 11 February 2017 at 15:39, Bartosiak-Jentys, Chris <chris.bartosiak-jen...@certico.co.uk> wrote:

Thank you for your reply Doug,

I didn't use localhost as I was preparing to follow instructions (blog post: http://community.redhat.com/blog/2014/11/up-and-running-with-ovirt-3-5-part-two/) for setting up CTDB and had already created hostnames for the floating IP when I decided to ditch that and go with the hosts file hack. I already had the volumes mounted on those hostnames but you are absolutely right, simply using localhost would be the best option.

Thank you for your suggested outline of how to power up/down the cluster, I hadn't considered the fact that turning on two out of date nodes would clobber data on the new node. This is something I will need to be very careful to avoid. The setup is mostly for lab work so not really mission critical but I do run a few VM's (freeIPA, GitLab and pfSense) that I'd like to keep up 24/7. I make regular backups (outside of ovirt) of those just in case.

Thanks, I will do some reading on how gluster handles quorum and heal operations but your procedure sounds like a sensible way to operate this cluster.

Regards,

Chris.

On 2017-02-11 18:08, Doug Ingham wrote:

On 11 February 2017 at 13:32, Bartosiak-Jentys, Chris <chris.bartosiak-jen...@certico.co.uk> wrote:
Hello list,

Just wanted to get your opinion on my ovirt home lab setup. While this is not a production setup I would like it to run relatively reliably so please tell me if the following storage configuration is likely to result in corruption or just bat s**t insane.

I have a 3 node hosted engine setup, VM data store and engine data store are both replica 3 gluster volumes (one brick on each host). I do not want to run all 3 hosts 24/7 due to electricity costs, I only power up the larger hosts (2 Dell R710's) when I need additional resources for VM's.

I read about using CTDB and floating/virtual IP's to allow the storage mount point to transition between available hosts but after some thought decided to go about this another, simpler, way:

I created a common hostname for the storage mount points: gfs-data and gfs-engine

On each host I edited /etc/hosts file to have these hostnames resolve to each hosts IP i.e. on host1 gfs-data & gfs-engine --> host1 IP
on host2 gfs-data & gfs-engine --> host2 IP
etc.

In ovirt engine each storage domain is mounted as gfs-data:/data and gfs-engine:/engine My thinking is that this way no matter which host is up and acting as SPM it will be able to mount the storage as its only dependent on that host being up.

I changed gluster options for server-quorum-ratio so that the volumes remain up even if quorum is not met, I know this is risky but its just a lab setup after all.

So, any thoughts on the /etc/hosts method to ensure the storage mount point is always available? Is data corruption more or less inevitable with this setup? Am I insane ;) ?

Why not just use localhost? And no need for CTDB with a floating IP, oVirt uses libgfapi for Gluster which deals with that all natively.

As for the quorum issue, I would most definitely *not* run with quorum disabled when you're running more than one node. As you say you specifically plan for when the other 2 nodes of the replica 3 set will be active or not, I'd do something along the lines of the following...

Going from 3 nodes to 1 node:
- Put nodes 2 & 3 in maintenance to offload their virtual load;
- Once the 2 nodes are free of load, disable quorum on the Gluster volumes;
- Power down the 2 nodes.

Going from 1 node to 3 nodes:
- Power on *only* 1 of the pair of nodes (if you power on both & self-heal is enabled, Gluster will "heal" the files on the main node with the older files on the 2 nodes which were powered down);
- Allow Gluster some time to detect that the files are in split-brain;
- Tell Gluster to heal the files in split-brain based on modification time; - Once the 2 nodes are in sync, re-enable quorum & power on the last node, which will be resynchronised automatically;
- Take the 2 hosts out of maintenance mode.

If you want to power on the 2nd two nodes at the same time, make absolutely sure self-heal is disabled first! If you don't, Gluster will see the 2nd two nodes as in quorum & heal the data on your 1st node with the out-of-date data.

--
Doug


_______________________________________________
Users mailing list
Users@ovirt.org
http://lists.ovirt.org/mailman/listinfo/users

Reply via email to