This folder contains the deployment manifests for the Go language extension.
TLS/SSL is required for secure communication with the language server. Once you have completed "Configure TLS/SSL" in docs/configure.md, for your overall Sourcegraph instance, you'll need to configure TLS/SSL for the Go language server as well.
The Go language server needs its own domain (e.g. go.sourcegraph.example.com
), and an SSL certificate/key for that domain.
-
Create a TLS secret that contains your TLS certificate and private key for the Go language server.
kubectl create secret tls go-tls --key $PATH_TO_KEY --cert $PATH_TO_CERT
Update create-new-cluster.sh with the previous command.
echo kubectl create secret tls go-tls --key $PATH_TO_KEY --cert $PATH_TO_CERT >> create-new-cluster.sh
-
Add the above TLS configuration to configure/lang/go/lang-go.Ingress.yaml, making sure to use the real domain name that you are using for the Go language server.
spec: tls: - hosts: # 🚨 TLS is required for secure communication with the language server. # See the customization guide (../../../docs/configure.md) for information # about configuring TLS # # Make sure to replace 'go.sourcegraph.example.com' with the real domain that you are # using for the Go language server. - go.sourcegraph.example.com secretName: go-tls rules: - host: go.sourcegraph.example.com
WARNING: Do NOT commit the actual TLS cert and key files to your fork (unless your fork is private and you are okay with storing secrets in it).
HTTP basic authentication is used to prevent unauthorized access to the language server. At a high level, you'll create a secret then put it in both configure/lang/go/lang-go.Ingress.yaml and in your Sourcegraph global settings so that logged-in users are authenticated when their browser makes requests to the Go language server.
WARNING: 🚨 If your basic auth credentials are exposed, anyone with that credential now has unauthorized access to the language server and the code it operates on. Using an auth proxy, VPN, or firewall would provide more security. More information about these alternative methods will come at a later date. 🚨
These instructions are derived from https://kubernetes.github.io/ingress-nginx/examples/auth/basic/
-
Create an
.htpasswd
file in the current directory with one entry:> htpasswd -c auth langserveruser New password: Re-type new password: Adding password for user langserveruser
WARNING: Do NOT commit the actual
auth
password file to your fork (unless your fork is private and you are okay with storing secrets in it). -
Create a secret named
langserver-auth
from theauth
file that you just created> kubectl create secret generic langserver-auth --from-file=auth secret "basic-auth" created
Update create-new-cluster.sh with the previous command.
echo kubectl create secret generic langserver-auth --from-file=auth >> create-new-cluster.sh
-
Add the
kubectl
command that applies the Go language server configuration to kubectl-apply-all.shecho kubectl apply --prune -l deploy=lang-go -f configure/lang/go --recursive >> kubectl-apply-all.sh
-
Apply your changes to the cluster
./kubectl-apply-all.sh
Add the following fields to your Sourcegraph global settings ($PASSWORD
is the HTTP basic auth password that you created above, and $GO_DOMAIN_NAME
is the domain name that you are using for your Go language server instance):
"go.serverUrl": "wss://langserveruser:$PASSWORD@$GO_DOMAIN_NAME/",
"go.sourcegraphUrl": "http://sourcegraph-frontend:30080",
If you haven't setup SSL/TLS and HTTP basic authentication yet go.serverUrl
should look like this:
"go.serverUrl": "ws://$GO_DOMAIN_NAME"
Note that wss
has been changed to ws
.
If you choose not to expose the language server to the internet yet, you need to forward a local port to the language server so that your browser can connect to it:
kubectl port-forward svc/lang-go 9876:7777
Then your go.serverUrl
would look like this:
"go.serverUrl": "ws://localhost:9876"
By default, the Go language server uses a large amount of resources so that it's capable of handling large repositories like https://github.com/kubernetes/kubernetes/.
resources:
limits:
cpu: "8"
memory: 12Gi
requests:
cpu: "1"
memory: 11Gi
Feel free to lower these resource requests if you aren't adding large Go repositories to your Sourcegraph instance.