Skip to main content

Module providing IBM Fail over functions

Project description

IBM Cloud Fail Over Functions

Overview

IBM Cloud Fail Over is a Python module designed to automate failover processes for applications hosted on IBM Cloud. This module provides essential functions to manage failover scenarios effectively, ensuring high availability and reliability.

Features

  • Automated Failover: Seamlessly switch to backup resources when primary resources are unavailable.
  • Resource Management: Manage critical resources like Virtual IPs and Floating IPs with ease.

Installation

You can install the IBM Cloud Fail Over module using pip. Run the following command:

pip install ibm_cloud_fail_over

Usage

Main Functions

fail_over_cr_vip

This function manages the failover of a Cloud Resource Virtual IP (CR VIP).

Usage:

from ibm_cloud_fail_over import fail_over_cr_vip

# Example usage
active_ip = fail_over_cr_vip(vpc_url='IBM Cloud VPC regional URL",
                           primary_vip='your_primary_vip',
                           secondary_vip='your_secondary_vip',
                           api_key="Optional: API key" )
print(active_ip)

Parameters:

Parameter Type Description
vpc_url str IBM Cloud VPC regional URL.
primary_vip str The primary Virtual IP to monitor.
secondary_vip str The secondary Virtual IP to switch to.
api_key str Optional needed only if you are not using trusted profile, IBM cloud api acsess key

Returns:

  • The Active ip post failover operation.

fail_over_floating_ip_start

This function manages the failover of a Floating IP Attach to the caller Endpoint (VSI/BM)

Usage:

from ibm_cloud_fail_over import fail_over_floating_ip_start

# Example usage
result = fail_over_floating_ip_start(vpc_url='IBM Cloud VPC regional URL",
                                master_vni_id="Virtual network inetface uuid for new active",
                                passive_vni_id="Virtual network inetface uuid for new passive" ,
                                fip_id="the floating ip uuid",
                                api_key="Optional: API key" ))
print(result)

Parameters:

Parameter Type Description
vpc_url str(url) IBM Cloud VPC regional URL.
master_vni_id str(uuid) Virtual network inetface uuid for new active.
passive_vni_id str(uuid) Virtual network inetface uuid for new active.
fip_id str(uuid) Floating IP uuid to move.
api_key str Optional needed only if you are not using trusted profile, IBM cloud api acsess key
Returns:
  • A confirmation message indicating the success or failure of the failover operation.

fail_over_floating_ip_stop

This function manages the failover of a Floating IP Detach to the caller Endpoint (VSI/BM)

Usage:

from ibm_cloud_fail_over import fail_over_floating_ip_stop

# Example usage
result = fail_over_floating_ip_stop(vpc_url='IBM Cloud VPC regional URL",
                                master_vni_id="Virtual network inetface uuid for new active",
                                passive_vni_id="Virtual network inetface uuid for new passive" ,
                                fip_id="the floating ip uuid",
                                api_key="Optional: API key" ))
print(result)

Parameters:

Parameter Type Description
vpc_url str(url) IBM Cloud VPC regional URL.
master_vni_id str(uuid) Virtual network inetface uuid for new active.
passive_vni_id str(uuid) Virtual network inetface uuid for new active.
fip_id str(uuid) Floating IP uuid to move.
api_key str Optional needed only if you are not using trusted profile, IBM cloud api acsess key
Returns:
  • A confirmation message indicating the success or failure of the failover operation.

fail_over_get_attached_fip

This function manages the failover of a Floating IP Detach to the caller Endpoint (VSI/BM)

Usage:

from ibm_cloud_fail_over import fail_over_get_attached_fip

# Example usage
api_key = ""
attached_fip_id, attached_fip_ip = fail_over_get_attached_fip(api_key)

print(attached_fip_ip)
print(attached_fip_id)

Parameters: None

Returns: attached_fip_id, attached_fip_ip

fail_over_public_address_range

This function manages the failover of a public address range by updating its target zone to match the VSI's local availability zone.

Usage:

from ibm_cloud_fail_over import fail_over_public_address_range

# Example usage
result = fail_over_public_address_range(
    range_id="public_address_range_uuid",
    vpc_url="IBM Cloud VPC regional URL",
    api_key="Optional: API key",
    api_version="2025-05-06",  # Optional: API version
    maturity="beta",           # Optional: API maturity level
    generation="2"             # Optional: API generation
)
print(result)

Parameters:

