2017-11-27 00:44:32 +03:00
|
|
|
---
|
|
|
|
date: "2016-12-01T16:00:00+02:00"
|
|
|
|
title: "Installation from source"
|
|
|
|
slug: "install-from-source"
|
|
|
|
weight: 10
|
|
|
|
toc: true
|
|
|
|
draft: false
|
|
|
|
menu:
|
|
|
|
sidebar:
|
|
|
|
parent: "installation"
|
|
|
|
name: "From source"
|
|
|
|
weight: 30
|
|
|
|
identifier: "install-from-source"
|
|
|
|
---
|
|
|
|
|
|
|
|
# Installation from source
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
This section will not include basic [installation instructions](https://golang.org/doc/install).
|
2017-11-27 00:44:32 +03:00
|
|
|
|
2018-01-17 00:18:11 +03:00
|
|
|
**Note**: Go version 1.8 or higher is required
|
2017-11-27 00:44:32 +03:00
|
|
|
|
|
|
|
## Download
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
First retrieve the source code. The easiest way is to use the Go tool. Use the following
|
|
|
|
commands to fetch the source and switch into the source directory.
|
2017-11-27 00:44:32 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
go get -d -u code.gitea.io/gitea
|
|
|
|
cd $GOPATH/src/code.gitea.io/gitea
|
|
|
|
```
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
Decide which version of Gitea to build and install. Currently, there are multiple options
|
|
|
|
to choose from. The `master` branch represents the current development version. To build
|
|
|
|
with master, skip to the [build section](#build).
|
2017-11-27 00:44:32 +03:00
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
To work with tagged releases, the following commands can be used:
|
2017-11-27 00:44:32 +03:00
|
|
|
```
|
|
|
|
git branch -a
|
|
|
|
git checkout v1.0
|
|
|
|
```
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
To validate a Pull Request, first enable the new branch (`xyz` is the PR id; for example
|
|
|
|
`2663` for [#2663](https://github.com/go-gitea/gitea/pull/2663)):
|
2017-11-27 00:44:32 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
git fetch origin pull/xyz/head:pr-xyz
|
|
|
|
```
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
To build Gitea from source at a specific tagged release (like v1.0.0), list the available
|
|
|
|
tags and check out the specific tag.
|
|
|
|
|
|
|
|
List available tags with the following.
|
2017-11-27 00:44:32 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
git tag -l
|
2018-01-09 01:48:42 +03:00
|
|
|
git checkout v1.0.0 # or git checkout pr-xyz
|
2017-11-27 00:44:32 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
## Build
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
Since all required libraries are already bundled in the Gitea source, it's
|
|
|
|
possible to build Gitea with no additional downloads. Various
|
|
|
|
[make tasks](https://github.com/go-gitea/gitea/blob/master/Makefile) are
|
|
|
|
provided to keep the build process as simple as possible.
|
|
|
|
<a href='{{< relref "doc/advanced/make.en-us.md" >}}'>See here how to get Make</a>.
|
|
|
|
Depending on requirements, the following build tags can be included.
|
2017-11-27 00:44:32 +03:00
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
* `bindata`: Build a single monolithic binary, with all assets included.
|
2018-10-23 19:33:51 +03:00
|
|
|
* `sqlite sqlite_unlock_notify`: Enable support for a [SQLite3](https://sqlite.org/) database. Suggested only
|
2018-01-09 01:48:42 +03:00
|
|
|
for tiny installations.
|
|
|
|
* `tidb`: Enable support for a [TiDB](https://github.com/pingcap/tidb) database.
|
|
|
|
* `pam`: Enable support for PAM (Linux Pluggable Authentication Modules). Can be used to
|
|
|
|
authenticate local users or extend authentication to methods available to PAM.
|
2017-11-27 00:44:32 +03:00
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
Bundling assets into the binary using the `bindata` build tag can make development and
|
|
|
|
testing easier, but is not ideal for a production deployment. To include assets, they
|
|
|
|
must be built separately using the `generate` make task.
|
2017-11-27 00:44:32 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
TAGS="bindata" make generate build
|
|
|
|
```
|
|
|
|
|
|
|
|
## Test
|
|
|
|
|
2018-01-09 01:48:42 +03:00
|
|
|
After following the steps above a `gitea` binary will be available in the working directory.
|
|
|
|
It can be tested from this directory or moved to a directory with test data. When Gitea is
|
|
|
|
launched manually from command line, it can be killed by pressing `Ctrl + C`.
|
2017-11-27 00:44:32 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
./gitea web
|
|
|
|
```
|