server { listen 80; server_name site.com; return 301 http://www.site.com$request_uri; } server { listen 80; server_name www.site.com; }
location /d { rewrite ^ http://server.ru$request_uri? permanent; #301 redirect }
location ~* /d { proxy_pass http://new-server.ru:80; proxy_redirect http://new-server.ru:80 /; resolver 8.8.8.8; break; }
location @nocached { } location / { if ($cookie_dle_user_id) { return 412; } } error_page 412 = @nocached;
location ^~ /freegeoip/ { #use google as dns resolver 8.8.8.8; proxy_pass http://freegeoip.net/json/$remote_addr; }
location ^~ /secure/ { root /www/mysite.com/httpdocs/secure; auth_basic "Website development"; auth_basic_user_file /www/mysite.com/authfile; }
Затем генерируем сам файл, где логин будет admin, а пароль pass
$ php -r "echo 'admin:'. crypt('pass', base64_encode('pass'));" > /www/mysite.com/authfile
server { listen 80; server_name site.com; location ^~ /api/target/ { index receive.php; alias /some/path/to/site/target/; location ~ \.php$ { # Fix for server variables that behave differently under nginx/php-fpm than typically expected fastcgi_split_path_info ^(.+\.php)(/.+)$; # Include the standard fastcgi_params file included with nginx include fastcgi_params; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_index receive.php; # Override the SCRIPT_FILENAME variable set by fastcgi_params fastcgi_param SCRIPT_FILENAME $request_filename; # Pass to upstream PHP-FPM; This must match whatever you name your upstream connection fastcgi_pass phpfpm; #fastcgi_ignore_client_abort off; #try_files $uri =404; } } }
rewrite ^([^.\?]*[^/])$ $1/ permanent;
location ~* .(eot|ttf|woff) { add_header Access-Control-Allow-Origin *; }
root /var/www/dev.payments-api.host.org/frontend/web; location /admin/ { alias /var/www/dev.payments-api.host.org/backend/web/; # serve static files direct + allow friendly urls # Note: The seemingly weird syntax is due to a long-standing bug in nginx: https://trac.nginx.org/nginx/ticket/97 try_files $uri $uri/ /admin//admin/index.php?$args; location ~ /admin/.+\.php$ { include fastcgi_params; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $request_filename; include fastcgi_params; fastcgi_read_timeout 300; proxy_redirect off; } } # / location location @admin { rewrite ^/admin(/.*)$ /index.php?$1; }
for pid in `pidof nginx`; do echo "$(< /proc/$pid/cmdline)"; egrep 'files|Limit' /proc/$pid/limits; echo "Currently open files: $(ls -1 /proc/$pid/fd | wc -l)"; echo; done