One cluster can be shared between multiple teams. For multi-tenancy, the namespaces used by different teams should have different policies according to the best practices for multi-tenancy. This doc walks you through the steps for configuring namespace specific policies, such as Role, RoleBinding and NetworkPolicy for a cluster shared between teams.
In this tutorial, you will
- Configure your repository with Kustomize configurations to get namespace specific policies from a common base.
- Preview and validate the configs that you create.
- Use Config Sync to automatically render and sync your cluster to your repository.
- Verify that your installation succeeded.
This section describes prerequisites you must meet before this tutorial.
- ConfigSync is installed on your cluster, with the version at least 1.9.0. If not, you can install it following the instructions.
- Install the
nomos
command. If you've already installednomos
, make sure you upgrade it to version 1.9.0 or later.
The automated-rendering
directory includes a root kustomization.yaml
file that references the three team overlays.
resources:
- configsync-src/team-a
- configsync-src/team-b
- configsync-src/team-c
The automated-rendering/configsync-src
file is a symbolic link that links to the source directory: ../configsync-src
.
If you need to update some configuration, you need to fork this example repository into your organization and clone the forked repo locally.
$ git clone https://github.com/<YOUR_ORGANIZATION>/anthos-config-management-samples acm-samples
Then you can follow the instructions in this session. It is optional and shouldn’t affect the steps below.
When you add new configuration or update configuration under the directory acm-samples/namespace-specific-policy/configsync-src/base
, the change will be propagated to configuration for all of team-a
, team-b
and team-c
.
An overlay is a kustomization that depends on another customization.
In this example, there are three overlays: team-a
, team-b
and team-c
. If you only need to update some configuration in
one overlay, you only need to touch the directory for that overlay.
Here is an example of adding another Role in the overlay team-a
.
We can add a new file
acm-samples/namespace-specific-policy/configsync-src/team-a/another-role.yaml
with the following content:
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: pod-reader
rules:
- apiGroups: [""]
resources: ["pods"]
verbs: ["get", "watch", "list"]
Then include the new config in
acm-samples/namespace-specific-policy/configsync-src/team-a/kustomization.yaml
by adding the file name under resources
.
# kustomization.yaml
resources:
- ../base
- another-role.yaml
...
Then you can commit and push the update.
$ git add .
$ git commit -m 'update configuration'
$ git push
Before Config Sync renders the configs and syncs them to the cluster, ensure that the configs
are accurate by running nomos hydrate
to preview the rendered configuration and running nomos vet
to validate that the format is correct.
- Run the following
nomos hydrate
with the following flags:
nomos hydrate --source-format=unstructured --output=OUTPUT_DIRECTORY
In this command:
--source-format=unstructured
letsnomos hydrate
work on an unstructured repository. Since you are using Kustomize configurations, you need to use an unstructured repository and add this flag.--output=OUTPUT_DIRECTORY
lets you define a path to the rendered configs. Replace OUTPUT_DIRECTORY with the location that you want the output to be saved in.
- Check the syntax and validity of your configs by running
nomos vet
with the following flags:
nomos vet \
--source-format=unstructured \
--keep-output=true \
--output=OUTPUT_DIRECTORY
In this command:
--source-format=unstructured
letsnomos vet
work on an unstructured repository.--keep-output=true
saves the rendered configs.--output=OUTPUT_DIRECTORY
is the path to the rendered configs.
Now you can configure ConfigSync to sync these policies to the cluster.
You can do this either using the GCP console or gcloud
.
Following the console instructions for configuring Config Sync, you need to
- Select None in the Git Repository Authentication for ACM section
- Select Enable Config Sync in the ACM settings for your clusters section
- If you're using your forked repo, the URL should be the Git repository url for your fork:
https://github.com/<YOUR_ORGANIZATION>/anthos-config-management-samples.git
; otherwise the URL should behttps://github.com/GoogleCloudPlatform/anthos-config-management-samples.git
- the Branch should be
master
. - the Tag/Commit should be
HEAD
. - the Source format field should unstructured.
- the Policy directory field should be
namespace-specific-policy/automated-rendering
.
- If you're using your forked repo, the URL should be the Git repository url for your fork:
You can also configure the Git repository information in a
config-management.yaml
file and use a gcloud
command to apply it.
-
Create the
config-management.yaml
filecat << EOF > config-management.yaml apiVersion: configmanagement.gke.io/v1 kind: ConfigManagement metadata: name: config-management spec: git: policyDir: namespace-specific-policy/automated-rendering secretType: none syncBranch: master # If you're using your forked repo, # syncRepo field should be https://github.com/<YOUR_ORGANIZATION>/anthos-config-management-samples.git syncRepo: https://github.com/GoogleCloudPlatform/anthos-config-management-samples.git sourceFormat: unstructured EOF
-
Apply the
config-management.yaml
file.gcloud alpha container hub config-management apply \ --membership=CLUSTER_NAME \ --config=config-management.yaml \ --project=PROJECT_ID
Replace the following variables:
CLUSTER_NAME
: the name of the registered cluster that you want to apply this configuration to.PROJECT_ID
: your GCP project ID.
Now you can verify that the namespace specific policies are synced to the cluster.
nomos status
You can also double-check the resources exist in the cluster.
# Verify the RoleBinding exist
$ kubectl get RoleBinding/team-admin-rolebinding -n team-a
# Verify the Role exist
$ kubectl get Role/team-admin -n team-a
# Verify the NetworkPolicy exist
$ kubectl get NetworkPolicy/deny-all -n team-a
To clean up the team namespaces and policies for them, we recommend removing the directories that contain their configuration from your Git repository.
$ rm -r acm-samples/namespace-specific-policy/manual-rendering/configsync/team-*/*
$ git add .
$ git commit -m 'clean up'
$ git push
When the last commit from the root repository is synced, the three namespace team-a
, team-b
and team-c
are deleted from the cluster.
To stop the syncing using ConfigSync, you can delete the ConfigManagement resource.
kubectl delete -f config-management.yaml