Learn how to interact with the SIP as ISG supporter or OIV, both called operators.
Concepts
{"extSrvIntegType":"","gClientId":"","creatorName":"Fabian Fischer","outputType":"block","lastModifierName":"Fabian Fischer","language":"de","uiConfig":"{\"defaultFonts\":[\"Source Sans Pro Light\",\"Source Sans Pro\",\"Helvetica\",\"Verdana\",\"Times New Roman\",\"Garamond\",\"Comic Sans MS\",\"Courier New\",\"Georgia\",\"Lucida Console\",\"Tahoma\"],\"customPresetColors\":[\"009FE3\",\"f03a47\",\"af5b5b\",\"f6f4f3\",\"183059\"],\"presetColors\":[\"E6D0DE\",\"CDA2BE\",\"B5739D\",\"E1D5E7\",\"C3ABD0\",\"A680B8\",\"D4E1F5\",\"A9C4EB\",\"7EA6E0\",\"D5E8D4\",\"9AC7BF\",\"67AB9F\",\"D5E8D4\",\"B9E0A5\",\"97D077\",\"FFF2CC\",\"FFE599\",\"FFD966\",\"FFF4C3\",\"FFCE9F\",\"FFB570\",\"F8CECC\",\"F19C99\",\"EA6B66\"],\"defaultColorSchemes\":[[\"vseth\",{\"fill\":\"#f5f5f5\",\"stroke\":\"#666666\"},{\"fill\":\"#009FE3\",\"stroke\":\"#0077aa\"},{\"fill\":\"#f03a47\",\"stroke\":\"#af2b34\"},{\"fill\":\"#af5b5b\",\"stroke\":\"#703b3b\"},{\"fill\":\"#f6f4f3\",\"stroke\":\"#B8B7B6\"},{\"fill\":\"#183059\",\"stroke\":\"#0f1e38\"},{\"fill\":\"#D5E8D4\",\"stroke\":\"#82B366\"}],[null,{\"fill\":\"#f5f5f5\",\"stroke\":\"#666666\"},{\"fill\":\"#dae8fc\",\"stroke\":\"#6c8ebf\"},{\"fill\":\"#d5e8d4\",\"stroke\":\"#82b366\"},{\"fill\":\"#ffe6cc\",\"stroke\":\"#d79b00\"},{\"fill\":\"#fff2cc\",\"stroke\":\"#d6b656\"},{\"fill\":\"#f8cecc\",\"stroke\":\"#b85450\"},{\"fill\":\"#e1d5e7\",\"stroke\":\"#9673a6\"}],[null,{\"fill\":\"#f5f5f5\",\"stroke\":\"#666666\"},{\"fill\":\"#dae8fc\",\"stroke\":\"#6c8ebf\"},{\"fill\":\"#d5e8d4\",\"stroke\":\"#82b366\"},{\"fill\":\"#ffe6cc\",\"stroke\":\"#d79b00\"},{\"fill\":\"#fff2cc\",\"stroke\":\"#d6b656\"},{\"fill\":\"#f8cecc\",\"stroke\":\"#b85450\"},{\"fill\":\"#e1d5e7\",\"stroke\":\"#9673a6\"}],[null,{\"fill\":\"#f5f5f5\",\"stroke\":\"#666666\",\"gradient\":\"#b3b3b3\"},{\"fill\":\"#dae8fc\",\"stroke\":\"#6c8ebf\",\"gradient\":\"#7ea6e0\"},{\"fill\":\"#d5e8d4\",\"stroke\":\"#82b366\",\"gradient\":\"#97d077\"},{\"fill\":\"#ffcd28\",\"stroke\":\"#d79b00\",\"gradient\":\"#ffa500\"},{\"fill\":\"#fff2cc\",\"stroke\":\"#d6b656\",\"gradient\":\"#ffd966\"},{\"fill\":\"#f8cecc\",\"stroke\":\"#b85450\",\"gradient\":\"#ea6b66\"},{\"fill\":\"#e6d0de\",\"stroke\":\"#996185\",\"gradient\":\"#d5739d\"}],[null,{\"fill\":\"#eeeeee\",\"stroke\":\"#36393d\"},{\"fill\":\"#f9f7ed\",\"stroke\":\"#36393d\"},{\"fill\":\"#ffcc99\",\"stroke\":\"#36393d\"},{\"fill\":\"#cce5ff\",\"stroke\":\"#36393d\"},{\"fill\":\"#ffff88\",\"stroke\":\"#36393d\"},{\"fill\":\"#cdeb8b\",\"stroke\":\"#36393d\"},{\"fill\":\"#ffcccc\",\"stroke\":\"#36393d\"}]],\"fontCss\":\"@font-face{ font-family: \u0027Source Sans Pro Light\u0027; font-weight: 300; font-style: normal; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-Light.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-Light.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-Light.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-Light.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro Light\u0027; font-weight: 300; font-style: italic; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-LightIt.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-LightIt.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-LightIt.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-LightIt.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro\u0027; font-weight: 400; font-style: normal; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-Regular.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-Regular.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-Regular.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-Regular.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro\u0027; font-weight: 400; font-style: italic; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-It.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-It.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-It.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-It.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro Light\u0027; font-weight: 600; font-style: normal; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-Semibold.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-Semibold.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-Semibold.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-Semibold.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro Light\u0027; font-weight: 600; font-style: italic; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-SemiboldIt.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-SemiboldIt.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-SemiboldIt.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-SemiboldIt.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro\u0027; font-weight: 700; font-style: normal; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-Bold.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-Bold.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-Bold.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-Bold.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro\u0027; font-weight: 700; font-style: italic; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-BoldIt.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-BoldIt.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-BoldIt.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-BoldIt.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro\u0027; font-weight: 900; font-style: normal; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-Black.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-Black.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-Black.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-Black.ttf\u0027) format(\u0027truetype\u0027); } @font-face{ font-family: \u0027Source Sans Pro\u0027; font-weight: 900; font-style: italic; font-stretch: normal; src: url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF2/TTF/SourceSansPro-BlackIt.ttf.woff2\u0027) format(\u0027woff2\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/WOFF/OTF/SourceSansPro-BlackIt.otf.woff\u0027) format(\u0027woff\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/OTF/SourceSansPro-BlackIt.otf\u0027) format(\u0027opentype\u0027), url(\u0027https://static.vseth.ethz.ch/npm/source-sans-pro@3.6.0/TTF/SourceSansPro-BlackIt.ttf\u0027) format(\u0027truetype\u0027); }\",\"version\":\"1.4\"}","diagramDisplayName":"","sFileId":"","attId":"15925577","diagramName":"concepts","aspect":"","links":"auto","ceoName":"SIP","tbstyle":"top","canComment":false,"diagramUrl":"","csvFileUrl":"","border":true,"maxScale":"1","owningPageId":8552462,"editable":false,"ceoId":8552462,"pageId":"","lbox":true,"serverConfig":{"emailpreview":"1"},"odriveId":"","revision":1,"macroId":"afaa3e81-fc52-4320-abc2-e6ed182d38d1","previewName":"concepts.png","licenseStatus":"OK","service":"","isTemplate":"","width":"417","simpleViewer":false,"lastModified":1586950844410,"exceedPageWidth":false,"oClientId":""}
We introduce two concepts: Applications and Deployments. All interaction with an SIP cluster is through sipctl and the VCS. Some day all this will be done via the Gatekeeper web UI.
Application
An SIP application bundles a gitlab repository with a branch and commit hash, a docker image and the configuration from sip.yml. All application definitions go to the *-apps namespace of your organisation (e.g. amiv-apps). Applications are not runnable by themselves.
SIP cares about stability of applications. It can happen frequently that the commit hash of the application changes in order to automatically install updates. Those updates have to maintain backward compatibility. If an incompatible change is to be released, this is done by creating a new application from the existing one and changing the branch and commit hash of the release to the new version.
Deployment
An application can be deployed into a namespace which creates an SIP deployment (something different from a Kubernetes Deployment if you know this). The SIP infrastructure will then automatically instantiate Kubernetes resources to finally start the application's container.
While the application can change arbitrarily, often and is mostly under the control of the developers of the application, deployments are controlled by the OIVs. They choose whether they want to automatically follow all updates of the application (auto-update) or stay on a fixed commit hash until the OIV triggers a manual update.
Gatekeeper
This is the planned GUI frontend application for all interactions with SIP for an operator. Here you will be able to manage your applications and deployments. It talks directly with the SIP API and does not interact with the cluster directly.
This is a command-line tool to interact with SIP. It is meant to support the same tasks as Gatekeeper.
Installation
Download the tool and make sure it is executable in your shell.
Put the following content into ~/.config/vseth/sipctl/config.yml
$ mkdir -p ~/.config/vseth/sipctl/
endpoints:
- domain: api.vseth-k8s-redzone.vseth.ethz.ch:443
registry: eu.gcr.io/aerial-reef-202214
If you know what our Greenzone is and you need to interact with it, use this config. .
endpoints:
- domain: api.k8s-eth.vseth.ethz.ch:443
registry: eu.gcr.io/aerial-reef-202214
Both gatekeeper and sipctl interact with an application inside the kubernetes cluster called the sip-api. It transforms user requests into kubernetes resources of deployments, applications and other internal resources. It runs as container inside kubernetes.
sipctl
See above
The primary tool to interact with a kubernetes cluster. To maintain your cluster, better get used it. You can view the cluster status, including all resources of Kubernetes and SIP. You can access logs and metrics of containers. You can add and delete all kubernetes resources with it.
To get access to a cluster, put the corresponding kubeconfig into ~/.kube/config
Redzone Cluster: Install the google cloud SDK on your machine and follow the instructions here
Greenzone Cluster: Copy the kubeconfig from root@k8s-eth.vseth.ethz.ch:/etc/rancher/k3s/k3s.yaml
to your machine. Then replace the string "localhost" with "k8s-eth.vseth.ethz.ch" in the kubeconfig.
A template engine to apply kubernetes manifests automatically. We use it for cluster-level management tasks, see the charts repo.