We follow Eric Raymond’s famous philosophy:
- build small
- build modular
- build simple
- DB2CTL
- Licenses
- Terminology
- Commands
- Building the application
- Generate yaml configuration file
- Validate config file
- Generate all bash configuration files
- Install config files
- Cleanup
This tool generates Linbit (Storage), Pacemaker (HA) and Db2 (Warehouse) deployment scripts.
The minimum deployment unit for production is four servers with storage replication to provide resiliency from a node failue.
The failure domain is one machine per four servers. It means that you can lose one server out of four servers and Db2 warehouse will continue to run within a recovery time objective under 120 seconds.
The db2ctl
usage is as per this Apache license. The LinBit software defined storage requires a support license on RHEL/CentOS. The Db2 requires a commercial license from IBM.
However, it is possible to evaluate the solution by requesting the trial support license from LinBit for the storage and a trial license for Db2 from IBM.
There are 2 different configuration files that are mentioned in this repo:
- The initial
yaml
config file. This is similar tovalues.yaml
in helm, and it is used by the tool to create the second set of configuration files. - The second set of configuration files are the
bash configuration scripts
that are created by this tool. These files are used for setting up the software defined storage (Linbit), High Availability (Pacemaker), Db2 Warehouse).
In short, the db2ctl
tool uses a yaml
config file to create a set of bash
config files for Linbit, Pacemaker and Db2 for any Db2 production database cluster from 4 nodes to all the way to the 32 nodes.
db2ctl commands
- init (creates yaml config file)
- parse (optional, parses config file for error checking)
- generate
- all (optional, generates all shell script files)
- mapping (optional, generate mapping file)
- binpacking (optional, generate binpacking file)
- linbit Generate linbit install scripts
- pacemaker Generate pacemaker install scripts
generate flags
-b, --bin (optional) use custom bin packing file when generating config scripts, run 'generate' first to generate bin-packing file
-m, --map (optional) use custom mapping yaml file when generating config scripts, run 'generate' first to generate mapping file
- install
- all (install all shell scripts created)
- prereq (install pre-req modules)
- linbit (install linbit modules)
- pacemaker (install pacemaker modules)
- db2 (install db2 modules)
- cleanup
- all (cleans all resources) - TODO
- linbit (cleans linbit)
- pacemaker (cleans pacemaker)
- db2 (cleans db2) - TODO
- state (displays install state of all components, accepts optional args)
- install ((displays install state of all installed components)
- cleanup ((displays install state of all cleanup components)
- version (displays version info for the application)
--json (gives output in JSON)
Global flags
-c (configuration file, defaults to 'db2pc-sample.yaml')
-v (prints verbosely, useful for debugging)
-d, --dry-run (optional) shows what scripts will run, but does not run the scripts
-n, --no-generate (optional) do not generate bash scripts as part of install/cleanup, instead use the ones in generated folder. Useful for running local change to the scripts
-r, --re-run (optional) re-run script from initial state, ignoring previously saved state
The following assumes that you are using a MacBook. You may to tweak this for Linux and Windows.
- Clone the repo
brew install go
Make sure your PATH
env variable has go/bin
included (export PATH=$PATH:$(go env GOPATH)/bin)
)
git checkout develop
go get github.com/rakyll/statik
brew install goreleaser
make install
to test the tool on your MacBook or Windows laptop.make build-linux
to build the GO binary for Linux.make send-linux
to scp the tool to your target RHEL/CentOS machine. You need to modift the Makefile.upload.sh
- used by the developers of this tool to release the binary to GitHub.
db2ctl init
This will create the db2ctl-sample.yaml
. It is a configuration file that the tool uses to generate linbit, pacemaker and db2 configuration filess.
In the spirit of the open-source, please put up a PR if you are making changes to the deployment scripts so that it is useful to the community.
Copy db2ctl-sample.yaml
to db2ctl.yaml
and make changes.
db2ctl parse -c db2ctl.yaml
This will check if the db2ctl.yaml
is valid or not.
(Run with -v
to print the whole parsed object)
Note: -c
defaults to db2ctl.yaml
, so you can omit to specify -c db2ctl.yaml
, if the file is in the same directory.
db2ctl generate all -c db2ctl.yaml
This will generate all the configuration files needed for the application.
Note: -c
defaults to db2ctl.yaml
, so it can be ignored if the file is in the same directory.
db2ctl install <command> -c db2ctl.yaml
Note: -c
defaults to db2ctl.yaml
, so it can be ignored if the file is in the same directory.
db2ctl cleanup <command> -c db2ctl.yaml
Note: -c
defaults to db2ctl.yaml
, so it can be ignored if the file is in the same directory.