php扩展memcache的安装

1.安装memcache服务器

Memcached作为开放、免费、高效的、分布式的内存缓存系统受到很多网站的欢迎。

官网下载memcached源代码安装包,稳定版即可

官网:http://memcached.org/

安装之前看看系统中是否安装libevent库,因为memcache依赖该库。

解压memcache安装包,进入目录执行./configure文件

tar -vxf memcached-1.4.25.tar.gz

./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent

Make

Make install

如图所示,安装成功

php扩展memcache的安装

启动memcache测试

进入到安装目录下的bin目录执行

./memcached -m 64 -p 11211 -d -u nobody

注意不能用root用户执行

-d 后台运行,不能占住屏幕

使用netstat查看端口和进程,如图所示,表示启动成功。

php扩展memcache的安装

可使用telnet连接测试

Telnet 服务器ip 11211

测试连接成功,表示memcache安装成功。

2.编译php扩展模块

Pecl官网下载memcache扩展

官网:http://pecl.php.net/

使用tar命令解压memcache扩展

进入到目录可以看到并没有configure文件,这里要使用phpize扩展安装

执行/usr/local/php/bin/phpize 后可以看到动态生成的configure文件,接下来可以正常配置编译了。

指定配置文件位置编译

./configure --with-php-config=/usr/local/php/bin/php-config

Make

Make install

如图所示,表示安装成功

php扩展memcache的安装

Installingsharedextensions:/usr/local/php/lib/php/extensions/no-debug-zts-20100525/

Memcache连接扩展位置,php配置文件中需要指定

修改php.ini文件,开启扩展

extension=/usr/local/php/lib/php/extensions/no-debug-zts-20100525/memcache.so

访问服务器查看是否安装成功

Phpinfo()测试查看,如图所示,安装成功

php扩展memcache的安装

附memcached启动脚本一份,根据rpm安装修改得到,在redhat实践可用。

#! /bin/sh
#
# chkconfig: - 55 45
# description: The memcached daemon is a network memory cache service.
# processname: memcached
# config: /etc/sysconfig/memcached
# pidfile: /var/run/memcached/memcached.pid

# Standard LSB functions
#. /lib/lsb/init-functions

# Source function library.
. /etc/rc.d/init.d/functions

PORT=11211
USER=memcached
MAXCONN=1024
CACHESIZE=64
OPTIONS=""

if [ -f /etc/sysconfig/memcached ];then
. /etc/sysconfig/memcached
fi

# Check that networking is up.
. /etc/sysconfig/network

if [ "$NETWORKING" = "no" ]
then
exit 0
fi

RETVAL=0
prog="memcached"
#pidfile=${PIDFILE-/var/run/memcached/memcached.pid}
lockfile="/var/lock/subsys/memcached"

start () {
echo -n $"Starting $prog: "
# Ensure that /var/run/memcached has proper permissions
if [ "`stat -c %U /var/run/memcached`" != "$USER" ]; then
chown $USER /var/run/memcached
fi

daemon $prog memcached -d -p $PORT -u $USER -m $CACHESIZE -c $MAXCONN $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch ${lockfile}
}
stop () {
echo -n $"Stopping $prog: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f ${lockfile}
return $RETVAL


}

restart () {
stop
start
}

# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status memcached
RETVAL=$?
;;
restart|reload|force-reload)
restart
;;
condrestart|try-restart)
[ -f ${lockfile} ] && restart || :
;;
*)
echo $"Usage: $0 {start|stop|status|restart|reload|force-reload|condrestart|try-restart}"
RETVAL=2
;;
esac

exit $RETVAL

上一篇:专题笔记--Java 类集框架


下一篇:jsonp原生js代码示例