Menu
Woocommerce Menu

Drupal7中配置Memcache方法详解

0 Comment

Memcache的配置就不多说,drupal由于模块较多,数据库调用频繁,因此memcache是drupal站点中必备的配置,本文大概列一下Drupal7中关于memcache的配置情况,以方便大家查阅。

由于CentOS5有一个memcached的安装包,如果要玩memcached,就直接找到memcached-1.4.5-1.el5.kb.i386.rpm下载安装了。

  1. 安装memcache服务以及启动memcached。

  2. 安装drupal的memcache模块。()

  3. 配置settings.php

memcachedb麻烦一些,虽然有为openSUSE弄好的包(memcachedb-1.0.4-2.1.i586),但由于RHEL5.5的C++库太老,没办法安装,只能从源代码编译起了。我的安装基本上基于一个很干净的RHEL5.5。

 代码如下

安装的过程可以参考http://www.linuxidc.com/Linux/2011-02/32138p2.htm。稍有不同的是,libevent这个包,RHEL5.5里的已经足够了,因此要做的就是编译安装db4.7和memcachedb1.2.1beta。注意,在装了前者之后,需要执行echo
“/usr/local/BerkeleyDB.4.7/lib/” >>
/etc/ld.so.conf.d/db4.7.ld.so.conf和ldconfig,才能让memcachedb找到新版的berkeley
db。

 $conf[‘cache_backends’][] =
‘sites/all/modules/memcache/memcache.inc’;
  // The ‘cache_form’ bin must be assigned no non-volatile storage.
  $conf[‘cache_class_cache_form’] = ‘DrupalDatabaseCache’;
  $conf[‘cache_default_class’] = ‘MemCacheDrupal’;
  $conf[‘memcache_key_prefix’] = ‘something_unique’;

RHEL5.5事实上也带db4的,不过版本较老,为4.3,memcachedb1.2.x不能够支持。当我install了4.7之后,发现这也不会有冲突。因为install的目标目录是/usr/local/BerkeleyDB.4.7/,而系统rpm包包含的db4有这些内容:

注意,需要将memcache.inc的文件路径写正确,如Drupal模块目录组织方式总结中提到,我们一般将memcache模块会放置在contrib文件夹下面,因此路径可能是
sites/all/modules/contrib/memcache/memcache.inc。
此外memcache_key_prefix最好设置一下。

/lib/libdb-4.3.so
/usr/lib/libdb-4.3.so
/usr/lib/libdb_cxx-4.3.so
/usr/share/doc/db4-4.3.29
/usr/share/doc/db4-4.3.29/LICENSE
/usr/share/doc/db4-4.3.29/README

  1. 多个memcachd服务。
    默认情况下,如果不配置memcache_servers以及memcache_bins的话,Drupal会认为只有一个server,即127.0.0.1:11211,如果有多个memcache实例的话,需要添加如下配置。

两者是可以共存的:-)

 代码如下

编译好了memcachedb,要弄一个/etc/init.d/memcachedb脚本,让service将memcachedb管理起来:

$conf[‘memcache_servers’] = array(
  ‘10.1.1.1:11211’ => ‘default’,
  ‘10.1.1.1:11212’ => ‘default’,
  ‘10.1.1.2:11211’ => ‘default’,
  ‘10.1.1.3:11211’ => ‘cluster2’,
  ‘10.1.1.4:11211’ => ‘cluster2’
);
$conf[‘memcache_bins’] = array(
  ‘cache’  => ‘default’,
  ‘cache_filter’ => ‘cluster2’,
  ‘cache_menu’ => ‘cluster2’
);

?

一切就绪。

#! /bin/sh
#
# chkconfig: – 55 45
# description: The memcachedb daemon is a network memory cache service
backing by berkeley db.
# processname: memcachedb
# config: /etc/sysconfig/memcachedb
# pidfile: /var/run/memcachedb/memcachedb.pid
# Standard LSB functions
#. /lib/lsb/init-functions
# Source function library.
澳门新匍京娱乐app,. /etc/init.d/functions
PORT=22222
USER=root
OPTIONS=””
DATADIR=/var/mcdb_data
PROCESSID=/var/run/memcachedb/memcachedb.pid
PROCESSIDDIR=`dirname $PROCESSID`
if [ -f /etc/sysconfig/memcachedb ];then
. /etc/sysconfig/memcachedb
fi
# Check that networking is up.
. /etc/sysconfig/network
if [ “$NETWORKING” = “no” ]
then
exit 0
fi
RETVAL=0
prog=”memcachedb”
start () {
echo -n $”Starting $prog: “
if [ ! -d $PROCESSIDDIR  ]; then
mkdir $PROCESSIDDIR -p
fi
# insure that /var/run/memcachedb has proper permissions
if [ “`stat -c %U $PROCESSIDDIR`” != “$USER” ]; then
chown $USER $PROCESSIDDIR
fi
daemon –pidfile $PROCESSID /usr/local/bin/memcachedb -d -p $PORT -r -u
$USER -H $DATADIR -P $PROCESSID  $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/memcachedb
}
stop () {
echo -n $”Stopping $prog: “
killproc -p $PROCESSID /usr/local/bin/memcachedb
RETVAL=$?
echo
if [ $RETVAL -eq 0 ] ; then
rm -f /var/lock/subsys/memcachedb
rm -f $PROCESSID
fi
}
restart () {
stop
start
}
# See how we were called.
case “$1″ in
start)
start
;;
stop)
stop
;;
status)
status /usr/local/bin/memcachedb
;;
restart|reload|force-reload)
restart
;;
condrestart)
[ -f /var/lock/subsys/memcachedb ] && restart || :
;;
*)
echo $”Usage: $0
{start|stop|status|restart|reload|force-reload|condrestart}”
exit 1
esac
exit $?
同时提供在/etc/sysconfig/下的配置文件memcachedb

最后讲解一下单台机器如何配置多个memcache实例,即单台机器的memcache集群搭建。
我们需要修改2个文件,一个是启动脚本/etc/init.d/memcached-multi,另一个是配置文件/etc/sysconfig/memcached。

PORT=”22222″

标签:

发表评论

电子邮件地址不会被公开。 必填项已用*标注

相关文章

网站地图xml地图