Created
October 30, 2014 07:59
-
-
Save yauh/68c460b7659569ee7a86 to your computer and use it in GitHub Desktop.
Piwik HTTPS configuration with nginx
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#/etc/nginx/fastcgi_param | |
fastcgi_param QUERY_STRING $query_string; | |
fastcgi_param REQUEST_METHOD $request_method; | |
fastcgi_param CONTENT_TYPE $content_type; | |
fastcgi_param CONTENT_LENGTH $content_length; | |
fastcgi_param SCRIPT_FILENAME $request_filename; | |
fastcgi_param SCRIPT_NAME $fastcgi_script_name; | |
fastcgi_param REQUEST_URI $request_uri; | |
fastcgi_param DOCUMENT_URI $document_uri; | |
fastcgi_param DOCUMENT_ROOT $document_root; | |
fastcgi_param SERVER_PROTOCOL $server_protocol; | |
fastcgi_param GATEWAY_INTERFACE CGI/1.1; | |
fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; | |
fastcgi_param REMOTE_ADDR $remote_addr; | |
fastcgi_param REMOTE_PORT $remote_port; | |
fastcgi_param SERVER_ADDR $server_addr; | |
fastcgi_param SERVER_PORT $server_port; | |
fastcgi_param SERVER_NAME $server_name; | |
fastcgi_param HTTPS $https if_not_empty; | |
# PHP only, required if PHP was built with --enable-force-cgi-redirect | |
fastcgi_param REDIRECT_STATUS 200; |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
;;;;;;;;;;;;;;;;;;;;; | |
; FPM Configuration ; | |
; /etc/php5/fpm/php-fpm.conf | |
;;;;;;;;;;;;;;;;;;;;; | |
; All relative paths in this configuration file are relative to PHP's install | |
; prefix (/usr). This prefix can be dynamically changed by using the | |
; '-p' argument from the command line. | |
; Include one or more files. If glob(3) exists, it is used to include a bunch of | |
; files from a glob(3) pattern. This directive can be used everywhere in the | |
; file. | |
; Relative path can also be used. They will be prefixed by: | |
; - the global prefix if it's been set (-p argument) | |
; - /usr otherwise | |
;include=/etc/php5/fpm/*.conf | |
;;;;;;;;;;;;;;;;;; | |
; Global Options ; | |
;;;;;;;;;;;;;;;;;; | |
[global] | |
; Pid file | |
; Note: the default prefix is /var | |
; Default Value: none | |
pid = /var/run/php5-fpm.pid | |
; Error log file | |
; If it's set to "syslog", log is sent to syslogd instead of being written | |
; in a local file. | |
; Note: the default prefix is /var | |
; Default Value: log/php-fpm.log | |
error_log = /var/log/php5-fpm.log | |
; syslog_facility is used to specify what type of program is logging the | |
; message. This lets syslogd specify that messages from different facilities | |
; will be handled differently. | |
; See syslog(3) for possible values (ex daemon equiv LOG_DAEMON) | |
; Default Value: daemon | |
;syslog.facility = daemon | |
; syslog_ident is prepended to every message. If you have multiple FPM | |
; instances running on the same server, you can change the default value | |
; which must suit common needs. | |
; Default Value: php-fpm | |
;syslog.ident = php-fpm | |
; Log level | |
; Possible Values: alert, error, warning, notice, debug | |
; Default Value: notice | |
;log_level = notice | |
; If this number of child processes exit with SIGSEGV or SIGBUS within the time | |
; interval set by emergency_restart_interval then FPM will restart. A value | |
; of '0' means 'Off'. | |
; Default Value: 0 | |
;emergency_restart_threshold = 0 | |
; Interval of time used by emergency_restart_interval to determine when | |
; a graceful restart will be initiated. This can be useful to work around | |
; accidental corruptions in an accelerator's shared memory. | |
; Available Units: s(econds), m(inutes), h(ours), or d(ays) | |
; Default Unit: seconds | |
; Default Value: 0 | |
;emergency_restart_interval = 0 | |
; Time limit for child processes to wait for a reaction on signals from master. | |
; Available units: s(econds), m(inutes), h(ours), or d(ays) | |
; Default Unit: seconds | |
; Default Value: 0 | |
;process_control_timeout = 0 | |
; The maximum number of processes FPM will fork. This has been design to control | |
; the global number of processes when using dynamic PM within a lot of pools. | |
; Use it with caution. | |
; Note: A value of 0 indicates no limit | |
; Default Value: 0 | |
; process.max = 128 | |
; Specify the nice(2) priority to apply to the master process (only if set) | |
; The value can vary from -19 (highest priority) to 20 (lower priority) | |
; Note: - It will only work if the FPM master process is launched as root | |
; - The pool process will inherit the master process priority | |
; unless it specified otherwise | |
; Default Value: no set | |
; process.priority = -19 | |
; Send FPM to background. Set to 'no' to keep FPM in foreground for debugging. | |
; Default Value: yes | |
;daemonize = yes | |
; Set open file descriptor rlimit for the master process. | |
; Default Value: system defined value | |
;rlimit_files = 1024 | |
; Set max core size rlimit for the master process. | |
; Possible Values: 'unlimited' or an integer greater or equal to 0 | |
; Default Value: system defined value | |
;rlimit_core = 0 | |
; Specify the event mechanism FPM will use. The following is available: | |
; - select (any POSIX os) | |
; - poll (any POSIX os) | |
; - epoll (linux >= 2.5.44) | |
; - kqueue (FreeBSD >= 4.1, OpenBSD >= 2.9, NetBSD >= 2.0) | |
; - /dev/poll (Solaris >= 7) | |
; - port (Solaris >= 10) | |
; Default Value: not set (auto detection) | |
;events.mechanism = epoll | |
; When FPM is build with systemd integration, specify the interval, | |
; in second, between health report notification to systemd. | |
; Set to 0 to disable. | |
; Available Units: s(econds), m(inutes), h(ours) | |
; Default Unit: seconds | |
; Default value: 10 | |
;systemd_interval = 10 | |
;;;;;;;;;;;;;;;;;;;; | |
; Pool Definitions ; | |
;;;;;;;;;;;;;;;;;;;; | |
; Multiple pools of child processes may be started with different listening | |
; ports and different management options. The name of the pool will be | |
; used in logs and stats. There is no limitation on the number of pools which | |
; FPM can handle. Your system will tell you anyway :) | |
; To configure the pools it is recommended to have one .conf file per | |
; pool in the following directory: | |
include=/etc/php5/fpm/pool.d/*.conf |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#/etc/nginx/sites-enabled/piwik.domain.org.conf | |
######## NGINX PIWIK SITE CONFIGURATION ############## | |
server { | |
listen 80; | |
server_name piwik.domain.org; | |
return 301 https://$host$request_uri; # all requests should be https | |
} | |
server { | |
listen 443 ssl spdy; # ssl and spdy enabled | |
server_name piwik.domain.org; | |
# SSL | |
ssl_certificate /etc/nginx/crt/ssl.crt; | |
ssl_certificate_key /etc/nginx/crt/ssl.key.out; | |
ssl_session_cache shared:SSL:10m; | |
ssl_session_timeout 10m; | |
ssl_ciphers ECDH+AESGCM:ECDH+AES256:ECDH+AES128:DH+3DES:!ADH:!AECDH:!MD5; | |
ssl_prefer_server_ciphers on; | |
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; | |
add_header Strict-Transport-Security "max-age=63072000; includeSubDomains"; | |
add_header X-Frame-Options DENY; | |
add_header X-Content-Type-Options nosniff; | |
ssl_trusted_certificate /etc/nginx/crt/ssl.crt; | |
ssl_stapling on; # Requires nginx >= 1.3.7 | |
ssl_stapling_verify on; # Requires nginx => 1.3.7 | |
resolver 8.8.8.8 8.8.4.4; | |
# Content configuration | |
root /var/www/html/piwik; | |
index index.php index.html; | |
# Log output | |
access_log /var/log/nginx/piwik.access.log; | |
error_log /var/log/nginx/piwik.error.log; | |
# Support for favicon. | |
# Return a 204 (No Content) if the favicon doesn't exist. | |
location = /favicon.ico { | |
try_files /favicon.ico =204; | |
} | |
# Try all locations and relay to index.php as a fallback. | |
location / { | |
try_files $uri $uri/ $uri/index.php /index.php; | |
} | |
# enable PHP for this site | |
location ~ \.php$ { | |
try_files $uri =404; | |
fastcgi_split_path_info ^(.+\.php)(/.+)$; | |
include /etc/nginx/fastcgi_params; | |
fastcgi_pass unix:/var/run/php5-fpm.sock; | |
fastcgi_index index.php; | |
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; | |
} | |
# serve static files more efficiently | |
location ~* \.(js|ico|gif|jpg|jpeg|png|css|html|htm|swf|htc|xml|bmp|cur|txt|pdf|zip)$ { | |
access_log off; | |
expires max; | |
} | |
# enable gzip compression for this site | |
gzip on; | |
gzip_http_version 1.0; | |
gzip_comp_level 2; | |
gzip_proxied any; | |
gzip_min_length 1000; | |
gzip_buffers 16 8k; | |
gzip_types text/plain text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript; | |
gzip_disable "MSIE [1-6].(?!.*SV1)"; | |
gzip_vary on; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment