Sourcegraph Data Center is deployed using Kubernetes. Before proceeding with these instructions, provision a Kubernetes cluster on the infrastructure of your choice.
-
Install Tiller with RBAC privileges (the server-side counterpart to Helm) on your cluster:
# Give Helm privileges to create RBAC resources. kubectl create serviceaccount --namespace kube-system tiller kubectl create clusterrolebinding tiller --clusterrole=cluster-admin --serviceaccount=kube-system:tiller # Add Helm to your cluster using the created service account. helm init --service-account tiller
- If installing Tiller is not an option, consult the instructions below for installing without Tiller.
- If your Kubernetes environment does not permite RBAC, consult the instructions below for installing without RBAC.
-
Create a
values.yaml
file with the following contents:cluster: storageClass: create: {none,aws,gcp} name: $NAME zone: $ZONE site: {}
- If using Google Cloud, set
cluster.storageClass.create
togcp
andcluster.storageClass.zone
to the zone of your cluster (e.g.,us-west1-a
). Delete thecluster.storageClass.name
line. - If using AWS, set
cluster.storageClass.create
toaws
andcluster.storageClass.zone
to the zone of your cluster (e.g.,us-east-1a
). Delete thecluster.storageClass.name
line. - If using Azure, set
cluster.storageClass.create
tonone
and setcluster.storageClass.name
tomanaged-premium
. Delete thecluster.storageClass.zone
line. - If using anything else OR if you would prefer to provide your own storage class, set
cluster.storageClass.create
tonone
and deletecluster.storageClass.name
andcluster.storageClass.zone
. Now create a storage class in your Kubernetes cluster with name "default". We recommend that the storage class use SSDs as the underlying disk type. For more info, see the section below on "creating a storage class manually".
- If using Google Cloud, set
-
Install the Helm chart to your cluster:
helm install --name sourcegraph -f values.yaml https://github.com/sourcegraph/datacenter/archive/latest.tar.gz
If you see the error
could not find a ready tiller pod
, wait a minute and try again. -
Confirm that your deployment is launching by running
kubectl get pods
. If pods get stuck inPending
status, runkubectl get pv
to check if the necessary volumes have been provisioned (you should see at least 4). Google Cloud Platform users may need to request an increase in storage quota. -
When the deployment completes, you need to make the main web server accessible over the network to external users. To do so, connect port 30080 (or the value of
httpNodePort
in the site config) on the nodes in the cluster to the Internet. The easiest way to do this is to add a network rule that allows ingress traffic to port 30080 on at least one node (see AWS Security Group rules, Google Cloud Platform Firewall rules). Sourcegraph should then be accessible at$EXTERNAL_ADDR_OF_YOUR_NODE:30080
. For production environments, we recommend using an Internet Gateway (or equivalent) and configuring a load balancer in Kubernetes.
You will now see the Sourcegraph setup page when you visit the address of your instance. If you made your instance accessible on the public Internet, make sure you secure it before adding your private repositories.
Sourcegraph Data Center communicates with the Kubernetes API for service discovery. It also has some janitor DaemonSets that clean up temporary cache data. To do that we need to create RBAC resources. For details, see Helm's Role-based Access Control documentation.
If using RBAC is not an option, you can set "site.rbac": "disabled"
in your values.yaml
and run helm init
instead of
helm init --service-account tiller
to install Tiller.
If installing Tiller is not an option, you can locally generate the Kubernetes configuration by running the following:
mkdir -p generated
wget https://github.com/sourcegraph/datacenter/archive/latest.tar.gz && helm template -f values.yaml latest.tar.gz --output-dir=generated
kubectl apply -R -f generated/sourcegraph/templates
If cluster.storageClass.create
is set to none
, then you will need to create a storage class manually:
- Create a file called
storage-class.yaml
that meets the requirements described in the Kubernetes docs. The name of the storage class should match the name set incluster.storageClass.name
("default" by default). We recommend specifying SSDs as the disk type if possible. - Run
kubectl apply -f storage-class.yaml
. - You should see the storage class appear when you run
kubectl get storageclass
.
After installing the Sourcegraph Helm chart, you should see persistent volume claims (kubectl get pvc
) bound to
volumes provisioned using this storage class.
You can set additional values in values.yaml
to configure your cluster. The default set of configuration values is
defined by the values.yaml
file in this directory.
The configuration structure is split into two top-level fields:
site
defines application-level settings like code host integrations and authentication settings. The full set of options forsite
is described here: https://about.sourcegraph.com/docs/config/settings.cluster
defines settings specific to the configuration of the Kubernetes cluster, like replica counts and CPU/memory allocation. Refer to thevalues.yaml
in this repository to see whichcluster
fields can be overridden.
In some cases, it is desirable to set config fields to the contents of external files. The Helm CLI
supports this with the --set
flag. For example, if you had an AWS Code Commit access key and a SSH
known_hosts
file, you could use the following command to incorporate these values into the config
while deploying:
helm install --name sourcegraph -f values.yaml \
--set "site.awsCodeCommit[0].secretAccessKey"="$(cat secretAccessKeyFile)" \
--set "site.gitserverSSH.known_hosts"="$(cat known_hosts)" \
https://github.com/sourcegraph/datacenter/archive/latest.tar.gz