Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[installer] Make ws-manager-bridge configurable #9760

Merged
merged 2 commits into from
May 5, 2022

Conversation

andrew-farries
Copy link
Contributor

@andrew-farries andrew-farries commented May 4, 2022

Description

One of the Webapp team's epics for Q2 is to use the Gitpod installer to deploy to Gitpod SaaS. In order to do that we will need to add additional configuration to the installer to make the output suitable for a SaaS deployment as opposed to a self-hosted deployment.

This PR allows the ws-manager-bridge component to control whether or not it should register itself as a workspace cluster. For self hosted installations it should do so but for SaaS, where we run separate workspace clusters, it should not.

Related Issue(s)

Part of #9097

How to test

Create an installer config file containing this experimental section:

experimental:
  webapp:
    wsManagerBridge:
      skipSelf: true

Get a versions.yaml for use with the installer:

docker run -it --rm "eu.gcr.io/gitpod-core-dev/build/versions:${version}" cat versions.yaml > versions.yaml

Then invoke the installer as:

go run . render --debug-version-file versions.yaml --config /path/to/config --use-experimental-config

The ws-manager-bridge config will contain the following when skipSelf is false:

  ws-manager-bridge.json: |-
    {
      "installation": "default",
      "staticBridges": [
        {
          "name": "default",
          "url": "dns:///ws-manager:8080",
          "tls": {
            "ca": "/ws-manager-client-tls-certs/ca.crt",
            "crt": "/ws-manager-client-tls-certs/tls.crt",
            "key": "/ws-manager-client-tls-certs/tls.key"
          },
          "state": "available",
          "maxScore": 100,
          "score": 50,
          "govern": true,
          "admissionConstraints": null
        }
      ],

and the staticBridges key will be [] when skipSelf is true.

Likewise the WSMAN_CFG_MANAGERS env var in the server component will change according to the value of skipSelf (but the json is bas64 encoded).

Release Notes

Allow `ws-manager-bridge` service to skip registering itself as a workspace, via the installer.

Documentation

None.

Andrew Farries added 2 commits May 4, 2022 15:59
Ensure that no workspace clusters are returned when either skipSelf is
set or the installation is not a full one.
@andrew-farries andrew-farries force-pushed the af/installer-configure-ws-manager-bridge branch from 64abad4 to 6c622be Compare May 4, 2022 16:00
@andrew-farries andrew-farries marked this pull request as ready for review May 4, 2022 16:13
@andrew-farries andrew-farries requested review from a team May 4, 2022 16:14
@github-actions github-actions bot added team: delivery Issue belongs to the self-hosted team team: webapp Issue belongs to the WebApp team labels May 4, 2022
Copy link
Member

@geropl geropl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice 👍

@roboquat roboquat merged commit 02c2d26 into main May 5, 2022
@roboquat roboquat deleted the af/installer-configure-ws-manager-bridge branch May 5, 2022 07:45
@roboquat roboquat added the deployed: webapp Meta team change is running in production label May 5, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
deployed: webapp Meta team change is running in production release-note size/M team: delivery Issue belongs to the self-hosted team team: webapp Issue belongs to the WebApp team
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants