Docker nginx / php notes

Prev  
 Next

This is an old revision of the document!


Back  
 Next

nginx / php notes

nginx executable

To run and control nginx.

  • nginx to run.
  • nginx -h to get all help / options
  • nginx -s signal, where signal maybe:
    • stop for fast shutdown
    • quit for graceful shutdown
    • reload to reload the configuration files
    • reopen to reopen the log files
  • nginx -t to test configuration
  • nginx -c config_file to start nginx with a non default config file. Default config file is /etc/nginx/nginx.conf.

Alpine nginx standard configuration (v3.18.4, 2023-10-07)

/etc/nginx/

/etc/nginx/fastcgi.conf

/etc/nginx/fastcgi_params

See fastcgi_params Versus fastcgi.conf – Nginx Config History, basically fastcgi.params is for historical reasons where fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; has to be separately configured in the location directive.

/etc/nginx/mime.types

/etc/nginx/nginx.conf

/etc/nginx/scgi_params

Simple Common Gateway Interface (scgi) look like another alternative protocol similar to FastCGI. Probably not relevant unless you intend to use.

/etc/nginx/uwsgi_params

The uWSGI project looks like an older module add in for Python, and also other languages. Probably not relevant unless you intend to use.

/etc/nginx/http.d/

/etc/nginx/http.d/default.conf

/etc/nginx/modules/

This directory is empty.

/etc/nginx/conf.d/

This directory does not exist. This is a concern as the default nginx configuration nginx.conf references this directory. Of course the /etc/nginx/conf.d is a default override directory, so it can be created on use.

/usr/share/nginx/

/usr/share/nginx/http-default_server.conf

/usr/share/nginx/http-default_server.conf is the same as /etc/nginx/http.d/default.conf listed above.

/var/lib/nginx/html/

/var/lib/nginx/html/index.html

/var/www/

There is following empty subdirectory structure: /var/www/localhost/htdocs

basic static site from base setup

Unless otherwise configured nginx reads the configuration file at /etc/nginx/nginx.conf. This file has dynamic module overrides and root code snippet updates. The main virtual host configuration files are located in sub-directory /etc/nginx/http.d

static web page

Place this at following location; /var/www/test/index.html

basic static html test page

Basic Static Content

The directory /etc/nginx/http.d/ should already exit. Create test.conf.

/etc/nginx/http.d/test.conf

The existing default.conf return 404 error and will conflict with the new simple configuration and need to be removed.

nginx logging

nginx seems to have the following log levels # [ debug | info | notice | warn | error | crit ]. Hence when developing and creating a html server use of info or notice is probably used whereas warn or error level logging would probably be used for a normal running html server.

s6-rc nginx

In order to run nginx in the foreground us echo “daemon off;” » /etc/nginx/nginx.conf. I tried nginx -g 'daemon off;', but that did not work.

php-fpm

There are 2 php executables, php a cli version (/usr/bin/php82) and php-fpm for fpm-fcgi (/usr/sbin/php-fpm82). We are interested in the fpm type and it can be run in foreground using flag -F or --nodaemonize. The php-fpm modules are stored here /usr/lib/php82/modules. There is /etc/php82 that has the configuration files.

php82 config files

/etc/php82/php-fpm.conf

/etc/php82/php.ini

/etc/php82/php-fpm.d/www.conf

nginx fastcgi setup

/etc/nginx/http.d/fastcgi_test.conf

/var/www/test/test.php

/var/www/test/phpinfo.php

/app/www/public/data/attic/docker_notes/nginx-php-notes.1697109797.txt.gz · Last modified: 2023-10-12 Thu wk41 19:23
CC Attribution-Share Alike 4.0 International Except where otherwise noted, content on this wiki is licensed under the following license: CC Attribution-Share Alike 4.0 International