Online collaboration platform providing groupware capabilities by default, extensible with additional apps.
| Port | 8082 |
| Registry | ghcr.io/daemonless/nextcloud |
| Source | https://github.com/nextcloud/server |
| Website | https://nextcloud.com/ |
| Tag | Description | Best For |
|---|---|---|
latest / pkg |
FreeBSD Quarterly. Uses stable, tested packages. | Most users. Matches Linux Docker behavior. |
pkg-latest |
FreeBSD Latest. Rolling package updates. | Newest FreeBSD packages. |
Before deploying, ensure your host environment is ready. See the Quick Start Guide for host setup instructions.
services:
nextcloud:
image: "ghcr.io/daemonless/nextcloud:latest"
container_name: nextcloud
environment:
- PUID=1000 # User ID for the application process
- PGID=1000 # Group ID for the application process
- TZ=UTC # Timezone for the container
volumes:
- "/path/to/containers/nextcloud:/config"
- "/path/to/containers/nextcloud/data:/data"
ports:
- "8082:80"
restart: unless-stopped.env:
# .env
DIRECTOR_PROJECT=nextcloud
PUID=1000
PGID=1000
TZ=UTC
appjail-director.yml:
# appjail-director.yml
options:
- virtualnet: ':<random> default'
- nat:
services:
nextcloud:
name: nextcloud
options:
- container: 'boot args:--pull'
- expose: '8082:80 proto:tcp' \
oci:
user: root
environment:
- PUID: !ENV '${PUID}'
- PGID: !ENV '${PGID}'
- TZ: !ENV '${TZ}'
volumes:
- nextcloud: /config
- nextcloud_data: /data
volumes:
nextcloud:
device: '/path/to/containers/nextcloud'
nextcloud_data:
device: '/path/to/containers/nextcloud/data'Makejail:
# Makejail
ARG tag=latest
OPTION overwrite=force
OPTION from=ghcr.io/daemonless/nextcloud:${tag}
Note: Exposing ports in AppJail means that your service can be reached from remote hosts. If that is not your intention, do not expose the ports and communicate with the service using the IPv4 address assigned by the virtual network.
podman run -d --name nextcloud \
-p 8082:80 \
-e PUID=1000 \
-e PGID=1000 \
-e TZ=UTC \
-v /path/to/containers/nextcloud:/config \
-v /path/to/containers/nextcloud/data:/data \
ghcr.io/daemonless/nextcloud:latestappjail oci run -Pd \
-o overwrite=force \
-o container="args:--pull" \
-o virtualnet=":<random> default" \
-o nat \
-o expose="8082:80 proto:tcp" \
-e PUID=1000 \
-e PGID=1000 \
-e TZ=UTC \
-o fstab="/path/to/containers/nextcloud /config <pseudofs>" \
-o fstab="/path/to/containers/nextcloud/data /data <pseudofs>" \
ghcr.io/daemonless/nextcloud:latest nextcloudNote: Exposing ports in AppJail means that your service can be reached from remote hosts. If that is not your intention, do not expose the ports and communicate with the service using the IPv4 address assigned by the virtual network.
- name: Deploy nextcloud
containers.podman.podman_container:
name: nextcloud
image: "ghcr.io/daemonless/nextcloud:latest"
state: started
restart_policy: always
env:
PUID: "1000"
PGID: "1000"
TZ: "UTC"
ports:
- "8082:80"
volumes:
- "/path/to/containers/nextcloud:/config"
- "/path/to/containers/nextcloud/data:/data"Access at: http://localhost:8082
| Variable | Default | Description |
|---|---|---|
PUID |
1000 |
User ID for the application process |
PGID |
1000 |
Group ID for the application process |
TZ |
UTC |
Timezone for the container |
| Path | Description |
|---|---|
/config |
Configuration and application files |
/data |
User data storage |
| Port | Protocol | Description |
|---|---|---|
80 |
TCP | Web UI |
Architectures: amd64
User: bsd (UID/GID via PUID/PGID, defaults to 1000:1000)
Base: FreeBSD 15.1
Need help? Join our Discord community.