Skip to content

Python class for MongoDB Ops Manager and Ansible module

License

Notifications You must be signed in to change notification settings

DanielOsuntoyinbo/opsmancombo

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpsManCombo

OpsManCombo is CLI tool for MongoDB database cluster and single node management via Ops Manager REST API, designed for technical teams. More information about Ops Manager can be found under: https://docs.opsmanager.mongodb.com/current/, information about Ops Manager REST API can be found under: https://docs.opsmanager.mongodb.com/current/reference/api/

Opsmancombo use Ops Manager REST API calls for MongoDB database minor and major upgrade, downgrade, MongoDB cluster alert detection, replication check, stopping and starting MongoDB processes on single node.

OpsManCombo should be used by your Dev Ops team! - OpsManCombo can be integrated with frameworks like Ansible!. OpsManCombo can be started in upgrade (for MongoDB databases upgrade) and maintenance mode (for cluster and single nodes maintenance). OpsManCombo can use SSL Cert Verification or can be run without SSL Cert Verification. Logging option can also be set.

use cases: • MongoDB cluster upgrade, • MongoDB cluster downgrade, • stop MongoDB processes on one node from MongoDB cluster (e.g for node reboot or HW exchange), • start MongoDB processes on MongoDB node, • alert detection on MongoDB cluster, • replication sync check on MongoDB cluster.

Maintenance mode is recomended for technical staff for their day to day tasks - like take one node out from cluster for firmware upgrade and reboot or kernel patching. Before any operation maintenance window will be created on Ops Manager to avoid alert generation. After operation maintenance window will be deleted.

MongoDB database upgrade examples:

  • MongoDB cluster upgrade with SSL Cert Verification:

./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --verify <path_to_certificate> upgrade -d <database_name> -v <desired_MongoDB_version>

  • MongoDB cluster upgrade without SSL Cert Verification: ./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --no-verify upgrade -d <database_name> -v <desired_MongoDB_version>

  • OpsManCombo can be also start in maintenance mode for single node from the cluster.

to check replication sync: ./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --no-verify maintenance -a sync -n <node_name>

to check alerts on MongoDB cluster: ./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --no-verify maintenance -a alert -n <node_name>

to stop mongoDB processes on single node: ./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --no-verify maintenance -a stop -n <node_name>

to start mongoDB processes on single node: ./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --no-verify maintenance -a start -n <node_name>

to check if any change is currently deploying on MongoDB cluster by Ops Manager ./opsmancombo.py -u <ops_manager_user_name> -k <ops_manager_api_key> -m https://<ops_manager:port> -l <path_to_logs> --no-verify maintenance -a check -n <node_name>

  • input parameters:

upgrade mode: -u <user_name> -k <api_key_to_OpsManager> -m https://<ops_manager_address:port> -l <path_to_log_file> ssl: --no-verify | --verify <path_to_ssl_certificate> -d <MongoDB_database_name> -v <desired_MongoDB_version>

maintenance mode: -u <user_name> -k <api_key_to_OpsManager> -m https://<ops_manager_address:port> -l <path_to_log_file> ssl: --no-verify | --verify -a action:alert,stop,start,sync,check -n <single_node_address>

About

Python class for MongoDB Ops Manager and Ansible module

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%