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.21.tar.gz (18.2 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.21-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ibm_cloud_fail_over-1.0.21.tar.gz
  • Upload date:
  • Size: 18.2 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.21.tar.gz
Algorithm Hash digest
SHA256 80d52e7dabcb1cb42f549617aa509e20c46e9ec9e3956957ac344c2d741c8f94
MD5 3aa0adbf215fbef17c84b1c111d18760
BLAKE2b-256 052bacd377b4656132f8b09e6e53b310ed18ea80b0c4a0c54ee0dc590e3ec1f0

See more details on using hashes here.

Provenance

The following attestation bundles were made for ibm_cloud_fail_over-1.0.21.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.21-py3-none-any.whl.

File metadata

File hashes

Hashes for ibm_cloud_fail_over-1.0.21-py3-none-any.whl
Algorithm Hash digest
SHA256 b4e5f6e70d20c056e705aebcbd614b715308f78aa0d2133a0015343b376dcf32
MD5 6896d21083aa8ff5a68761aef80b80cf
BLAKE2b-256 da82ce4978995ef56163bffc361696cbae9c08199279210dd6d583de0193770d

See more details on using hashes here.

Provenance

The following attestation bundles were made for ibm_cloud_fail_over-1.0.21-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