65 lines
2.5 KiB
Markdown
65 lines
2.5 KiB
Markdown
# custom-php
|
|
|
|
Coöp Cloud + [PHP](https://php.org) + MariaDB (optional) + Nginx = 🥳
|
|
|
|
<!-- metadata -->
|
|
|
|
* **Category**: Development
|
|
* **Status**: 3, stable
|
|
* **Image**: [`php`](https://hub.docker.com/_/php), 4, upstream
|
|
* **Healthcheck**: Yes
|
|
* **Backups**: Yes
|
|
* **Email**: 3
|
|
* **Tests**: 2
|
|
* **SSO**: No
|
|
|
|
<!-- endmetadata -->
|
|
|
|
## Basic usage
|
|
|
|
1. Set up Docker Swarm and [`abra`][abra]
|
|
2. Deploy [`coop-cloud/traefik`][cc-traefik]
|
|
3. `abra app new custom-php --secrets` (optionally with `--pass` if you'd like
|
|
to save secrets in `pass`)
|
|
4. `abra app config YOURAPPDOMAIN`
|
|
- be sure to change `$DOMAIN` to something that resolves to
|
|
your Docker swarm box
|
|
- if you need to enable the optional database, uncomment `COMPOSE_FILE="compose.yml:compose.mariadb.yml"` in which case configure your site to load the DB credentials from env:
|
|
- `getenv('DB_NAME');`
|
|
- `getenv('DB_HOST');`
|
|
- `getenv('DB_USER');`
|
|
- `@file_get_contents(getenv('DB_PASSWORD_FILE'));`
|
|
5. Deploy with `abra app deploy YOURAPPDOMAIN`
|
|
6. Copy your site files using something like: `abra app cp YOURAPPDOMAIN index.html app:/var/www/html/` or if you want to copy an entire directory: `tar -cf - -C my_site/path/here . | abra app YOURAPPDOMAIN cp - app:/var/www/html/`
|
|
6. Use [restore functionality](https://docs.coopcloud.tech/backup-restore/) to import a SQL file into the db
|
|
6. Open the configured domain in your browser to check all is good
|
|
|
|
|
|
## Extra
|
|
|
|
Indicate extensions you need in the `PHP_EXTENSIONS` env var. The entrypoint script will install them on startup.
|
|
|
|
You can see what PHP extensions compiled into the image by checking the output of `abra app run YOURAPPDOMAIN app "php -m"`
|
|
|
|
You can see the PHP config and environment by checking the output of `abra app run YOURAPPDOMAIN app "php -i"`
|
|
|
|
|
|
## Email
|
|
|
|
There is a local or remote SMTP relay configuration available.
|
|
|
|
* **local**: `COMPOSE_FILE=compose.yml:compose.mailrelay.yml`
|
|
* **remote**: `COMPOSE_FILE=compose.yml:compose.mailrelay.yml:compose.smtp.yml`
|
|
|
|
Below are the instructions for the local relay.
|
|
|
|
1. Deploy [`postfix-relay`][cc-postfix-relay]
|
|
2. `abra app config YOURAPPDOMAIN`, and uncomment the email lines; change
|
|
`MAIL_FROM` to make sure the domain is the same as `postfix-relay`'s
|
|
`$DOMAIN` or in its `$EXTRA_SENDER_DOMAINS`
|
|
3. `abra app deploy YOURAPPDOMAIN`
|
|
|
|
[abra]: https://git.autonomic.zone/autonomic-cooperative/abra
|
|
[cc-traefik]: https://git.autonomic.zone/coop-cloud/traefik
|
|
[cc-postfix-relay]: https://git.autonomic.zone/coop-cloud/traefik
|