If you have a script that copies crontabs from their usual location on local disk, then this is not going to work when server fails as the failover node cannot copy from a server that is down.
Therefore if you want to failover crontabs, you need to put them on shared storage.
So supposing you have a diskgroup which is shared between the nodes with volume mounted on /data1 then you could move crontabs from /var/spool/cron to /data1 and create a symbolic link from /var/spool/cron/crontabs to /data1/cronabs. The problem with this is that no crontabs will run on inactive nodes and you may need local root crontabs to run on inactive nodes.
So you could link each users crontab to shared storage and leave roots as local, but there can still be issues, especially in your case where you have 3 nodes:
Supposing you have /data1 on node1 and /data2 on node2 and both fail to node3. If /data1 and /data2 can both run on node3 at the same time then crontabs won't work if you have the same users on both as you can't link to two files so this will only work if you have rules so that node3 can't run both services or each service group has its own set of unique users and also this will then involve having a script (in a Application resource or postonline trigger) to change the link so that /var/spool/cron on node3 points to users on either /data1 or data2.
There are other possibilities, but it depends on what you have so you need to explain your environment:
- What service groups do you have on what nodes
- Where are the service groups allowed to fail to and are multiple service groups allowed to fail to the same node
- Are crontab entries being created frequently or are they pretty static
- Do any service groups have the same username associated with them as another service group
Mike