-
Notifications
You must be signed in to change notification settings - Fork 0
GV Configuration Framework
Your TIBCO BusinessEvents application deployed on a cloud platform can use global variables from gv configuration framework. This framework allows customers to configure and pull GV values from various end-stores (also referred as GV provider in this document) when running the BE application in container mode. Framework supports following types of GV providers:
- HTTP - Use this type when end-store has an http based API to access it. Example: AWS S3, Azure Blob, github, etc...
- Consul - Use this type when end-store is Consul
- Custom - Use this type to provide custom implementation to pull GV values from an end-store of user choice
While building the BE application image, use --gv-provider
flag to select GV provider type - http
, consul
OR custom name
. To add more than one GV use comma separated format ex: "consul,http"
. While using multiple gv providers if same key/value pair present in gvs then key/value pair from last mentioned gv is considered. More details are available in their respective sections below.
Note: Sample commands are given for docker
. If you are using buildah
replace docker
with buildah
in build commands. You can run with podman
by simply replacing docker
with podman
command in all run commands.
To select this provider type, pass http
to --gv-provider flag while building the BE application image.
Sample:
./build_image.sh \
-i app \
-s /home/user/tibco/installers \
--gv-provider http \
-t fdhttp:latest
Following environment variables are applicable for this GV provider type:
- GVP_HTTP_SERVER_URL - end-store URL
- GVP_HTTP_HEADERS - Header values to access the end-store API
Sample run:
docker run \
-e GVP_HTTP_SERVER_URL="<SERVER_URL>" \
-e GVP_HTTP_HEADERS="Authorization:token 9222c5cf6e380ba1395e9d8acce8764265f85933,Content-Type:application/json" \
-p 8108:8108 --name=fdhttpgit fdhttp:latest
Sample run:
docker run \
-e GVP_HTTP_SERVER_URL="<SERVER_URL>" \
-e GVP_HTTP_HEADERS="x-ms-date: $(date -u)" \
-p 8108:8108 --name=fdhttpazure fdhttp:latest
- The Consul server that is to be used as key-value store for the application global variables must already be setup. For instructions on installation and setup, see the Consul documentation.
- (Optional) For a secured (HTTPS) Consul server, ensure that you have access to the CA and CLI certificates.
-
Connect to the Consul server that you have already setup from your web browser. Set up your application global variables in the Consul server as key-value pairs.
Syntax for keys in Consul is
<AppName>/<ProfileName>/<GV-Key> = <GV-Value>
Where,
-
AppName
is a name for the TIBCO BusinessEvents application of your choosing, for example, FraudDetection. -
ProfileName
is the name for the profile in the application, for example, prod, default, and so on. -
GV-Key
is the name of the global variable as defined in your TIBCO BusinessEvents application. In the case of global variables within a global variable group, use the usual format of separating them with a forward slash, for example, RMS/port. -
GV-Value
is the value to set for the global variable.
-
-
(Optional) For the secured Consul server, copy the CA and CLI certificates in the same folder as application EAR and CDD files.
To select this provider type, pass consul
to --gv-provider flag while building the BE application image.
Sample:
./build_image.sh \
-i app \
-s /home/user/tibco/installers \
--gv-provider consul \
-t fdconsul:latest
Following environment variables are applicable for this GV provider type:
- CONSUL_SERVER_URL - Consul URL
- BE_APP_NAME - App name created in the Consul
- APP_CONFIG_PROFILE - Profile created in the Consul
Sample run:
docker run \
-e "CONSUL_SERVER_URL=http://consul:8500" \
-e "BE_APP_NAME=FraudDetection" \
-e "APP_CONFIG_PROFILE=default" \
-p 8108:8108 --name=fdconsul fdconsul:latest
Sample run(Secured Consul Server):
The CONSUL_CACERT
, CONSUL_CLIENT_CERT
, and CONSUL_CLIENT_KEY
environment variables are only required for the secured Consul server.
docker run \
-e "CONSUL_SERVER_URL=http://consul:8500" \
-e "BE_APP_NAME=FraudDetection" \
-e "APP_CONFIG_PROFILE=default" \
-e "CONSUL_CACERT=/opt/tibco/be/ext/consul-agent-ca.pem" \
-e "CONSUL_CLIENT_CERT=/opt/tibco/be/ext/dc1-cli-consul-0.pem" \
-e "CONSUL_CLIENT_KEY=/opt/tibco/be/ext/dc1-cli-consul-0-key.pem" \
-p 8108:8108 --name=fdconsul fdconsul:latest
To add a custom GV provider, create a new folder under be-tools/cloud/docker/gvproviders/custom/
and name it as per your choice - lets say CUSTOM_PROVIDER
. Provide implementation as per below instructions:
- Add
be-tools/cloud/docker/gvproviders/custom/CUSTOM_PROVIDER/setup.sh
(setup.bat for windows). This gets invoked by the framework during BE application docker build. Provide logic to download required packages & setup environment needed for the config provider. - Add
be-tools/cloud/docker/gvproviders/custom/CUSTOM_PROVIDER/run.sh
(run.bat for windows). This gets invoked by the framework during run time. Provide logic to pull GV values from the end-store, parse and write them into the JSON file at/home/tibco/be/gvproviders/output.json
Sample output.json
for reference:
{
"KEY1": "VALUE1",
"KEY2": "VALUE2"
}
To select this provider type, pass CUSTOM_PROVIDER
to --gv-provider flag while building the BE application image.
Sample:
./build_image.sh \
-i app \
-s /home/user/tibco/installers \
--gv-provider CUSTOM_PROVIDER \
-t fdcustom:latest
There is a custom GV provider aws
added as a reference example. This GV provider can pull GVs from AWS Secrets Manager or AWS S3.
Refer to following files at be-tools/cloud/docker/gvproviders/custom/aws
for the implementation logic:
setup.sh -> Installs aws cli & other tools
run.sh -> Configure aws cli, pull secrets from AWS Secrets Manager
Sample command to build BE app image which uses aws
GV provider:
./build_image.sh \
-i app \
-s /home/user/tibco/installers \
--gv-provider aws \
-t fdcustom:latest
Sample run command to pull GVs from AWS Secrets Manager:
docker run \
-e AWS_ACCESS_KEY_ID=<AWS ACCESS ID> \
-e AWS_SECRET_ACCESS_KEY=<AWS SECRET> \
-e AWS_DEFAULT_REGION=<REGION> \
-e AWS_ROLE_ARN=<ASSUMED ROLE> \
-e AWS_SM_SECRET_ID=<AWS SECRETS MANAGER - SECRET ID> \
-p 8108:8108 --name=fdcustom fdcustom:latest
Note: This GV provider can be easily updated to pull GVs from S3
. Uncomment the section "Read GV values from AWS S3 into JSON_FILE" and comment "Read GV values from AWS Secrets Manager into JSON_FILE" in be-tools/cloud/docker/gvproviders/custom/aws/run.sh
. Also update environment variable's validations and echo statements accordingly.
Parent Topic: Containerize TIBCO BusinessEvents