Skip to content

Alpine-based PHP-FPM and NGINX HumHub docker-container

License

Notifications You must be signed in to change notification settings

javanile/humhub-docker

 
 

Repository files navigation

Alpine-based PHP-FPM and NGINX HumHub docker-container

Codacy Badge Docker Image CI

HumHub is a feature rich and highly flexible OpenSource Social Network Kit written in PHP. This container provides a quick, flexible and lightweight way to set-up a proof-of-concept for detailed evaluation. Using this in production is possible, but not recommended.

Versions

  • dockerimage badge (latest) latest: unstable master build (use with caution! might be unstable)
  • dockerimage badge (1.5.x) 1.5.2: latest stable release (recommended)
  • dockerimage badge (1.6.x) 1.6.2: latest beta release
  • dockerimage badge (experimental) experimental: test build (testing only)

Quickstart

No database integrated. For persistency look at the Compose-File example.

  1. docker run -d --name humhub_db -e MYSQL_ROOT_PASSWORD=root -e MYSQL_DATABASE=humhub mariadb:10.2
  2. docker run -d --name humhub -p 80:80 --link humhub_db:db mriedmann/humhub:1.2.0
  3. open http://localhost/ in browser
  4. complete the installation wizard (use db as database hostname and humhub as database name)
  5. finished

Known issues

  • The installation wizard is sometimes not working with chrome. Workaround: Use other browser for installing.

Composer File Example

version: '3.1'
services:
  humhub:
    build: .
    links:
      - "db:db"
    ports:
      - "80:80"
    volumes:
      - "_data/config:/var/www/localhost/htdocs/protected/config"
      - "_data/uploads:/var/www/localhost/htdocs/uploads"
  db:
    image: mariadb:10.2
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: humhub

Advanced Config

This container supports some further options which can be configured via environment variables. Look at the docker-compose.yml for some inspiration.

HUMHUB_DB_USER & HUMHUB_DB_PASSWORD

default: ""

This username and password will be used to connect to the database. Please do not set the HUMHUB_DB_PASSWORD without HUMHUB_DB_USER to avoid problems. If this is not set, the visual installer will show up at the first startup.

HUMHUB_DB_NAME

default: humhub

Defines the name of the database where humhub is installed.

HUMHUB_DB_HOST

default: db

Defines the mysql/mariadb-database-host. If you use the --link argument please specify the name of the link as host or use db as linkname (--link <container>:db).

HUMHUB_AUTO_INSTALL

default: false

If this and HUMHUB_DB_USER are set an automated installation will run during the first startup. This feature utilities a hidden installer-feature used for integration testing ( see code file ).

HUMHUB_PROTO & HUMHUB_HOST

default: http, localhost

If these are defined during auto-installation, humhub will be installed and configured to use urls with those details. (i.e. If they are set as HUMHUB_PROTO=https, HUMHUB_HOST=example.com, humhub will be installed and configured so that the base url is https://example.com/. Leaving these as default will result in humhub being installed and configured to be at http://localhost/.

HUMHUB_ADMIN_LOGIN & HUMHUB_ADMIN_EMAIL & HUMHUB_ADMIN_PASSWORD

default: admin, [email protected], test

If these are defined during auto-installation, humhub admin will be created with those credentials.

INTEGRITY_CHECK

default: 1

This can be set to "false" to disabled the startup integrity check. Use with caution!

WAIT_FOR_DB

default: 1

Can be used to let the startup fail if the db host is unavailable. To disable this, set it to "false". Can be useful if an external db-host is used, avoid when using a linked container.

SET_PJAX

default: 1

PJAX is a jQuery plugin that uses ajax and pushState to deliver a fast browsing experience with real permalinks, page titles, and a working back button. (ref) This library is known to cause problems with some browsers during installation. This container starts with PJAX disabled to improve the installation reliability. If this is set (default), PJAX is enabled during the second startup. Set this to "false" to permanently disable PJAX. Please note that changing this after container-creation has no effect on this behavior.

Mailer Config

It is possible to configure HumHub email settings using the following environment variables:

HUMHUB_MAILER_SYSTEM_EMAIL_ADDRESS    [[email protected]]
HUMHUB_MAILER_SYSTEM_EMAIL_NAME       [HumHub]
HUMHUB_MAILER_TRANSPORT_TYPE          [php]
HUMHUB_MAILER_HOSTNAME                
HUMHUB_MAILER_PORT                    
HUMHUB_MAILER_USERNAME                
HUMHUB_MAILER_PASSWORD                
HUMHUB_MAILER_ENCRYPTION              
HUMHUB_MAILER_ALLOW_SELF_SIGNED_CERTS 

LDAP Config

It is possible to configure HumHub LDAP authentication settings using the following environment variables:

HUMHUB_LDAP_ENABLED             [0]
HUMHUB_LDAP_HOSTNAME            
HUMHUB_LDAP_PORT                
HUMHUB_LDAP_ENCRYPTION          
HUMHUB_LDAP_USERNAME            
HUMHUB_LDAP_PASSWORD            
HUMHUB_LDAP_BASE_DN             
HUMHUB_LDAP_LOGIN_FILTER        
HUMHUB_LDAP_USER_FILTER         
HUMHUB_LDAP_USERNAME_ATTRIBUTE  
HUMHUB_LDAP_EMAIL_ATTRIBUTE     
HUMHUB_LDAP_ID_ATTRIBUTE        
HUMHUB_LDAP_REFRESH_USERS       

PHP Config

It is also possible to change some php-config-settings. This comes in handy if you have to scale this container vertically.

Following environment variables can be used (default values in angle brackets):

PHP_POST_MAX_SIZE       [16M]
PHP_UPLOAD_MAX_FILESIZE [10M]
PHP_MAX_EXECUTION_TIME  [60]
PHP_MEMORY_LIMIT        [1G]
PHP_TIMEZONE            [UTC]

NGINX Config

Following variables can be used to configure the embadded Nginx. The configfile gets rewritten on every container startup and is not persisted. Avoid changing it by hand.

NGINX_CLIENT_MAX_BODY_SIZE [10m]
NGINX_KEEPALIVE_TIMEOUT    [65]

Contribution

Please use the issues-page for bugs or suggestions. Pull-requests are highly welcomed.

About

Alpine-based PHP-FPM and NGINX HumHub docker-container

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 83.5%
  • Shell 12.2%
  • Dockerfile 4.2%
  • Makefile 0.1%