Repository for maintaining Helm chart definitions for metaphactory
kubectl
and Helm 3 installed- a Kubernetes cluster setup (client and server version >= 1.23 , check with
kubectl version
) - outgoing HTTP/HTTPS traffic for the Kubernetes cluster, allowing to access external Docker registries (e.g. Docker Hub)
To perform any deployments or updates, you will first need to log into the metaphact's Docker Hub repository. If you do not yet have access, please register for a trial on https://metaphacts.com/get-started and follow the steps for a Docker-based deployment. After registration, you will receive an email containing a user name and token to access the container image from Docker Hub which can be used to log in using docker login
.
IMPORTANT: This guide is using a StatefulSet
for the deployment of metaphactory, which includes the pod and volume claim definitions in one file and allows easy update and scale-out configurations defined in templates/statefulset.yaml
.
The configuration for an AWS Load Balancer with SSL termination is included in templates/metaphactory-ingress-tls.yaml
and can be activated by setting the property enabled
in the ingress
section within values.yaml
to true
.
The important configuration parameters in this Helm Chart are externalized in the values.yaml
files, so one can easily change these parameters in just one place without modifying any of the provided template files.
You can also define separate values.yaml
files which contains configuration properties for specific deployment. As an example, for development one would create a copy of values.yaml
as development-values.yaml
and adjust the parameters accordingly. To deploy the Helm chart with the values defined in this file, the filename is passed as a parameter to the install
command i.e. helm install metaphactory -f values-dev.yaml ./charts/metaphactory/
. Without this setting, Helm will use the default values in the values.yaml
file.
When updating parameters in a values file with the chart already running, the configuration can be updated by "upgrading" a chart. To pick up the new configuration without needing to restart and rerun all the configuration separately, one would run the upgrade
command: helm upgrade -f values.yaml metaphactory ./charts/metaphactory/
applies all changes from the values.yaml
file.
The SSO configuration defined in file values.yaml
provides an example configuration using OIDC with Azure AD for Single-Sign On (SSO) and a database configuration for an externally running GraphDB database.
This Helm chart supports SSO via OpenID Connect (OIDC), the OIDC configuration is defined in shiro-sso-oidc-params.ini
(parameter ssoOidcParams
in file values.yaml
). The example shows how to use OIDC with Azure AD for Single-Sign On (SSO). When using Azure, the values for discoveryURI.value
(replace customer-tenant-id
with your organization's ID), callbackUrl.value
(externally reachable URL of your metaphactory installation), clientId.value
(ID of application registered for metaphactory in Azure AD), and clientSecret.value
(corresponding client password) need to be adjusted.
Local users can be enabled by un-commenting the parameter enableLocalUsers
in environment.prop
. The users are defined in the shiro.ini
file also provided in parameter localDefaultUsers
in file values.yaml
.
Also see the Authentication and Authorization Providers documentation for details on OIDC configuration.
Please note: as this file is projected into the container as a read-only file, users and passwords cannot be managed using metaphactory's User Administration page. Instead, they can be created using the Shiro Command Line Hasher tool and stored in the parameter.
The database configuration is provided with the repository-config
key in the ConfigMap
. See Repository Manager as well as How to connect to GraphDB or How to connect to Stardog for details on database configuration.
Please note: as this file is projected into the container as a read-only file, it cannot be changed using metaphactory's Repository Administration page.
Note: the ConfigMap
contains two configuration files for the tests and assets repositories: repository-assets-config
and repository-tests-config
which will configure metaphactory to use GraphDB repositories for assets and tests.
To create a new deployment from scratch chose from these two options:
- Clone this GIT repository
- Create a namespace (or use an existing one):
kubectl create ns metaphactory-dev
- Create a secret in your cluster to pull images from a private registry and note down the name of that secret (the secret name assumed in provided configuration files is
regcred
):kubectl create secret docker-registry regcred --docker-username=metaphactscustomers --docker-password=<your-token-from-registration> --namespace metaphactory-dev
- Create a secret in your cluster to access the database (the secret name assumed in provided configuration files is
credentials
):kubectl create secret generic credentials --from-literal=repository.username=admin --from-literal=repository.password=admin --namespace metaphactory-dev
- Ensure that the correct secret names from the previous steps are set in
values.yaml
for parametersimagePullSecretName:
andcredentialsSecretName:
- Ensure that the intended storage class is set in
values.yaml
in thestorage
part forclassName:
. Use the commandkubectl get storageclass
to list available storage classes in your cluster. - The default configuration creates a service of type
LoadBalancer
. This can be changed totype: ClusterIP
ortype: NodePort
in theservice
section ofvalues.yaml
. - Adjust the SSO and database configuration in
values.yaml
to work with the target environment (see below) - Next start the metaphactory chart with
helm install -f values.yaml metaphactory ./charts/metaphactory/
and verify that the pod and service are running fine withkubectl get pods
andkubectl get service metaphactory
service should show an external IP, please note down this IP or hostname. Please note, that Helm will create the deployment within the default namespace. To use a different namespace, rather executehelm install metaphactory ./charts/metaphactory/ --namespace metaphactory-dev
instead. - Verify that the application is running by connecting to
http://<external IP>
with the external IP as retrieved during step 9. - Login with your SSO user. When local users are enabled (see
Configuration
below), user name and credentials can be provided in the login form available at the/login
endpoint. The default credentials are useradmin
with passwordadmin
.
To remove the complete setup run following commands (Note: This will remove all persistent volumes and data as well!)
- Remove the metaphactory chart with
helm uninstall metaphactory
- Note: This will destroy all metaphactory runtime data and configuration!
Please follow below steps before contacting our support on [email protected]
- Run
kubectl describe service metaphactory
to verify the status of the service. - Run
kubectl describe pod metaphactory
to get details on the metaphactory pod status. The init container should be in state terminated and the actual container in state running. - Follow activity in the cluster with
kubectl events
- Pull logs on the metaphactory pod with
kubectl logs metaphactory-0
- You can access the container for advanced troubleshooting through
kubectl exec -it metaphactory-0 -- sh