Правила переписывания WordPress для субдоменов Nginx - APC FPC - медленно, как черепаха. Зачем?
Запуск на Ubunty 10.04 Nginx (один из последних) с многосайтовым поддоменом Wordpress с использованием плагина.
APC У меня последняя версия с php, у меня 4 веб-сайта почти без трафика (по 30 посещений в день на каждом), и облачный сервер с RackSpace (2 ГБ ОЗУ, базовая модель), кажется, 50% ОЗУ нормально. Это работает, но
1) Я использую плагины batcache, apc, но я не уверен, сколько памяти им дать, в настоящее время 128 мегабайт. Я поставил APC на 128 мегабайт из-за ошибок в журнале, запрашивающих больше памяти, и посмотрите ниже, как это выглядит. https://i.imgur.com/dKTmz.jpg <--- изображение графа страницы apc.php
2) Javascript не получает GZIP.
3) index.php находится внутри каждого URL-адреса, и, если удалить WordPress, выдает ошибки.
Ниже приведены мои cfg файлы. Пожалуйста, помогите мне увидеть, чего не хватает, я просмотрел 50 страниц nginx для конфигов и адаптировал один из них, так как ни один из них точно не подходил для моей настройки
nginx.cfg
user www-data;
worker_processes 2;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
use epoll; #v1
# multi_accept on; #v1
}
http {
##
# Basic Settings
##
sendfile on;
tcp_nopush on;
#tcp_nodelay off; #v1
tcp_nodelay on; #v2
server_tokens off;
include mime.types;
default_type application/octet-stream;
index index.php index.htm index.html redirect.php;
keepalive_timeout 15;
keepalive_requests 2000;
types_hash_max_size 2048;
##necessary if using a multi-site plugin
server_name_in_redirect off;
##necessary if running Nginx behind a reverse-proxy
port_in_redirect off;
server_names_hash_bucket_size 64;
open_file_cache max=1000 inactive=300s;
open_file_cache_valid 360s;
open_file_cache_min_uses 2;
open_file_cache_errors off;
client_body_buffer_size 128K;
client_header_buffer_size 1k;
client_max_body_size 2m;
large_client_header_buffers 4 8k;
client_body_timeout 10m;
client_header_timeout 10m;
send_timeout 10m;
##
# Logging Settings
##
error_log /var/log/nginx/error.log;
access_log off;
##
# Gzip Settings
##
gzip on;
gzip_vary on;
gzip_proxied any; #v2
#gzip_proxied expired no-cache no-store private auth; #v1
gzip_comp_level 6;
gzip_min_length 1000;
gzip_buffers 32 8k; #v1
# gzip_buffers 16 8k; #v2
gzip_http_version 1.1;
gzip_disable "MSIE [1-6].(?!.*SV1)";
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
##
# Fast cgi
##
# fastcgi_intercept_errors on;
# fastcgi_ignore_client_abort on;
# fastcgi_buffers 8 16k;
# fastcgi_buffer_size 32k;
# fastcgi_read_timeout 120;
#fastcgi_index index.php;
#
# limit_req_zone $binary_remote_addr zone=one:10m rate=1r/s;
##
# Virtual Host Configs
##
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
доступные сайты
map $host $wp_dir_id {
.my-website-with-id-1-in-wordpress.com 1;
site2.com 2;
site3.com 3;
site4.com 4;
}
server {
## Ports
listen 80;
## server name
# . acts as wildcard
server_name .my-website-with-id-1-in-wordpress.com;
## root
root /var/www/;
## global rewrites
# WordPress Network sites files (map is above)
if ( $wp_dir_id != 1 )
{
rewrite ^/files/(.*)$ /wp-content/blogs.dir/$wp_dir_id/files/$1 last;
}
# fallback if site is not mapped
if ( $wp_dir_id = 1 )
{
rewrite ^(.*)/files/(.*)$ /wp-includes/ms-files.php?file=$2 last;
}
## locations
location / {
# enable browser cache for images
# not location, because this applies for PHP served images as well in WP Network
if ( $uri ~ \.(ico|gif|jpg|jpeg|png)$ ) {
expires 31d;
add_header Pragma public;
add_header Cache-Control "public, must-revalidate, proxy-revalidate";
}
# enable browser cache for css / js
# not location, because this applies for PHP served files as well in WP Network
if ( $uri ~ \.(css|js)$ ) {
expires 7d;
add_header Pragma public;
add_header Cache-Control "public, must-revalidate, proxy-revalidate";
}
# default uri
try_files $uri $uri/ @rewrites;
}
# rewrite rules
location @rewrites {
rewrite ^(.*)$ /index.php?q=$1 last;
}
## hide files starting with .
location ~ /\. {
deny all;
log_not_found off;
}
## enable nginx status screen, optional
location /nginx_status {
stub_status on;
}
## pass to PHP5-FPM server in the background
location ~ .php {
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 $document_root$fastcgi_script_name;
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;
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;
# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param REDIRECT_STATUS 200;
fastcgi_index index.php;
fastcgi_connect_timeout 60;
fastcgi_send_timeout 180;
fastcgi_read_timeout 180;
fastcgi_buffer_size 128k;
fastcgi_buffers 4 256k;
fastcgi_busy_buffers_size 256k;
fastcgi_temp_file_write_size 256k;
fastcgi_intercept_errors on;
fastcgi_ignore_client_abort on;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
#fastcgi_pass 127.0.0.1:9000;
fastcgi_pass unix:/var/run/php5-fpm.sock;
}
}
1 ответ
Я частично могу ответить, так как после дня или двух чтения
1) APC по-прежнему фрагментирован, как ссылка на изображение выше. Я попытаюсь добраться до него, и если я выясню, что вызывает фрагментацию, но самые большие фрагментированные файлы - плагины batcache и apc wordpress.
2) javascript не получал gzip, потому что он был отправлен как application/javascript, и я увидел, что у меня есть два javascript в моем cfg alreeady, включая text/javascript (который я всегда считал javascript по умолчанию.
Так что теперь все, что приходит с сервера, становится gzimed. Поэтому после того, как я добавил application/javascript в строку, начинающуюся с 'gzip_types' в первом блоке кода в моем вопросе, javascript начал работать.
3) index.php не переписывался, так как у меня не было всех правил перезаписи nginx для многосайтовых поддоменов (есть 3 основных, чтобы получить симпатичные perma-ссылки). Однако это вызвало дополнительную проблему, для которой я открою новый вопрос.
Это три строки перезаписи, и у меня была только последняя
rewrite ^(/[^/]+)?(/wp-.*) $2 last;
rewrite ^(/[^/]+)?(/.*\.php) $2 last;
rewrite ^/(.*)$ /index.php?q=$1 last;