manager

command
v0.5.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 27, 2021 License: Apache-2.0 Imports: 29 Imported by: 0

README

manager

Kubernetes custom resources and controllers of Fybrik.

The manager binary includes all of the controllers that this project defines but you need to select which of the controllers to run by passing one or more of the following command line arguments:

  • enable-all-controllers to enable all controllers
  • enable-application-controller to enable the controller for FybrikApplication
  • enable-blueprint-controller to enable the controller for Blueprint
  • enable-motion-controller to enable the controllers for BatchTransfer and StreamTransfer

Run and debug locally

Beyond testing, you may run and debug the manager outside the cluster using the following instructions.

Run required components

Components such as connectors need to be running before you run the manager. This can be done by one of these options:

  1. Running components locally directly (no instructions provided)
  2. Running components in a cluster

For option 2, the Helm installation allows you to pick which compoenents to install. Follow the installation guide as usual but in the Helm installation for the control plane add --set manager.enabled=false to skip the deployment of the manager. For example:

helm install fybrik charts/fybrik --set global.tag=master --set manager.enabled=false -n fybrik-system --wait
Expose running components

Components such as connectors need to be reachable over localhost. If you chose to run these components in a cluster you can use port-forward. For example:

kubectl -n fybrik-system port-forward svc/katalog-connector 49152:80 &
kubectl -n fybrik-system port-forward svc/opa-connector 49153:80 &
Set configuration environment variables

The main configuration map is not available when running locally. Therefore, you need to define configuration as environment variables.

Create .env file in the root folder of the project. For example:

VAULT_ADDRESS="http://vault.fybrik-system:8200"
MAIN_POLICY_MANAGER_NAME="opa"
MAIN_POLICY_MANAGER_CONNECTOR_URL="http://localhost:49153"
CATALOG_PROVIDER_NAME="katalog"
CATALOG_CONNECTOR_URL="localhost:49152"
CONNECTION_TIMEOUT="120"
VAULT_MODULES_ROLE="module"
ENABLE_WEBHOOKS="false"

If you plan to run manager from the command line, then run the following to export all of the variables:

set -a; . .env; set +a
Run the manager
From command line

You can now run the manager from the manager folder using one of these options:

  1. make run
  2. go run main.go --enable-all-controllers --metrics-bind-addr=0
From IDE

If you wish to debug it from an IDE then be sure to configure the environment variables properly as described in the previous step.

Below is a launch.json file for VSCode:

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Launch",
            "type": "go",
            "request": "launch",
            "mode": "auto",
            "program": "${workspaceFolder}/manager/main.go",
            "envFile": "${workspaceFolder}/.env",
            "args": ["--metrics-bind-addr=0", "--enable-all-controllers"]
        }
    ]
}

Directory structure

The rest of this README describes the directory structure.

apis

Holds the Customer Resource Definitions (CRDs) of the project:

  • app.fybrik.io/v1alpha1: Includes FybrikApplication, administrator APIs FybrikModule and FybrikBucket, and internal CRDs Blueprint and Plotter.
  • motion.fybrik.io/v1alpha1: Includes data movements APIs BatchTransfer and StreamTransfer. Usually not used directly but rather invoked as a module.
controllers

Holds the customer controllers of the project:

  • controllers/app holds the controllers for app.fybrik.io APIs FybrikApplication, Blueprint and Plotter.
  • controllers/motion holds the controllers for motion.fybrik.io APIs BatchTransfer and StreamTransfer.
testdata

Includes resources that are used in unit tests and in integration tests.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
apis
app/v1alpha1
Package v1alpha1 contains API Schema definitions for the api v1alpha1 API group +kubebuilder:object:generate=true +groupName=app.fybrik.io
Package v1alpha1 contains API Schema definitions for the api v1alpha1 API group +kubebuilder:object:generate=true +groupName=app.fybrik.io
motion/v1alpha1
+groupName=motion.fybrik.io Package v1 contains API Schema definitions for the motion v1 API group +kubebuilder:object:generate=true +groupName=motion.fybrik.io
+groupName=motion.fybrik.io Package v1 contains API Schema definitions for the motion v1 API group +kubebuilder:object:generate=true +groupName=motion.fybrik.io
app

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL