Skip to content

Latest commit

 

History

History
224 lines (169 loc) · 10.8 KB

install.md

File metadata and controls

224 lines (169 loc) · 10.8 KB

Installation

Requirements

Install

Note: Sourcegraph sends performance and usage data to Sourcegraph to help us make our product better for you. The data sent does NOT include any source code or file data (including URLs that might implicitly contain this information). You can view traces and disable telemetry in the site admin area on the server.

Sourcegraph Data Center is deployed using Kubernetes. Before proceeding with these instructions, provision a Kubernetes cluster on the infrastructure of your choice. Make sure you have configured kubectl to access your cluster.

  1. 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
  2. Create a values.yaml file with the following contents:

    cluster:
      storageClass:
        create: {none,aws,gcp}
        name: $NAME
        zone: $ZONE
    site: {
      "auth.providers": [{"type": "builtin", "allowSignup": false}],
    }
    
    • If using Google Cloud, set cluster.storageClass.create to gcp and cluster.storageClass.zone to the zone of your cluster (e.g., us-west1-a). Delete the cluster.storageClass.name line.
    • If using AWS, set cluster.storageClass.create to aws and cluster.storageClass.zone to the zone of your cluster (e.g., us-east-1a). Delete the cluster.storageClass.name line.
    • If using Azure, set cluster.storageClass.create to none and set cluster.storageClass.name to managed-premium. Delete the cluster.storageClass.zone line.
    • If using anything else OR if you would prefer to provide your own storage class, set cluster.storageClass.create to none and delete cluster.storageClass.name and cluster.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".
  3. Examine the sample values.yaml in the deploy-sourcegraph repo for additional starting configuration values. Do not copy fields in if you don't need to change them; the values in your user-provided file are merged in on top of this file. The existing resource allocations are probably a reasonable starting point.

    If you find you've made errors, you can update values.yaml using helm upgrade; for more information, read about upgrading Sourcegraph Data Center.

  4. 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.

  5. Confirm that your deployment is launching by running kubectl get pods. If pods get stuck in Pending status, run kubectl 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. If you have enough volumes, but pods are still stuck, kubectl cluster-info dump (very verbose, dump it to a file) may have more information; for instance:

     "Reason": "FailedScheduling",
     "Message": "0/3 nodes are available: 1 Insufficient memory, 3 Insufficient cpu.",
    

    That could indicate failing to specify --machine-type=n1-standard-16. Google's default is n1-standard-1; this provides only single-CPU nodes, which are never able to satisfy requests for a 2-CPU node.

  6. 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. If you have multiple nodes, all the addresses should work interchangeably, because kube-proxy fakes that up for you. 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.

Add language servers for code intelligence

Code intelligence is a paid upgrade on top of the Data Center deployment option. After following these instructions to confirm it works, buy code intelligence.

Code intelligence provides advanced code navigation and cross-references for your code on Sourcegraph.

To enable code intelligence, add a site.langservers property to your values.yaml file specifying which language servers to run (omitting languages you don't want):

# values.yaml

site: {
    "langservers": [
        { "language": "go" },
        { "language": "javascript" },
        { "language": "typescript" },
        { "language": "python" },
        { "language": "java" },
        { "language": "php" }
    ]
}

After modifying values.yaml, update your cluster:

helm upgrade -f values.yaml sourcegraph https://github.com/sourcegraph/datacenter/archive/$VERSION.tar.gz

For more information,

  • Refer to the examples directory for an example of a cluster config with code intelligence enabled.
  • See the language-specific docs for configuring specific languages.
  • Contact us with questions or problems relating to code intelligence.

Additional configuration

You can set additional fields in values.yaml to configure your Sourcegraph instance. The values.yaml file is split into two top-level fields:

  • site defines Sourcegraph site configuration. For the full list of options, see "Sourcegraph site configuration options".
  • cluster defines settings specific to the configuration of the Kubernetes cluster, like replica counts and CPU/memory allocation. Refer to ../values.yaml in this repository to see which cluster fields can be overridden.

The default configuration is defined in this repository's top-level values.yaml.

For common site configuration tasks, see:

Troubleshooting

See the Troubleshooting page.

Install without RBAC

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, then

  • Set "site.rbac": "disabled" in your values.yaml
  • Run helm init instead of helm init --service-account tiller to install Tiller.

Install without 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

Creating a storage class manually

If cluster.storageClass.create is set to none, then you will need to create a storage class manually:

  1. 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 in cluster.storageClass.name ("default" by default). We recommend specifying SSDs as the disk type if possible.
  2. Run kubectl apply -f storage-class.yaml.
  3. 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.

Secrets

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 "cluster.gitserver.ssh.known_hosts"="$(cat known_hosts)" \
    https://github.com/sourcegraph/datacenter/archive/latest.tar.gz