zola/docs/content/documentation/getting-started/installation.md

167 lines
3.9 KiB
Markdown
Raw Normal View History

2017-09-12 07:13:26 +00:00
+++
title = "Installation"
weight = 10
2017-09-12 07:13:26 +00:00
+++
2018-10-18 21:09:32 +00:00
Zola provides pre-built binaries for MacOS, Linux and Windows on the
[GitHub release page](https://github.com/getzola/zola/releases).
2018-11-19 22:46:49 +00:00
### macOS
2018-11-19 22:46:49 +00:00
Zola is available on [Brew](https://brew.sh):
2017-10-16 13:22:47 +00:00
```sh
2018-11-19 22:46:49 +00:00
$ brew install zola
```
2021-07-21 11:11:51 +00:00
Zola is also available on [MacPorts](https://www.macports.org):
```sh
$ sudo port install zola
```
### Arch Linux
Zola is available in the official Arch Linux repositories.
2017-10-16 13:22:47 +00:00
```sh
$ pacman -S zola
2017-10-21 07:48:29 +00:00
```
### Alpine Linux
Zola is available in the official Alpine Linux repository, only on the `edge` version for now.
```sh
$ apk add zola --repository http://dl-cdn.alpinelinux.org/alpine/edge/community/
```
### Debian
Zola is available over at [barnumbirr/zola-debian](https://github.com/barnumbirr/zola-debian).
Grab the latest `.deb` for your Debian version then simply run:
```sh
$ sudo dpkg -i zola_<version>_amd64_debian_<debian_version>.deb
```
### Fedora
Zola has been available in the official repositories since Fedora 29.
```sh
$ sudo dnf install zola
```
### Void Linux
Zola is available in the official Void Linux repositories.
```sh
$ sudo xbps-install zola
```
### FreeBSD
Zola is available in the official package repository.
```sh
$ pkg install zola
```
### OpenBSD
Zola is available in the official package repository.
```sh
$ doas pkg_add zola
```
### Snapcraft
Zola is available on snapcraft:
2017-10-16 13:22:47 +00:00
```sh
$ snap install --edge zola
2017-10-16 13:22:47 +00:00
```
2021-02-03 13:59:45 +00:00
### Docker
Zola is available on [Docker Hub](https://hub.docker.com/r/balthek/zola).
It has no `latest` tag, you will need to specify a [specific version to pull](https://hub.docker.com/r/balthek/zola/tags).
```sh
$ docker pull balthek/zola:0.14.0
$ docker run balthek/zola:0.14.0 --version
2021-02-03 13:59:45 +00:00
```
#### Build
```sh
$ docker run -u "$(id -u):$(id -g)" -v $PWD:/app --workdir /app balthek/zola:0.14.0 build
2021-02-03 13:59:45 +00:00
```
#### Serve
```sh
$ docker run -u "$(id -u):$(id -g)" -v $PWD:/app --workdir /app -p 8080:8080 balthek/zola:0.14.0 serve --interface 0.0.0.0 --port 8080 --base-url localhost
2021-02-03 13:59:45 +00:00
```
You can now browse http://localhost:8080.
> To enable live browser reload, you may have to bind to port 1024. Zola searches for an open
> port between 1024 and 9000 for live reload. The new docker command would be
> `$ docker run -u "$(id -u):$(id -g)" -v $PWD:/app --workdir /app -p 8080:8080 -p 1024:1024 balthek/zola:0.14.0 serve --interface 0.0.0.0 --port 8080 --base-url localhost`
## Windows
Zola is available on [Scoop](https://scoop.sh):
```sh
$ scoop install zola
```
and [Chocolatey](https://chocolatey.org/):
2018-09-18 10:13:00 +00:00
```sh
$ choco install zola
```
Zola does not work in PowerShell ISE.
## From source
2021-11-25 08:15:00 +00:00
To build Zola from source, you will need to have Git, [Rust and Cargo](https://www.rust-lang.org/)
installed. You will also need to meet additional dependencies to compile [libsass](https://github.com/sass/libsass):
- OSX, Linux and other Unix-like operating systems: `make` (`gmake` on BSDs), `g++`, `libssl-dev`
- NixOS: Create a `shell.nix` file in the root of the cloned project with the following contents:
```nix
with import <nixpkgs> {};
pkgs.mkShell {
buildInputs = [
libsass
openssl
pkgconfig
];
}
```
- Then, invoke `nix-shell`. This opens a shell with the above dependencies. Then, run `cargo build --release` to build the project.
- Windows (a bit trickier): updated `MSVC` and overall updated VS installation
From a terminal, you can now run the following command:
```sh
$ cargo build --release
```
If you encountered compilation errors like `error: failed to run custom build command for 'ring v0.16.20'`, you can try the command below instead:
```sh
$ cargo build --release --no-default-features --features=native-tls
```
The binary will be available in the `target/release` directory. You can move it in your `$PATH` to have the
`zola` command available globally or in a directory if you want for example to have the binary in the
same repository as the site.