oCIS with Traefik
- oCIS running behind Traefik as reverse proxy
- Traefik generating self-signed certificates for local setup or obtaining valid SSL certificates for a server setup
The docker stack consists of three containers. One of them is Traefik, a proxy which is terminating ssl and forwards the requests to oCIS in the internal docker network.
The other one is oCIS itself running all extensions in one container. In this example, oCIS uses its internal IDP LibreGraph Connect and the oCIS storage driver
The last one is Inbucket a mail service to view the notification mails oCIS generates.
- Linux server with docker and docker-compose installed
- Three domains set up and pointing to your server
- ocis.* for serving oCIS
- traefik.* for serving the Traefik dashboard
- mail.* for serving the Inbucket mail service
See also example server setup
-
Clone oCIS repository
git clone https://github.com/owncloud/ocis.git
-
Go to the deployment example
cd ocis/deployments/examples/ocis_traefik
-
Open the
.env
file in a text editor.The file by default looks like this:
# If you're on a internet facing server please comment out following line. # It skips certificate validation for various parts of oCIS and is needed if you use self signed certificates. INSECURE=true ### Traefik settings ### # Serve Traefik dashboard. Defaults to "false". TRAEFIK_DASHBOARD= # Domain of Traefik, where you can find the dashboard. Defaults to "traefik.owncloud.test" TRAEFIK_DOMAIN= # Basic authentication for the dashboard. Defaults to user "admin" and password "admin" TRAEFIK_BASIC_AUTH_USERS= # Email address for obtaining LetsEncrypt certificates, needs only be changed if this is a public facing server TRAEFIK_ACME_MAIL= ### oCIS settings ### # oCIS version. Defaults to "latest" OCIS_DOCKER_TAG= # Domain of oCIS, where you can find the frontend. Defaults to "ocis.owncloud.test" OCIS_DOMAIN= # oCIS admin user password. Defaults to "admin". ADMIN_PASSWORD= # The demo users should not be created on a production instance # because their passwords are public. Defaults to "false". DEMO_USERS= ### Email / Inbucket settings ### # Inbucket / Mail domain. Defaults to "mail.owncloud.test" INBUCKET_DOMAIN=
You are installing oCIS on a server and Traefik will obtain valid certificates for you so please remove
INSECURE=true
or set it tofalse
.If you want to use the Traefik dashboard, set TRAEFIK_DASHBOARD to
true
(default isfalse
and therefore not active). If you activate it, you must set a domain for the Traefik dashboard inTRAEFIK_DOMAIN=
e.g.TRAEFIK_DOMAIN=traefik.owncloud.test
.The Traefik dashboard is secured by basic auth. Default credentials are the user
admin
with the passwordadmin
. To set your own credentials, generate a htpasswd (e.g. by using an online tool or a cli tool).Traefik will issue certificates with LetsEncrypt and therefore you must set an email address in
TRAEFIK_ACME_MAIL=
.By default ocis will be started in the
latest
version. If you want to start a specific version of oCIS set the version toOCIS_DOCKER_TAG=
. Available versions can be found on Docker Hub.Set your domain for the oCIS frontend in
OCIS_DOMAIN=
, e.g.OCIS_DOMAIN=ocis.owncloud.test
.Set the initial admin user password in
ADMIN_PASSWORD=
, it defaults toadmin
.Now you have configured everything and can save the file.
-
Start the docker stack
docker-compose up -d
-
You now can visit oCIS, Traefik dashboard and Inbucket on your configured domains. You may need to wait some minutes until all services are fully ready, so make sure that you try to reload the pages from time to time.
For a more simple local ocis setup see Getting started
This docker stack can also be run locally. One downside is that Traefik can not obtain valid SSL certificates and therefore will create self-signed ones. This means that your browser will show scary warnings. Another downside is that you can not point DNS entries to your localhost. So you have to add static host entries to your computer.
On Linux and macOS you can add them to your /etc/hosts
file and on Windows to C:\Windows\System32\Drivers\etc\hosts
file like this:
127.0.0.1 ocis.owncloud.test
127.0.0.1 traefik.owncloud.test
127.0.0.1 mail.owncloud.test
After that you’re ready to start the application stack:
docker-compose up -d
Open https://ocis.owncloud.test in your browser and accept the invalid certificate warning. You now can login to oCIS with the default users, which also can be found here: Getting started. You may need to wait some minutes until all services are fully ready, so make sure that you try to reload the pages from time to time.