ノノログ

ホーム / ブログ / baserCMS / Nginx + Apache2.4 + PHP5.6 + MariaDBなbaesrCMSを立ててみた(仮)

Nginx + Apache2.4 + PHP5.6 + MariaDBなbaesrCMSを立ててみた(仮)

この記事は、baserCMSの2014年AdventCalenderより書かれた記事です。

いろいろ詳しくベンチとか書きたかったんだけど、時間がなくてざっくりですよ!!

やったこと

CentOS7 + Nginx1.6 + Apache2.4 + PHP5.6 + MariaDBなサーバを立ててみたって話。
ちなみに、サーバはさくらVPSのV5(かな?)の2G/SSDプランを利用しました。

フロントにNginxが立ってるけど、得にキャッシュの設定などはしてないです。

なんでそんなサーバ建てたのかっというのは、会社のBTS、Redmineがクソ重くて使うのにイライラしてたからリプレースしました。

Redmineを利用することと、会社の公式サイト(BaserCMS)を載せ、また速度改善のためこんな構成になりました。
ちなみにRedmineはNginx+Passengerで動いてますよ。

とりあえず晒す

ホントはいろいろやりたいんだけど、とりあえずapache benchだけ晒す。
実稼働してる(笑)ので軽くやってみた結果は下記です。

Server Software:        nginx/1.6.2
Server Hostname:        **************
Server Port:            80

Document Path:          /
Document Length:        12188 bytes

Concurrency Level:      10
Time taken for tests:   0.465 seconds
Complete requests:      10
Failed requests:        0
Write errors:           0
Total transferred:      125590 bytes
HTML transferred:       121880 bytes
Requests per second:    21.52 [#/sec] (mean)
Time per request:       464.616 [ms] (mean)
Time per request:       46.462 [ms] (mean, across all concurrent requests)
Transfer rate:          263.97 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        9    9   0.2      9       9
Processing:   380  432  22.7    436     454
Waiting:      380  431  22.7    436     453
Total:        389  441  22.8    445     463

 

テーマも変更してるし、コンテンツの量も初期状態とかではないし、比較対象をとってないので「これだけじゃわかんねーよ」状態ですが、概ね悪く無い数字ですね。
Connectが少ないのはチューニングを一切してないのでこの辺りを調整したらRequests per secondもかなり改善しそうですね。
CPU負荷も全然ないのでまだまだガッツリ行けそうな感じです。

confファイルを晒せと言われた気がする - 2015/03/03追記

nginx.confはこんな感じ

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


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;

    keepalive_timeout  65;

    #gzip  on;
    gzip              on;
    gzip_http_version 1.0;
    gzip_vary         on;
    gzip_comp_level   6;
    gzip_types        text/xml text/css application/xhtml+xml application/xml application/rss+xml application/atom_xml application/x-javascript application/x-httpd-php;
    gzip_disable      "MSIE [1-6]\.";

    proxy_temp_path   /var/tmp/nginx;
    proxy_cache_key   "$scheme://$host$request_uri";
    proxy_set_header  Host $host;
    proxy_set_header  X-Real-IP          $remote_addr;
    proxy_set_header  X-Forwarded-Host   $host;
    proxy_set_header  X-Forwarded-Server $host;
    proxy_set_header  X-Forwarded-For    $proxy_add_x_forwarded_for;

    upstream backend {
        server  127.0.0.1:8080;
    }

    include /etc/nginx/conf.d/*.conf;
}

conf.d/vhost.confはこんな感じ

# blog.gufii.net
server {
    listen 80;
    server_name blog.gufii.net blog2.gufii.net;
    root            /path/to/html/;
    index       index.php index.php;

    location / {

        proxy_pass http://backend;

    }
}

httpd.confはこんな感じ(変えたとこ抜粋)

~ 略
Listen *:8080
~ 略

<Directory "/var/www/html">
~ 略
    AllowOverride All
~ 略
<Directory>

~ 略

<Directory "/var/www/cgi-bin">
    AllowOverride None
    Options ExecCGI FollowSymLinks
    Require all granted
<Directory>

conf.d/vhost.conはこんな感じ

<Virtualhost *:8080>
    DocumentRoot /path/to/html/
    ServerName blog.gufii.net
    ErrorLog logs/blog.gufii.net-error_log
    CustomLog logs/blog.gufii.net-access_log combined
</Virtualhost>