Назад | Перейти на главную страницу

Рекомендуемая настройка для apache / mysql

У меня есть выделенный сервер с 1 ГБ памяти, обслуживающий некоторые сайты wordpress, но происходит это при выполнении тестов (ab: apache benmark, с -n 100 -c 10) для некоторых из этого wordpress, сервер начинает менять местами, а затем это похоже на смерть. ..

Итак, у меня вопрос, как настроить apache и mysql для этой цели? Я использую mpm_worker в apache для php5

Есть какие-нибудь советы по настройке файлов apache.conf и my.cnf?

РЕДАКТИРОВАТЬ: Я пытался собрать больше данных для публикации здесь, но поскольку мой сервер продолжает умирать из-за подкачки, я опубликую все, что у меня есть сейчас:

apache2.conf

<IfModule mpm_worker_module>
    StartServers          2
    MinSpareThreads      20
    MaxSpareThreads      50
    ThreadLimit          64
    ThreadsPerChild      25
    MaxClients           75
    MaxRequestsPerChild   0
</IfModule>

my.cnf (в [mysqld])

key_buffer_size         = 32M
max_allowed_packet      = 16M
thread_stack            = 192K
thread_cache_size       = 8
join_buffer_size        = 128K
myisam-recover          = BACKUP
max_connections         = 120
table_cache             = 128
max_heap_table_size     = 32M
tmp_table_size          = 32M
table_open_cache        = 128
query_cache_limit       = 1M
query_cache_size        = 16M
log_slow_queries        = /var/log/mysql/mysql-slow.log
long_query_time         = 2
log_queries_not_using_indexes = 1
expire_logs_days        = 10
max_binlog_size         = 100M

ps aux --sort -pcpu, -rss | голова -n 30

USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
www-data 11558 13.0  1.9 173280 20112 ?        R    13:59   0:00 /usr/lib/cgi-bin/php5
www-data 11529 14.0  3.6 190352 37192 ?        R    13:59   0:00 /usr/lib/cgi-bin/php5
www-data 11528 14.0  3.7 190784 37628 ?        R    13:59   0:00 /usr/lib/cgi-bin/php5
www-data 11526 16.5  3.9 192836 39580 ?        R    13:59   0:00 /usr/lib/cgi-bin/php5
svn       1909  4.2  0.3  91780  3628 ?        S    12:49   3:01 /usr/bin/svnserve --daemon --foreground -T -r /home/svn
mysql     7780  1.1  6.4 263812 64816 pts/1    Sl   13:43   0:11 /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --user=mysql --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306
root       856  1.1  0.0      0     0 ?        D    12:48   0:49 [md3_resync]
root       325  0.5  0.0      0     0 ?        S    12:48   0:22 [md3_raid1]
www-data  1731  0.3  1.1 449516 11232 ?        Sl   12:49   0:13 /usr/sbin/apache2 -k start
www-data  1732  0.2  1.0 383548 10408 ?        Sl   12:49   0:12 /usr/sbin/apache2 -k start
bind      1244  0.0  1.0 125576 11096 ?        Ssl  12:48   0:02 /usr/sbin/named -u bind
root      1235  0.0  0.0   3864   300 ?        SNs  12:48   0:02 /usr/sbin/powernowd -q
postgres  1420  0.0  0.6 105560  6764 ?        S    12:48   0:01 /usr/lib/postgresql/8.4/bin/postgres -D /var/lib/postgresql/8.4/main -c config_file=/etc/postgresql/8.4/main/postgresql.conf
danikaze  5068  0.0  0.4  24512  4112 pts/1    Ss   13:17   0:00 -bash
root         1  0.0  0.0   8356   788 ?        Ss   12:48   0:00 init [2]
root      1143  0.0  0.2  41148  2636 ?        Sl   12:48   0:00 /usr/sbin/monit -c /etc/monit/monitrc -s /var/lib/monit/monit.state
danikaze  2778  0.0  0.4  24632  4216 pts/0    Ss   12:49   0:00 -bash
postgres  1535  0.0  0.2 105668  2860 ?        Ss   12:49   0:00 postgres: writer process
root        56  0.0  0.0      0     0 ?        S    12:48   0:00 [kswapd0]
danikaze  2777  0.0  0.1  70496  1816 ?        S    12:49   0:00 sshd: danikaze@pts/0
postgres  1536  0.0  0.1 105560  1584 ?        Ss   12:49   0:00 postgres: wal writer process
root      2529  0.0  0.0      0     0 ?        S    12:49   0:00 [flush-253:2]
root      1627  0.0  0.5  90628  5360 ?        Ss   12:49   0:00 /usr/sbin/apache2 -k start
root      1689  0.0  0.0  16780   804 ?        S    12:49   0:00 /usr/sbin/rotatelogs -l /home/***.com.log.%Y-%m-%d 86400
postgres  1538  0.0  0.1  77108  1516 ?        Ss   12:49   0:00 postgres: stats collector process
root       968  0.0  0.0      0     0 ?        S    12:48   0:00 [flush-253:1]
root      7639  0.0  0.1  13940  1484 pts/1    S    13:43   0:00 /bin/sh/usr/bin/mysqld_safe
ntp       1237  0.0  0.2  38340  2148 ?        Ss   12:48   0:00 /usr/sbin/ntpd -p /var/run/ntpd.pid -g -u 105:106

бесплатно -m

             total       used       free     shared    buffers     cached
Mem:           986        769        216          0         37        532
-/+ buffers/cache:        199        787
Swap:         3827          0       3827

Я попытаюсь снова получить данные, когда сервер меняет местами, но я не знаю причины этого, даже если я нажимаю на сервер с помощью ab, единственное, что я получаю, это использование ЦП и MEM, но без обмена теперь я установил кеш для wordpress ... и все же я получаю, что сервер меняет местами и зависает в некоторые моменты: - /

Другое дело: сервер в основном использует apache + mysql, даже если есть еще svnserver, proftpd и pgsql, они почти не используются.

Поскольку вы используете mpm_worker, я настоятельно рекомендую использовать php5-fpm вместо mod_php.

Кроме того, 1 ГБ - не так много оперативной памяти, чтобы работать даже на слегка загруженном сайте WordPress. Вам обязательно следует увеличить объем оперативной памяти, если это возможно, так как это обеспечит максимальный рост производительности. Имея больше ОЗУ, вы можете обеспечить кеширование индексов MySQL, использовать APC и т. Д.

Запуск Учебник по настройке MySQL script также поможет установить хорошую базовую конфигурацию для вашего MySQL, чтобы гарантировать, что вы не тратите зря драгоценные ресурсы.

Также подумайте о том, чтобы установить vm.swappiness = 10 или 20 в вашем /etc/sysctl.conf, чтобы предотвратить раннюю подкачку.