Уменьшение нагрузки Apache сервера с помощью Nginx в RHEL 5

Документация связанная с установкой, настройкой и работой пользовательского ПО
Post Reply
User avatar
Raven
Бородатый сис
Бородатый сис
Posts: 2791
Joined: 03 Mar 2010, 15:12
ОС: RHEL 8
Location: Из серверной

Уменьшение нагрузки Apache сервера с помощью Nginx в RHEL 5

Post by Raven » 29 Apr 2010, 15:30

Уменьшение нагрузки Apache сервера с помощью Nginx в RHEL 5.2

Эта инструкция описывает, как установить и настроить Nginx для ускорения сервера Apache на основе RHEL 5.2.

1. Обновление установленных пакетов

Code: Select all

yum install update
2. Установка новых пакетов

Code: Select all

yum install -y httpd-devel
wget http://rpmfind.net/linux/EPEL/5Server/i386/nginx-0.6.31-3.el5.i386.rpm
rpm nginx-0.6.31-3.el5.i386.rpm
3. Редактирование /etc/nginx/nginx.conf

Настройте Nginx как обратный прокси:

Code: Select all

nano /etc/nginx/nginx.conf
если у вас двухядерный процессор:
Замените worker_processes 1; на worker_processes 2;

Замените

Code: Select all

# Load config files from the /etc/nginx/conf.d directory
include /etc/nginx/conf.d/*.conf;
#
# The default server
#
server {
listen 80;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}

на

Code: Select all

http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] $request '
'"$status" $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
gzip on;
# Load config files from the /etc/nginx/conf.d directory
include /etc/nginx/conf.d/*.conf;
#
# The default server
#
server {
listen 80;
server_name YOURSERVERNAME;
#charset koi8-r;
#access_log logs/host.access.log main;
#Main location
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;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
client_max_body_size 10m;
client_body_buffer_size 128k;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
root /usr/share/nginx/html;
index index.html index.htm index.php;
}


Эта функция позволяет Nginx работать с этими типами файлов:

Измените 

#location ~ /\.ht {
#deny all;


на

location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|wav|bmp|rtf|js)$ {root /var/www;}


4. Проверка Nginx Conf

nginx -t
Результат должен быть таким:

Code: Select all

2008/07/17 16:09:46 [info] 17197#0: the configuration file /etc/nginx/nginx.conf syntax is ok
2008/07/17 16:09:46 [info] 17197#0: the configuration file /etc/nginx/nginx.conf was tested successfully
5. Установка rpaf-2.0 модуля

Этот модуль дает активные Nginx IP-адреса для Apache.

Code: Select all

cd /usr/local/src
wget http://stderr.net/apache/rpaf/download/mod_rpaf-0.6.tar.gz
tar xzf mod_rpaf-0.6.tar.gz
cd mod_rpaf-0.6
Компиляция rpaf модуля:

Code: Select all

nano /usr/local/src/mod_rpaf-0.6/makefile
Замените APXS=$(shell which apxs) на APXS=/usr/sbin/apxs.

Способы компиляции:

I)

Code: Select all

make rpaf-2.0 && make install-2.0

II)

Code: Select all

apxs -i -c -n mod_rpaf-2.0.so mod_rpaf-2.0.c
6. Редактирование httpd.conf

Code: Select all

nano /etc/httpd/conf/httpd.conf
Добавьте

Code: Select all

...
LoadModule rpaf_module modules/mod_rpaf-2.0.so
....

#Mod_rpaf settings
RPAFenable On
RPAFproxy_ips 127.0.0.1 REALIP1 REALIP2
RPAFsethostname
Замените Listen 80 на Listen 8080, потому, что nginx будет использовать 80 порт.

7. Перезапуск Apache и запуск Nginx

Code: Select all

service httpd restart
service nginx start
8. Просмотр результатов

Apache тестовая страница через Nginx:
Image
В результате произведенных изменений снижается нагрузка на Apache, благодарятому, что основную функцию предзагрузки берет на себя nginx, скорость которого на порядок выше скорости apache.
Я не злопамятный, я просто часто ковыряю логи
Post Reply

Return to “Документация *nix”