https://github.com/clusterlabs/go-pacemaker
Go API for the Pacemaker cluster resource manager
https://github.com/clusterlabs/go-pacemaker
Last synced: about 1 month ago
JSON representation
Go API for the Pacemaker cluster resource manager
- Host: GitHub
- URL: https://github.com/clusterlabs/go-pacemaker
- Owner: ClusterLabs
- License: lgpl-2.1
- Created: 2016-11-19T11:34:42.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2025-02-26T16:28:52.000Z (3 months ago)
- Last Synced: 2025-03-28T06:51:10.123Z (about 2 months ago)
- Language: Go
- Size: 139 KB
- Stars: 7
- Watchers: 12
- Forks: 7
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Pacemaker
This library provides an API for connecting to and working with the
Pacemaker cluster manager, specifically with the cluster configuration
(the CIB), from the Go programming language.It is not meant to be a complete API. The main use case is connecting
to the CIB, subscribing to updates and reading the XML.**Note:** This API is under heavy development.
Current features:
* Connect and get CIB as an XML `[]byte` block
Major missing features:
* Decode CIB attributes and status section into a Go object structure
* Encode status section as JSON
* Decoding / encoding configuration section
* Writing changes back to the CIB* Get CIB as JSON
* Get CibObjects as JSON
* Make changes
* Create CibObjects
* Get status of resources and nodes
* History information
* Meta information about agents etc.## Compilation
The compile-time dependencies are Pacemaker, glib 2.0 and libxml2.
On openSUSE and similar distributions, this will get you all the
dependencies needed to compile:zypper in libpacemaker-devel libxml2-devel glib2-devel
To run the tests, the pacemaker schema files need to be available as
well. These are usually packaged separately, so to get these, you will
need to install the `pacemaker` package as well:zypper in pacemaker
## Usage
See `pacemaker_test.go` for usage examples.