Parameter Type Description
range_id str(uuid) The ID of the public address range to update
vpc_url str(url) IBM Cloud VPC regional URL
api_key str Optional: IBM Cloud API key (needed only if not using trusted profile)
api_version str Optional: API version (defaults to "2025-05-06")
maturity str Optional: API maturity level (defaults to "beta")
generation str Optional: API generation (defaults to "2")

Returns:

  • The updated public address range information if an update was needed
  • None if no update was needed (range already in correct zone)

Note:

  • The function automatically detects the VSI's local availability zone
  • The range is only updated if its current zone differs from the VSI's local zone
  • Requires the same instance metadata service and trusted profile setup as other functions

fail_over_check_par_zone_compatibility

This function checks if a public address range and the VSI are in the same availability zone.

Usage:

from ibm_cloud_fail_over import fail_over_check_par_zone_compatibility

# Example usage
zones_match, current_zone = fail_over_check_par_zone_compatibility(
    range_id="public_address_range_uuid",
    vpc_url="IBM Cloud VPC regional URL",
    api_key="Optional: API key",
    api_version="2025-05-06",  # Optional: API version
    maturity="beta",           # Optional: API maturity level
    generation="2"             # Optional: API generation
)

if zones_match:
    print(f"PAR and VSI are in the same zone: {current_zone}")
else:
    print(f"PAR and VSI are in different zones. PAR zone: {current_zone}")

Parameters:

Parameter Type Description
range_id str(uuid) The ID of the public address range to check
vpc_url str(url) IBM Cloud VPC regional URL
api_key str Optional: IBM Cloud API key (needed only if not using trusted profile)
api_version str Optional: API version (defaults to "2025-05-06")
maturity str Optional: API maturity level (defaults to "beta")
generation str Optional: API generation (defaults to "2")

Returns:

  • A tuple containing:
    • bool: True if the public address range and VSI are in the same zone, False otherwise
    • str: The current zone name of the public address range

Note:

  • The function automatically detects the VSI's local availability zone
  • Requires the same instance metadata service and trusted profile setup as other functions
  • Useful for checking zone compatibility before performing failover operations

Troubleshooting

If you encounter issues while using the module, consider the following:

  • Invalid IP Addresses: Ensure that the IP addresses provided for primary and secondary resources are valid and reachable.
  • Network Issues: Check your network connectivity to the IBM Cloud resources.
  • Permissions: Ensure that your IBM Cloud account has the necessary permissions to manage the specified resources.
  • Required dependencies: Enable Instance Metada Service on Both Enpoints
  • Optional dependencies: Enable Trusted profile to avoid using and api access key

For further assistance, please check the GitHub Issues page or contact the project maintainer.

Contributing

We welcome contributions! To contribute to the project, please follow these steps:

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature/YourFeature).
  3. Make your changes and commit them (git commit -m 'Add some feature').
  4. Push to the branch (git push origin feature/YourFeature).
  5. Create a new Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contact

For questions or support, please open an issue on GitHub or contact the project maintainer at dev@gampel.net.


### TOOD:
 

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ibm_cloud_fail_over-1.0.18.tar.gz (16.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ibm_cloud_fail_over-1.0.18-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file ibm_cloud_fail_over-1.0.18.tar.gz.

File metadata

  • Download URL: ibm_cloud_fail_over-1.0.18.tar.gz
  • Upload date:
  • Size: 16.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ibm_cloud_fail_over-1.0.18.tar.gz
Algorithm Hash digest
SHA256 bb34b3e1d7dfe4aad494c9fdc11caa035d09fca7e90bcebada523dbf7ee8c963
MD5 43a068edfff46c8c3c974ade1cf7f2a9
BLAKE2b-256 9edfb0c14155e0c68ce535156060edfb57b82fbf6f3550380c1a438274786811

See more details on using hashes here.

Provenance

The following attestation bundles were made for ibm_cloud_fail_over-1.0.18.tar.gz:

Publisher: publish.yml on gampel/ibm_cloud_fail_over

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ibm_cloud_fail_over-1.0.18-py3-none-any.whl.

File metadata

File hashes

Hashes for ibm_cloud_fail_over-1.0.18-py3-none-any.whl
Algorithm Hash digest
SHA256 c6ed1682c2de24f2bf4913c3ab123cee29714639978f14cd98cf99ca0b968c0a
MD5 05f132f0b34e59c73b993dd34faee3ad
BLAKE2b-256 8a004809878884b84295e2bf7c259ef862bb90164a44cb4781c44a65d6794759

See more details on using hashes here.

Provenance

The following attestation bundles were made for ibm_cloud_fail_over-1.0.18-py3-none-any.whl:

Publisher: publish.yml on gampel/ibm_cloud_fail_over

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page