My company has been running Kuberenetes for over a year now and GitLab for about 6 months. We recently upgrade to GitLab 9.x and are having trouble trying to figure out what's up with the decision around the CI + app configuration with Kube. This feature is awesome and would love to get it working in our environment.
It seems as though GitLab is expecting you to only have one cluster setup with all of your environments inside of that one cluster broken up by namespace which would equal your service/application and app which would equal your environment. This is what it looks like GitLab wants my Kuberenetes environment to look like, a single cluster with your service broken up into namespaces:
namespace = hello-world app = development app = qa app = production where in a real world example we would prefer to have the opposite which would work well with a single cluster as well
DEVELOPMENT CLUSTER namespace = development app = hello-world QA CLUSTER namespace = qa app = hello-world PRODUCTION CLUSTER namespace = production app = hello-world Having the namespace be the application and the apps be the environment, we wouldn't have the ability to upgrade to the latest version of kube without upgrading all. Maybe I'm missing something but based on what I'm reading and after testing this out, it looks as though this was the way it was designed.
For reference this is what my CI looks like right now to make the deploy board + terminal happy
development: <<: *deploy_definition stage: development environment: hello-world script: deploy.sh -a "hello-world" but it should look like this
development: <<: *deploy_definition stage: development environment: development script: deploy.sh -a "hello-world" To add to this confusion, they give you only one Kubernetes master to connect to in the integrations tab.
Is this correct, or am I missing something?
review/*environments andprodbut in your example it looks like you can only deploy to an environment with<project-name>