2018-10-07 20:43:15 +02:00
Developer Information
#####################
Reproducible Builds
***** ***** ***** *** *
This section describes how to reproduce the official released binaries for
2020-09-30 16:44:25 +02:00
restic for version 0.10.0 and later. For restic versions down to 0.9.3 please
refer to the documentation for the respective version. The binary produced
depends on the following things:
2018-10-07 20:43:15 +02:00
* The source code for the release
* The exact version of the official `Go compiler <https://golang.org> `__ used to produce the binaries (running `` restic version `` will print this)
* The architecture and operating system the Go compiler runs on (Linux, `` amd64 `` )
2021-09-11 18:00:18 -07:00
* The build tags (for official binaries, it's the tag `` selfupdate `` )
2018-10-07 20:43:15 +02:00
* The path where the source code is extracted to (`` /restic `` )
* The path to the Go compiler (`` /usr/local/go `` )
2021-09-11 18:00:18 -07:00
* The path to the Go workspace (`` GOPATH=/home/build/go `` )
* Other environment variables (mostly `` $GOOS `` , `` $GOARCH `` , `` $CGO_ENABLED `` )
2018-10-07 20:43:15 +02:00
In addition, The compressed ZIP files for Windows depends on the modification
2020-09-30 16:45:26 +02:00
timestamp and filename of the binary contained in it. In order to reproduce the
exact same ZIP file every time, we update the timestamp of the file `` VERSION ``
in the source code archive and set the timezone to Europe/Berlin.
2018-10-07 20:43:15 +02:00
2022-11-26 12:08:31 +01:00
In the following example, we'll use the file `` restic-0.14.0.tar.gz `` and Go
1.19 to reproduce the released binaries.
2018-10-07 20:43:15 +02:00
2020-09-30 16:44:25 +02:00
1. Determine the Go compiler version used to build the released binaries, then download and extract the Go compiler into `` /usr/local/go `` :
2018-10-07 20:43:15 +02:00
.. code ::
2020-09-30 16:44:25 +02:00
$ restic version
2022-11-26 12:08:31 +01:00
restic 0.14.0 compiled with go1.19 on linux/amd64
2018-10-13 12:53:01 +02:00
$ cd /usr/local
2022-11-26 12:08:31 +01:00
$ curl -L https://dl.google.com/go/go1.19.linux-amd64.tar.gz | tar xz
2018-10-07 20:43:15 +02:00
2. Extract the restic source code into `` /restic ``
.. code ::
2018-10-13 12:53:01 +02:00
$ mkdir /restic
$ cd /restic
2022-11-26 12:08:31 +01:00
$ TZ=Europe/Berlin curl -L https://github.com/restic/restic/releases/download/v0.14.0/restic-0.14.0.tar.gz | tar xz --strip-components=1
2018-10-07 20:43:15 +02:00
3. Build the binaries for Windows and Linux:
.. code ::
$ export PATH=/usr/local/go/bin:$PATH
2021-09-11 18:00:18 -07:00
$ export GOPATH=/home/build/go
2018-10-07 20:43:15 +02:00
$ go version
2022-11-26 12:08:31 +01:00
go version go1.19 linux/amd64
2018-10-07 20:43:15 +02:00
2020-03-01 11:32:36 +01:00
$ GOOS=linux GOARCH=amd64 CGO_ENABLED=0 go build -ldflags "-s -w" -tags selfupdate -o restic_linux_amd64 ./cmd/restic
2018-10-07 20:43:15 +02:00
$ bzip2 restic_linux_amd64
2022-11-26 12:08:31 +01:00
$ GOOS=windows GOARCH=amd64 CGO_ENABLED=0 go build -ldflags "-s -w" -tags selfupdate -o restic_0.14.0_windows_amd64.exe ./cmd/restic
$ touch --reference VERSION restic_0.14.0_windows_amd64.exe
$ TZ=Europe/Berlin zip -q -X restic_0.14.0_windows_amd64.zip restic_0.14.0_windows_amd64.exe
2018-10-13 12:53:01 +02:00
Building the Official Binaries
***** ***** ***** ***** ***** *****
The released binaries for restic are built using a Docker container. You can
find it on `Docker Hub <https://hub.docker.com/r/restic/builder> `__ as
`` restic/builder `` , the `` Dockerfile `` and instructions on how to build the
container can be found in the `GitHub repository
<https://github.com/restic/builder> `__
The container serves the following goals:
* Have a very controlled environment which is independent from the local system
* Make it easy to have the correct version of the Go compiler at the right path
* Make it easy to pass in the source code to build at a well-defined path
The following steps are necessary to build the binaries:
1. Either build the container (see the instructions in the `repository's README <https://github.com/restic/builder> `__ ). Alternatively, download the container from the hub:
.. code ::
docker pull restic/builder
2. Extract the source code somewhere:
.. code ::
2022-11-26 12:08:31 +01:00
tar xvzf restic-0.14.0.tar.gz
2018-10-13 12:53:01 +02:00
3. Create a directory to place the resulting binaries in:
.. code ::
mkdir output
3. Mount the source code and the output directory in the container and run the default command, which starts `` helpers/build-release-binaries/main.go `` :
.. code ::
docker run --rm \
2022-11-26 12:08:31 +01:00
--volume "$PWD/restic-0.14.0:/restic" \
2018-10-13 12:53:01 +02:00
--volume "$PWD/output:/output" \
2020-09-30 16:45:26 +02:00
restic/builder \
2022-11-26 12:08:31 +01:00
go run helpers/build-release-binaries/main.go --version 0.14.0
2018-10-13 12:53:01 +02:00
2020-09-30 16:45:26 +02:00
4. If anything goes wrong, you can enable debug output like this:
2018-10-13 12:53:01 +02:00
.. code ::
docker run --rm \
2022-11-26 12:08:31 +01:00
--volume "$PWD/restic-0.14.0:/restic" \
2018-10-13 12:53:01 +02:00
--volume "$PWD/output:/output" \
restic/builder \
2022-11-26 12:08:31 +01:00
go run helpers/build-release-binaries/main.go --version 0.14.0 --verbose
2018-10-13 12:53:01 +02:00
Prepare a New Release
***** ***** ***** ***** *
Publishing a new release of restic requires many different steps. We've
automated this in the Go program `` helpers/prepare-release/main.go `` which also
includes checking that e.g. the changelog is correctly generated. The only
required argument is the new version number (in `Semantic Versioning
<https://semver.org/> `__ format ` `MAJOR.MINOR.PATCH` `):
.. code ::
2022-11-26 12:08:31 +01:00
go run helpers/prepare-release/main.go 0.14.0
2018-10-13 12:53:01 +02:00
Checks can be skipped on demand via flags, please see `` --help `` for details.