Ich habe ein Bereitstellungssystem auf meinem Webserver. Jedes Mal, wenn eine App bereitgestellt wird, erstellt sie ein neues Verzeichnis mit Zeitstempel und verknüpft "aktuell" mit dem neuen Verzeichnis. Dies alles funktionierte gut und großartig auf Apache, aber auf dem neuen Nginx-Server, den ich eingerichtet habe, sieht es so aus, als würde ein Skript aus der "alten" Bereitstellung anstelle des neuen Symlink-Servers ausgeführt.
Ich habe einige Tutorials und Beiträge gelesen, wie man das löst, aber es gibt nicht viele Informationen und nichts scheint zu funktionieren. Hier ist meine vhost-Datei:
server {
listen 80;
server_name ~^(www\.)?(?<sname>.+?).testing.domain.com$;
root /var/www/$sname/current/public;
index index.html index.htm index.php;
location / {
try_files $uri $uri/ /index.php$is_args$args;
}
location ~* \.(jpg|jpeg|gif|png|bmp|ico|pdf|flv|swf|exe|html|htm|txt|css|js) {
add_header Cache-Control public;
add_header Cache-Control must-revalidate;
expires 7d;
}
location ~ \.php$ {
#fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/php/php7.1-fpm.sock;
include fastcgi_params;
fastcgi_param DOCUMENT_ROOT $realpath_root;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_index index.php;
}
location ~ /\.ht {
deny all;
}
}
und hier sind meine fastcgi_params:
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
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_NAME $fastcgi_script_name;
fastcgi_param REQUEST_URI $request_uri;
fastcgi_param DOCUMENT_URI $document_uri;
fastcgi_param DOCUMENT_ROOT $realpath_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;
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_script_name;
Ich würde mich sehr freuen, wenn mir jemand dabei helfen könnte, da im Moment jede Bereitstellung das Löschen der vorherigen Bereitstellung beinhaltet. System ist Ubuntu 14.04.5 LTS; PHP 7.1; Nginx nginx / 1.4.6 (Ubuntu)
SCRIPT_FILENAME
hat$document_root
nicht$realpath_root
.DOCUMENT_ROOT
ist so eingestellt,$realpath_root
wie ich es verstehe, es sollte den Wert der Kette ziehen oder bin ich völlig falsch undDOCUMENT_ROOT
ist nicht verwandt mit$document_root
DOCUMENT_ROOT
betrifft$document root
Unter /unix/157022/make-nginx-follow-symlinks können Sie das Problem möglicherweise durch Ändern umgehen
zu
(dh den Pfad von
$document_root
nach ändern$realpath_root
).Ich habe derzeit keinen Zugriff auf einen Nginx-Server, um dies zu bestätigen (mein Heimserver wird derzeit neu erstellt), aber die Lösung scheint von https://medium.com/@kanishkdudeja/truly-atomic-deployments zusammengearbeitet zu werden -mit-nginx-und-php-fpm-aed8a8ac1cd9 .
quelle