Вот решил себе чуть чуть пооптимизировать нагрузку на сервере, поставил (в качестве прокси) nginx, но маленькая ложечка дегтя все же нашлась в Друпаловском журнале доступа (accesslog), теперь вместо реальныйх адресов попадают 127.0.0.1, что вполне естественно, но может есть какая хитрая опция у nginx, что бы отдавал реальные адреса ? или "забить" ?
Комментарии
# your settings here!
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
Странно, все эти опции стоят ... вот мой полный конфиг nginx (при этом виртуальные хосты на апаче настроены на 127.0.0.1:8080), но в журнале доступа (accesslog), все равно попадают 127.0.0.1
worker_processes 1;
error_log /var/log/nginx/error_log info;
events {
worker_connections 8192;
#use epoll;
}
http {
include /usr/local/etc/nginx/mime.types;
default_type application/octet-stream;
log_format main
'$remote_addr - $remote_user [$time_local] '
'"$request" $status $bytes_sent '
'"$http_referer" "$http_user_agent" '
'"$gzip_ratio"';
client_header_timeout 10m;
client_body_timeout 10m;
send_timeout 10m;
connection_pool_size 256;
client_header_buffer_size 1k;
large_client_header_buffers 4 2k;
request_pool_size 4k;
gzip on;
gzip_min_length 1100;
gzip_buffers 4 8k;
gzip_types text/plain;
output_buffers 1 32k;
postpone_output 1460;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 75 20;
ignore_invalid_headers on;
index index.php;
server {
listen 80;
server_name www.xxx1.ru www.xxx2.ru;
access_log /var/log/nginx/localhost.access_log main;
error_log /var/log/nginx/localhost.error_log info;
location / {
proxy_pass http://127.0.0.1:8080/;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m;
client_body_buffer_size 128k;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
}
}
}
А, тогда у Вас недоделанный Апач.
Читайте решение для Apache 1.3x/2.x.
ok, спасибо. mod_rpaf у меня уже был включен
помогли вот эти две строчки добавленные в httpd.conf апача
RPAFEnable On
еще раз сэнкс
раз уж разговор о nginx зашел, может подскажете что где прописать чтобы чистые ссылки заработали? извините за флуд
Если Вам лень найти в Google, то используйте этот рецепт.
Для того, чтобы Drupal записывал правильные IP находясь за обратным прокси нужно установить в settings.php переменную reverse_proxy:
<?php
$conf['reverse_proxy'] = 1;
?>
Разумеется вебсервер должен передавать переменную HTTP_X_FORWARDED_FOR, поэтому настройки приведённые выше тоже нужны.