一、环境介绍
功用 | ip地址 | 安装软件 |
提供前段静态页面和动态页面 | 192.168.1.201 |
nginx+php |
缓存服务器 |
192.168.1.202 |
mencached |
数据库服务器 | 192.168.1.203 | MariaDB |
二、nginx与php的安装配置
1.nginx的安装与配置
关于Nginx的安装,请移步至本人相关博文http://wangfeng7399.blog.51cto.com/3518031/1403741,本处将不再给出操作步骤
2.安装php
关于php的安装,请移步至本人相关博文,http://wangfeng7399.blog.51cto.com/3518031/1381688,本处将不再给出操作步骤
3、安装xcache,为php加速
关于xcache的安装,请移步至本人相关博文http://wangfeng7399.blog.51cto.com/3518031/1381688,本处将不再给出具体操作步骤
4.nginx和php的结合
编辑/etc/nginx/nginx.conf,启用如下选项
1
2
3
4
5
6
7
|
location ~ \.php$ { root html;
fastcgi_pass 127.0 . 0.1 : 9000 ;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$$fastcgi_script_name;
include fastcgi_params;
} |
编辑/etc/nginx/fastcgi_params,将其内容更改为如下内容
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
fastcgi_param GATEWAY_INTERFACE CGI/ 1.1 ;
fastcgi_param SERVER_SOFTWARE nginx; 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 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格式的主页
1
2
3
4
|
location / { root html;
index index.php index.html index.htm;
} |
而后重新载入nginx的配置文件
1
2
3
4
|
[root@node1 ~]# service nginx reload nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
Reloading nginx: [ OK ] |
准备测试页面
1
2
3
4
|
[root@node1 ~]# vi /usr/local/nginx/html/index.php <?php phpinfo();
?> |
可以看到nginx与php、xcache整合成功
5.压力测试
1
2
3
4
5
6
7
8
9
10
11
12
13
|
[root@node1 xcache- 3.0 . 4 ]# ab -c 100 -n 1000 http: //192.168.1.201/index.php
Concurrency Level: 100
Time taken for tests: 3.259 seconds
Complete requests: 1000
Failed requests: 87
(Connect: 0 , Receive: 0 , Length: 87 , Exceptions: 0 )
Write errors: 0
Total transferred: 60208909 bytes
HTML transferred: 60061909 bytes
Requests per second: 306.81 [#/sec] (mean)
Time per request: 325.930 [ms] (mean)
Time per request: 3.259 [ms] (mean, across all concurrent requests)
Transfer rate: 18040.01 [Kbytes/sec] received
|
三、数据库的安装配置
关于数据库的安装配置,请移步至本人相关博文http://wangfeng7399.blog.51cto.com/3518031/1393146,本处将不再累赘
四、memcached的安装
1.简介
Memcached是一款开源、高性能、分布式内存对象缓存系统,可应用各种需要缓存的场景,其主要目的是通过降低对Database的访问来加速web应用程序。它是一个基于内存的“键值对”存储,用于存储数据库调用、API调用或页面引用结果的直接数据,如字符串、对象等。
memcached是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 为首开发的一款软件。现在已成为mixi、hatena、Facebook、Vox、LiveJournal等众多服务中提高Web应用扩展性的重要因素。
Memcached是一款开发工具,它既不是一个代码加速器,也不是数据库中间件。其设计哲学思想主要反映在如下方面:
1. 简单key/value存储:服务器不关心数据本身的意义及结构,只要是可序列化数据即可。存储项由“键、过期时间、可选的标志及数据”四个部分组成;
2. 功能的实现一半依赖于客户端,一半基于服务器端:客户负责发送存储项至服务器端、从服务端获取数据以及无法连接至服务器时采用相应的动作;服务端负责接收、存储数据,并负责数据项的超时过期;
3. 各服务器间彼此无视:不在服务器间进行数据同步;
4. O(1)的执行效率
5. 清理超期数据:默认情况下,Memcached是一个LRU缓存,同时,它按事先预订的时长清理超期数据;但事实上,memcached不会删除任何已缓存数据,只是在其过期之后不再为客户所见;而且,memcached也不会真正按期限清理缓存,而仅是当get命令到达时检查其时长;
Memcached提供了为数不多的几个命令来完成与服务器端的交互,这些命令基于memcached的协议实现。
存储类命令:set, add, replace, append, prepend
获取数据类命令:get, delete, incr/decr
统计类命令:stats, stats items, stats slabs, stats sizes
清理命令: flush_all
2.安装
memcached可以通过yum安装也可以通过编译源码安装,本处通过yun安装
1
|
[root@node2 ~]# yum install -y memcached |
3.使用telnet命令测试menmcached的使用
memcached提供一组基本命令用于基于命令行调用其服务或查看服务器状态等
1
2
3
4
5
6
7
8
9
10
11
12
|
[root@node2 ~]# telnet 127.0 . 0.1 11211
add mykey 0 60 12
Hello world! STORED get mykey
VALUE mykey 0 12
Hello world! END add命令格式: add keyname flag timeout datasize get 命令格式:
get keyname
|
4.memcached的常用选项说明:
-l <ip_addr>:指定进程监听的地址
-d:以守护模式运行
-u <username>:以指定的用户运行menmcached进程
-m <num>:用于缓存数据的最大内存空间,单位为MB,默认为64MB
-c <num>:最大支持的并发连接数,默认为1024
-p <num>: 指定监听的TCP端口,默认为11211
-U <num>:指定监听的UDP端口,默认为11211,0表示关闭UDP端口
-t <threads>:用于处理入站请求的最大线程数,仅在mencached编译时开启了支持线程才有效
-f <num>:设定slab allocator定义预先分配内存空间大小固定的块时使用的增长因子
-M:当内存不够使用时返回错误信息,而不是按照LRU算法利用空间
-n:指定最小的slab chuck大小;单位为字节
-S:启用ssl进行进行用户认证
五、安装Memcached的PHP扩展
1、安装php的memcache扩展
1
2
3
4
5
6
7
8
|
[root@node1 ~]# wget http: //pecl.php.net/get/memcache-2.2.7.tgz
[root@node1 ~]# tar xf memcache- 2.2 . 7 .tgz
[root@node1 ~]# cd memcache- 2.2 . 7
[root@node1 memcache- 2.2 . 7 ]# /usr/local/php/bin/phpize
[root@node1 memcache- 2.2 . 7 ]# ./configure -- with -php-config=/usr/local/php/bin/php-config --enable-memcache
[root@node1 memcache- 2.2 . 7 ]# make && make install
上述安装完成会出现如下提示 Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts- 20100525 /
|
2.开启menmcache扩展
编辑/etc/php.ini文件添加如下项
1
|
extension =/usr/local/php/lib/php/extensions/no-debug-non-zts- 20100525 /memcache.so
|
可以看到memcache加载成功
3.测试
1
2
3
4
5
6
7
8
9
10
11
|
在html路径下添加一个test.php页面,内容如下 <?php $mem = new Memcache;
$mem->connect( "127.0.0.1" , 11211 ) or die( "Could not connect" );
$version = $mem->getVersion(); echo "Server's version: " .$version. "<br/>\n" ;
$mem-> set ( 'hellokey' , 'Hello World' , 0 , 600 ) or die( "Failed to save data at the memcached server" );
echo "Store data in the cache (data will expire in 600 seconds)<br/>\n" ;
$get_result = $mem-> get ( 'hellokey' );
echo "$get_result is from memcached server." ;
?> |
可以看到测试成功
4.安装memcache的图形化界面
1
2
3
4
|
[root@node1 ~]# cd /usr/local/nginx/html/ [root@node1 html]# wget http: //www.junopen.com/memadmin/memadmin-1.0.12.tar.gz
[root@node1 html]# tar xf memadmin- 1.0 . 12 .tar.gz
[root@node1 html]# cd memadmin |
用户名和密码都为admin
有没有感到这是一个很赞的软件
5.压力测试
1
2
3
4
5
6
7
8
9
10
11
|
Concurrency Level: 100
Time taken for tests: 1.965 seconds
Complete requests: 1000
Failed requests: 0
Write errors: 0
Total transferred: 276000 bytes
HTML transferred: 129000 bytes
Requests per second: 508.81 [#/sec] (mean)
Time per request: 196.536 [ms] (mean)
Time per request: 1.965 [ms] (mean, across all concurrent requests)
Transfer rate: 137.14 [Kbytes/sec] received
|
六、nginx和memcached集合
nginx的数据也可以换成在memcache中,配置如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
server { listen 80 ;
server_name www.wangfeng7399.com;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
set $memcached_key $uri;
memcached_pass 192.168 . 1.202 : 11211 ;
default_type text/html;
error_page 404 @fallback;
}
location @fallback {
proxy_pass http: //192.168.1.201;
}
}
|