Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ckulka/baikal-docker
Provides a ready-to-go Baikal server, incl. docker-compose.yml & Systemd service file
https://github.com/ckulka/baikal-docker
amd64 apache arm32v7 arm64v8 baikal baikal-server docker docker-image dockerfile i386 multi-arch multi-arch-images multi-arch-support nginx
Last synced: about 1 month ago
JSON representation
Provides a ready-to-go Baikal server, incl. docker-compose.yml & Systemd service file
- Host: GitHub
- URL: https://github.com/ckulka/baikal-docker
- Owner: ckulka
- License: mit
- Created: 2015-06-25T22:59:26.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-09-17T09:20:11.000Z (3 months ago)
- Last Synced: 2024-09-17T11:55:06.228Z (3 months ago)
- Topics: amd64, apache, arm32v7, arm64v8, baikal, baikal-server, docker, docker-image, dockerfile, i386, multi-arch, multi-arch-images, multi-arch-support, nginx
- Language: Dockerfile
- Homepage: https://hub.docker.com/r/ckulka/baikal
- Size: 376 KB
- Stars: 326
- Watchers: 5
- Forks: 46
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-homelab - Baikal - docker?style=flat) ![Baikal](https://img.shields.io/github/languages/top/ckulka/baikal-docker?style=flat) | Provides a ready-to-go Baikal server, incl. docker-compose.yml & Systemd service file | (Apps / Syncing)
- jimsghstars - ckulka/baikal-docker - Provides a ready-to-go Baikal server, incl. docker-compose.yml & Systemd service file (Dockerfile)
README
# Baikal
[![Latest images](https://github.com/ckulka/baikal-docker/actions/workflows/build-latest.yaml/badge.svg)](https://github.com/ckulka/baikal-docker/actions/workflows/build-latest.yaml) [![Experimental images](https://github.com/ckulka/baikal-docker/actions/workflows/build-experimental.yaml/badge.svg)](https://github.com/ckulka/baikal-docker/actions/workflows/build-experimental.yaml) ![Docker Pulls](https://img.shields.io/docker/pulls/ckulka/baikal) ![Docker Architectures](https://img.shields.io/badge/arch-amd64%20%7C%20arm32v7%20%7C%20arm64v8%20%7C%20i386-informational)
This dockerfile provides a ready-to-go [Baikal server](http://sabre.io/baikal/).
For more details, see [ckulka/baikal-docker (GitHub)](https://github.com/ckulka/baikal-docker).
## Supported tags and respective Dockerfile links
Tags without a version are [weekly re-builds](https://github.com/ckulka/baikal-docker/actions/workflows/build-latest.yaml) to include the latest base image with the most recent updates:
- `latest` and `apache` are re-builds of the latest `*-apache` version
- `apache-php8.2` are re-builds of the latest `*-apache-php8.2` version
- `nginx` are re-builds of the latest `*-nginx` version
- `nginx-php8.2` are re-builds of the latest `*-nginx-php8.2` versionI follow the same version naming scheme as [Baikal](http://sabre.io/baikal/) themselves.
The following tags support multiple architectures, e.g. `amd64`, `arm32v7`, `arm64v8` and `i386`.
- [`0.9.5`, `0.9.5-apache`](https://github.com/ckulka/baikal-docker/blob/0.9.5/apache.dockerfile)
- [`0.9.5-apache-php8.2`, `0.9.5-php8.2`](https://github.com/ckulka/baikal-docker/blob/0.9.5/apache-php8.2.dockerfile)
- [`0.9.5-nginx`](https://github.com/ckulka/baikal-docker/blob/0.9.5/nginx.dockerfile)
- [`0.9.5-nginx-php8.2`](https://github.com/ckulka/baikal-docker/blob/0.9.5/nginx-php8.2.dockerfile)
- [`0.9.4`, `0.9.4-apache`](https://github.com/ckulka/baikal-docker/blob/0.9.4+msmtpfix/apache.dockerfile)
- [`0.9.4-php8.0`, `0.9.4-apache-php8.0`, `apache-php8.0`, `latest-php8.0`](https://github.com/ckulka/baikal-docker/blob/0.9.4+msmtpfix/apache-php8.0.dockerfile)
- [`0.9.4-nginx`](https://github.com/ckulka/baikal-docker/blob/0.9.4+msmtpfix/nginx.dockerfile)
- [`0.9.4-nginx-php8.0`, `nginx-php8.0`](https://github.com/ckulka/baikal-docker/blob/0.9.4+msmtpfix/nginx-php8.0.dockerfile)
- [`0.9.3`, `0.9.3-apache`](https://github.com/ckulka/baikal-docker/blob/0.9.3+msmtp/apache.dockerfile)
- [`0.9.3-php8.0`, `0.9.3-apache-php8.0`](https://github.com/ckulka/baikal-docker/blob/0.9.3+msmtp/apache-php8.0.dockerfile)
- [`0.9.3-nginx`](https://github.com/ckulka/baikal-docker/blob/0.9.3+msmtp/nginx.dockerfile)
- [`0.9.3-nginx-php8.0`](https://github.com/ckulka/baikal-docker/blob/0.9.3+msmtp/nginx-php8.0.dockerfile)For earlier versions all the way back to version 0.2.7, please search in the [tags](https://hub.docker.com/r/ckulka/baikal/tags) tab. Version 0.4.5 and older are only available for `amd64`. Version 0.9.0 and older do not support `i386`.
## Quick reference
- **Where to file issues**:
[https://github.com/ckulka/baikal-docker/issues](https://github.com/ckulka/baikal-docker/issues)
- **Supported architectures** ([more info](https://github.com/docker-library/official-images#architectures-other-than-amd64)):
`amd64`, `arm32v7`, `arm64v8`, `i386`
- **Image updates**:
[PRs for ckulka/baikal-docker](https://github.com/ckulka/baikal-docker/pulls)
- **Source of this description**:
[https://github.com/ckulka/baikal-docker](https://github.com/ckulka/baikal-docker)## What is Baikal?
From [sabre.io/baikal](http://sabre.io/baikal/):
> Baikal is a Cal and CardDAV server, based on sabre/dav, that includes an administrative interface for easy management.
>
> For more information, read the main website at baikal-server.com.
>
> Baikal is developed by Net Gusto and fruux.## How to use this image
The following command will start Baikal:
```bash
docker run --rm -it -p 80:80 ckulka/baikal:nginx
```Alternatively, use the provided [examples/docker-compose.yaml](https://github.com/ckulka/baikal-docker/blob/master/examples/docker-compose.yaml) from the Git repository:
```bash
docker compose up
```You can now open [http://localhost](http://localhost) or [http://host-ip](http://host-ip) in your browser and use Baikal.
### Persistent Data
The image exposes the `/var/www/baikal/Specific` and `/var/www/baikal/config` folders, which contain the persistent data. These folders should be part of a regular backup.
If you want to use local folders instead of Docker volumes, see [examples/docker-compose.localvolumes.yaml](https://github.com/ckulka/baikal-docker/blob/master/examples/docker-compose.localvolumes.yaml) to avoid file permission issues.
When the container starts, the startup script `/docker-entrypoint.d/40-fix-baikal-file-permissions.sh` ([Apache httpd](https://github.com/ckulka/baikal-docker/blob/master/files/docker-entrypoint.d/httpd/40-fix-baikal-file-permissions.sh), [nginx](https://github.com/ckulka/baikal-docker/blob/master/files/docker-entrypoint.d/nginx/40-fix-baikal-file-permissions.sh)) ensures that the file permissions are correct. You can disable this behaviour by setting the environment variable `BAIKAL_SKIP_CHOWN` to any value, e.g. `FALSE`.
### Further Guides
You can find more installation and configuration guides here:
- [Email Guide](https://github.com/ckulka/baikal-docker/blob/master/docs/email-guide.md)
- [SSL Certificate Guide](https://github.com/ckulka/baikal-docker/blob/master/docs/ssl-certificates-guide.md)
- [systemd Guide](https://github.com/ckulka/baikal-docker/blob/master/docs/systemd-guide.md)
- [Unraid Installation Guide](https://github.com/ckulka/baikal-docker/blob/master/docs/unraid-installation-guide.md)## Image Variants
The `ckulka/baikal` images come in several flavors, each designed for a specific use case.
### `ckulka/baikal:`
This is the defacto image and follows the official guidelines the closest using Apache httpd.
With that being said, it's worth checking out the `nginx` variant as it requires fewer resources and produces no warning messages out-of-the-box.
If you are unsure about what your needs are, you probably want to use this one though.
### `ckulka/baikal:apache`
This image relies on Apache httpd and uses the [official PHP image](https://hub.docker.com/_/php/) that's packaged with the Apache web server.
It also ships with HTTPS support and self-signed certificates, which can be replaced by user-provided certificates - for more details, see the [SSL Certificate Guide](https://github.com/ckulka/baikal-docker/blob/master/docs/ssl-certificates-guide.md).
This image uses environment variables to set Apache's `ServerName` and `ServerAlias` directives to avoid Apache httpd's warnings in the logs.
The `BAIKAL_SERVERNAME` environment variable is used to set the global `ServerName` directive, e.g. `dav.example.io`. For more details, see [Apache Core Features: ServerName Directive](https://httpd.apache.org/docs/2.4/mod/core.html#servername).
The `BAIKAL_SERVERALIAS` environment variable is used to set the `ServerAlias` directive of the `VirtualHost`s, e.g. `dav.example.org dav.example.com`. For more details, see [Apache Core Features: ServerAlias Directive](https://httpd.apache.org/docs/2.4/mod/core.html#serveralias).
### `ckulka/baikal:experimental`
This image has the latest code from the source repository [ckulka/baikal-docker](https://github.com/ckulka/baikal-docker), mainly used for testing before a version is released. Use this at your own risk.
### `ckulka/baikal:nginx`
This image relies on [nginx](https://www.nginx.com/) and uses the [official nginx image](https://hub.docker.com/_/nginx/).
Compared to the Apache variant, it is significantly smaller (less than half the size) and produces no warning messages out-of-the-box.