Spent far too long trying out different ways to get this to work. I need to setup a server listening to the local IP address to restrict things like phpldapadmin to internal requests. But hit problems with nginx appending the location to the root path, and php having no idea where to get the files from.
Here’s the config that ended up working
server { listen 80; root /var/www/default/; index index.html index.htm index.nginx-debian.html; server_name 192.168.0.3; location = / { try_files $uri $uri/ =404; } location /phpldapadmin { alias /usr/share/phpldapadmin/htdocs; index index.php index.html index.htm; location ~ \.php$ { include snippets/fastcgi-php.conf; # With php7.0-fpm: fastcgi_pass unix:/var/run/php/php7.0-fpm.sock; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_intercept_errors on; } } # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # location ~ \.php$ { include snippets/fastcgi-php.conf; # With php7.0-cgi alone: # fastcgi_pass 127.0.0.1:9000; # With php7.0-fpm: fastcgi_pass unix:/var/run/php/php7.0-fpm.sock; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_intercept_errors on; } access_log /var/log/nginx/localip-access.log; error_log /var/log/nginx/localip-error.log; }