From 306249602780a4e8f4d67bc049f00f4f857f3edc Mon Sep 17 00:00:00 2001 From: "Alex Ellis (OpenFaaS Ltd)" Date: Sun, 6 Oct 2019 21:23:45 +0100 Subject: [PATCH] Use separate port for control-port on exit node Although this only occurs with KinD, I've changed the control port from the same as the data-plane to an alternative port. It appears to unblock KinD and fix an issue reported by a user. Fixes: #7 Signed-off-by: Alex Ellis (OpenFaaS Ltd) --- .github/ISSUE_TEMPLATE.md | 2 +- artifacts/operator-amd64.yaml | 2 +- controller.go | 26 ++++++++++++++------------ 3 files changed, 16 insertions(+), 14 deletions(-) diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md index 7173dfdb..3f9caca3 100644 --- a/.github/ISSUE_TEMPLATE.md +++ b/.github/ISSUE_TEMPLATE.md @@ -14,7 +14,7 @@ ## Steps to Reproduce (for bugs) - + 1. 2. 3. diff --git a/artifacts/operator-amd64.yaml b/artifacts/operator-amd64.yaml index bbbdffc8..f5d441e5 100644 --- a/artifacts/operator-amd64.yaml +++ b/artifacts/operator-amd64.yaml @@ -18,7 +18,7 @@ spec: serviceAccountName: inlets-operator containers: - name: operator - image: alexellis/inlets-operator:0.2.5 + image: alexellis/inlets-operator:0.2.5-rc1 imagePullPolicy: Always command: - ./inlets-operator diff --git a/controller.go b/controller.go index 4aa2ba7a..85749188 100644 --- a/controller.go +++ b/controller.go @@ -36,6 +36,7 @@ import ( ) const controllerAgentName = "sample-controller" +const inletsControlPort = 8080 const ( // SuccessSynced is used as part of the Event 'reason' when a Tunnel is synced @@ -537,8 +538,6 @@ func makeClient(tunnel *inletsv1alpha1.Tunnel, targetPort int32, clientImage str replicas := int32(1) name := tunnel.Name + "-client" - inletsServicePort := 80 - deployment := appsv1.Deployment{ ObjectMeta: metav1.ObjectMeta{ Name: name, @@ -574,7 +573,7 @@ func makeClient(tunnel *inletsv1alpha1.Tunnel, targetPort int32, clientImage str Args: []string{ "client", "--upstream=" + fmt.Sprintf("http://%s:%d", tunnel.Spec.ServiceName, targetPort), - "--remote=" + fmt.Sprintf("ws://%s:%d", tunnel.Status.HostIP, inletsServicePort), + "--remote=" + fmt.Sprintf("ws://%s:%d", tunnel.Status.HostIP, inletsControlPort), "--token=" + tunnel.Spec.AuthToken, }, }, @@ -672,16 +671,19 @@ func (c *Controller) handleObject(obj interface{}) { } func makeUserdata(authToken string) string { + controlPort := fmt.Sprintf("%d", inletsControlPort) + return `#!/bin/bash - export INLETSTOKEN="` + authToken + `" - - curl -sLS https://get.inlets.dev | sudo sh - - curl -sLO https://raw.githubusercontent.com/alexellis/inlets/master/hack/inlets.service && \ - mv inlets.service /etc/systemd/system/inlets.service && \ - echo "AUTHTOKEN=$INLETSTOKEN" > /etc/default/inlets && \ - systemctl start inlets && \ - systemctl enable inlets` +export INLETSTOKEN="` + authToken + `" +export CONTROLPORT="` + controlPort + `" +curl -sLS https://get.inlets.dev | sudo sh + +curl -sLO https://raw.githubusercontent.com/alexellis/inlets/master/hack/inlets-operator.service && \ + mv inlets-operator.service /etc/systemd/system/inlets.service && \ + echo "AUTHTOKEN=$INLETSTOKEN" > /etc/default/inlets && \ + echo "CONTROLPORT=$CONTROLPORT" > /etc/default/inlets && \ + systemctl start inlets && \ + systemctl enable inlets` } func hasIgnoreAnnotation(annotations map[string]string) bool {