环境:
一台服务器:192.168.80.100
关闭防火墙及SElinux
systemctl stop firewalld
setenforce 0
安装memcached服务器:
yum install lrz* -y
上传源码包和插件包
memcached包与依赖包
memcached-1.5.9.tar.gz
libevent-2.1.8-stable.tar.gz
解压包
tar xf memcached-1.5.6.tar.gz -C /opt/
tar xf libevent-2.1.8-stable.tar.gz -C /opt/
编译环境
yum install gcc gcc-c++ make -y
安装与编译
cd /opt/libevent-2.1.8-stable
./configure --prefix=/usr/local/libevent //依赖包的安装目录
make && make install //编译并安装
安装memcached:
cd /opt/memcached-1.5.6
定制
./configure \
--prefix=/usr/local/memcached \
--with-libevent=/usr/local/libevent/
编译安装
make && make install
软连接/usr/local/libevent/lib/libevent-2.1.so.6.0.2
ln -s /usr/local/libevent/lib/libevent-2.1.so.6.0.2 /usr/lib64/libevent-2.1.so.6
因为需要libvent-2.1so.6.0.2库
运行Memcached服务
cd /usr/local/memcached/bin/
./memcached -d -m 32m -p 11211 -u root //以守护进程的方式分配32MB内存指定端口指定用户账号位root运行Memcached服务
以上选项说明如下:
-p:使用的tcp端口,默认为11211
-m:最大内存大小,默认为64M
-vv:以very vrebose模式启动,将调试信息和错误输出到控制台
-d:作为守护进程的后台运行
-c:最大运行的并发连接数,默认是1024,一般按照服务器的负载量来设置
-P:设置保存Memcached的pid文件
-l:监听的服务器IP地址,若有多个地址
-u:运行Memcached的用户,默认不能用root启动,若使用需要-u来指定root用户
设置Memcached 服务脚本:
vi /etc/init.d/memcached
#!/bin/bash
#chkconfig: 35 99 20
#description: memcached Service Control Script
PROG="/usr/local/memcached/bin/memcached"
case "$1" in
start)
$PROG -d -m 32 -p 11211 -u root
;;
stop)
pkill -9 memcached &> /dev/null
;;
restart)
$0 stop
$0 start
;;
*)
echo "Usage: $0 {start|stop|restart}"
exit 1
esac
exit 0
授权
chmod +x /etc/init.d/memcached
//添加运行权限
添加到service管理器
chkconfig --add memcached
启动memcached
service memcached start
查看是否启动:
netstat -anpt | grep memcached
telnet连接
安装telnet:
yum install -y telnet
连接登录:
telnet 127.0.0.1 11211
不进行压缩和序列化标识 数据过期时间为永不过期 标识号是5就需要输入5位数。:
set userid 0 0 5
输入数据以 . 结束:
123456
获取数据:
get userid
显示状态信息:
stats
退出:
quit
键值对语法如下:
command
memcached修改命令参数
参数 用法
key key用于查找缓存值
flags 可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息
expiration time 在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes 在缓存中存储的字节点
value 存储的值(始终位于第二行)memcached基本操作命令
1.set
set命令用于向缓存添加新的键值对,如果已经存在,则之前的值将被替换,响应STORED2.add
当缓存中不存在键时,add命令才会向缓存中添加一个键值对,如果缓存中已经存在该键,则之前的值将仍将保持不变,并返回响应NOT_STORED3.append user 0 0 4 //键值后追加4个字节
4.prepend username 0 0 2 //键值前追加2个字节
5.replace
仅当键已经存在时,replace命令才会替换缓存中的键,如果缓存中不存在该键,则返回响应NOT_STORED6.get
用于检索与之前添加的键值对相关的值7.delete
用于删除memcached中的任何现有值,将使用一个键调用delete,如果该键存在于缓存中,则删除该值。如果不存在,则返回一条NOT_FOUND消息。8.stats
转储所连接的 memcached 实例的当前统计数据。9.flush_all
仅用于清理缓存中的所有名称/值对。如果需要将缓存重置到干净的状态,则 flush_all 能提供很大的用处。10.quit //退出
例子:
set mykey 0 60 11
hello world
get mykeyappend mykey 0 60 1
a
get mykeyprepend mykey 0 60 3
higet mykey
delete mykey
以上安装memcached完成
1,安装 apache
yum install httpd httpd-devel -y
2.设置httpd服务开机启动
systemctl enable httpd
3.启动httpd服务
systemctl start httpd
4.查看端口监听情况
netstat -tunlp | grep httpd
6.安装mysql数据库
yum install mariadb mariadb-server mariadb-libs mariadb-devel -y
7.查看软件包情况
rpm -qa | grep mariadb
8.设置开机自启动
systemctl enable mariadb
9.启动mysql服务
systemctl start mariadb
10.查看端口监听情况
netstat -tunlp | grep mysql
11.数据库安全设置
mysql_secure_installation
按enter 然后输入y 然后输入密码 依次 按 y+y+n+y
12.登录mysql数据库测试
mysql -u root -p
13.安装php
yum -y install php php-devel
14.查看已安装php相关软件包
rpm -ql php
15.将php和mysql作关联
yum install php-mysql
16.查看
rpm -ql php-mysql
17.安装常用的php模块
yum install -y php-gd php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-snmp php-soap curl curl-devel php-bcmath
有得需要网上下载
18.创建php测试页面
cd /var/www/html
vim index.php
?>
19.重启httpd服务
systemctl restart httpd
20.客户端测试php
客户端访问http://192.168.80.100/index.php
21.客户端安装Memcache的PHP扩展功能
安装autoconf软件包
yum install autoconf -y
解压
tar xf memcache-2.2.7.tgz -C /opt/
增加php模块
cd /opt/memcache-2.2.7
/usr/bin/phpize
配置
./configure \
--enable-memcache \
--with-php-config=/usr/bin/php-config
编译及安装
make && make install
22.编辑php.ini
vi /etc/php.ini
732行,新增以下命令
extension_dir = "/usr/lib64/php/modules/"
864行,新增以下命令
extension = memcache.so
23.编写测试页面,测试memcached工作是否正常
vi /var/www/html/index.php
$memcache = new Memcache();
$memcache->connect('192.168.80.100',11211);
$memcache->set('key','Memcache test Successfull!',0,60);
$result = $memcache->get('key');
unset($memcache);
echo $result;
?>
24.重启httpd服务
service httpd restart
25.客户端进行访问测试是否成功 ,http://192.168.80.100/
结果图