Skip to content

Latest commit

 

History

History
108 lines (90 loc) · 5.26 KB

DOCKER-INFO.md

File metadata and controls

108 lines (90 loc) · 5.26 KB

<-- Back to main section

Docker container informations

Docker layout

Container Description
app PHP application container with nginx/apache and PHP-FPM and tools (your entrypoint for bash, php and other stuff)
storage Storage container, eg. for Solr data
postgres (optional) PostgreSQL database
solr (optional) Apache Solr server
elasticsearch (optional) Elasticsearch server
memcached (optional) Memcached server
redis (optional) Redis server
ftps (optional) FTP server (vsftpd)
maildev(optional) Maildev with easy web and REST interface for mailing
pgAdmin (optional) Tool written in PHP, intended to handle the administration of MySQL over the Web

The app/ directory will be mounted under /app inside app container.

Docker images

Container Source
app WebDevOps Images
storage Ubuntu official
mysql MySQL official
postgres PostgreSQL official
solr (optional) Solr from guywithnose
elasticsearch (optional) Elasticsearch official
memcached (optional) Memcached official
redis (optional) Redis official
ftp (optional) Ubuntu official
mailcatcher (optional) Mailcatcher from schickling
pgAdmin (optional) PhpMyAdmin official

Makefile

Customize the Makefile for your needs.

Command Description
make bash Enter main container with bash (user application)
make root Enter main container with bash (user root)

make backup General backup (run all backup tasks)
make restore General restore (run all restore tasks)

make mysql-backup Backup MySQL databases
make mysql-restore Restore MySQL databases

make solr-backup Backup Solr cores
make solr-restore Restore Solr cores

make build Run building (composer, gulp, bower)

Environment settings

Environment Description
DOCUMENT_ROOT Document root for Nginx and Apache HTTPD, can be absolute or relative (to /docker inside the container).
DOCUMENT_INDEX Default document index file for Nginx and Apache HTTPd
CLI_SCRIPT Target for "cli" command of main container
CLI_USER User which should be used to run CLI scripts (normally www-data, equals php-fpm user)

TYPO3_CONTEXT Context for TYPO3, can be used for TypoScript conditions and AdditionalConfiguration
FLOW_CONTEXT Context for FLOW and NEOS

MAIL_GATEWAY Upstream server for sending mails (ssmtp)
DNS_DOMAIN List of wildcard domains pointing to webserver (eg. for local content fetching)

MYSQL_ROOT_PASSWORD Password for MySQL user "root"
MYSQL_USER Initial created MySQL user
MYSQL_PASSWORD Password for initial MySQL user
MYSQL_DATABASE Initial created MySQL database
MYSQL_HOST MySQL Hostname
MYSQL_PORT Port that the MySQL instance is using

PHP_TIMEZONE Timezone (date.timezone) setting for PHP (cli and fpm)
EFFECTIVE_UID Effective UID for php, fpm und webserver
EFFECTIVE_GID Effective GID for php, fpm und webserver

Xdebug Remote debugger (PhpStorm)

1.) Add a server (Preferences -> Languages & Frameworks -> PHP -> Servers).

Setting Value
Hostname IP or Hostname of VM
Port 8000
Debugger Xdebug
Use path mappings Check
Path mapping of folder 'app' /app/

2.) Add a debug connection (Run -> Edit Configurations... -> Connections) and create a new configuration (PHP Web Application).

Setting Value
Server Server you created before
Start URL /
Browser Choose one

Save, set a break point and test the debugger.

Application cache

Symlink your application cache (eg. typo3temp/) to /storage/cache/ and it will be stored inside the storage container so it will be accessible within all containers (eg. web or main).