`

安装Memcached及Memcached配置

阅读更多

一、安装Memcached及Memcached配置和状态查询

          要想使用Memcached做缓存首先需要安装Memcached服务,安装方法如下:

      1. 下载Memcached:http://code.jellycan.com/memcached/现在的最新版本是1.2.6.注意下载正确的版本,windows 服务的话下载win32 binary。

      2.解压之后放在硬盘的目录下,如:D:\memcached. 然后在运行中输入cmd进入命令行,进入到Memcached.exe 所在的目录,例如:D:\memcached,然后输入:Memcached –d install,即可完成安装。

          Memcached还有其他的一些常用的命令如下:

      -p 监听的端口
      -l 连接的IP地址, 默认是本机
      -d start 启动memcached服务
      -d restart 重起memcached服务
      -d stop|shutdown 关闭正在运行的memcached服务
      -d install 安装memcached服务
      -d uninstall 卸载memcached服务
      -u 以的身份运行 (仅在以root运行的时候有效)
      -m 最大内存使用,单位MB。默认64MB
      -M 内存耗尽时返回错误,而不是删除项
      -c 最大同时连接数,默认是1024
      -f 块大小增长因子,默认是1.25
      -n 最小分配空间,key+value+flags默认是48
      -h 显示帮助

          按照上面的安装步骤安装之后,使用memcached –m 200来调整最大内存占用之后会发现没有起作用,总是默认的64MB的内存,在网上搜了一下,原因是注册表中并没有写入信息,可以这样来修改。

         1. memcached –d shutdown 首先关闭memcached服务。

         2.进入注册表,找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server,在其中有一个ImagePath项,值为"d:\memcached\memcached.exe" -d runservice,在后面加上-l 127.0.0.1 -m 3000 -c 2048。

        3.memcached –d start 启动memcached服务,这样就将memcached的最大内存修改为了3000MB。

        对Memcached缓存服务的状态查询,可以先telnet连接上服务:telnet 127.0.0.1 11211 ,然后使用 stats命令查看缓存服务的状态,会返回如下的数据:   

        time:    1255537291                               服务器当前的unix时间戳
        total_items:    54                                     从服务器启动以后存储的items总数量
        connection_structures:    19                    服务器分配的连接构造数
        version:    1.2.6                                        memcache版本
        limit_maxbytes:    67108864                    分配给memcache的内存大小(字节)
        cmd_get:    1645                                      get命令(获取)总请求次数
        evictions:    0                                            为获取空闲内存而删除的items数(分配给memcache的空间用满后需
                                                                         要删除旧的items来得到空间分配给新的items)
        total_connections:    19                           从服务器启动以后曾经打开过的连接数
        bytes:    248723                                      当前服务器存储items占用的字节数
        threads:    1                                             当前线程数
        get_misses:    82                                      总未命中次数
        pointer_size:    32                                    当前操作系统的指针大小(32位系统一般是32bit)
        bytes_read:    490982                              总读取字节数(请求字节数)
        uptime:    161                                           服务器已经运行的秒数
        curr_connections:    18                             当前打开着的连接数
        pid:    2816                                               memcache服务器的进程ID
        bytes_written:    16517259                     总发送字节数(结果字节数)
        get_hits:    1563                                      总命中次数
        cmd_set:    54                                          set命令(保存)总请求次数
        curr_items:    28                                       服务器当前存储的items数量

      二、在Discuz NT 3.0中配置Memcached服务

        在Discuz NT 3.0中配置Memcached服务较为简单,找到论坛根目录下的config目录,找到Memcached.config,打开,进行如下配置:

<?xml version="1.0"?>
<MemCachedConfigInfo xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <ApplyMemCached>(1)</ApplyMemCached>
    <ServerList>(2)</ServerList>
    <PoolName>DiscuzNT_MemCache</PoolName>
    <IntConnections>3</IntConnections>
    <MinConnections>3</MinConnections>
    <MaxConnections>5</MaxConnections>
    <SocketConnectTimeout>1000</SocketConnectTimeout>
    <SocketTimeout>3000</SocketTimeout>
    <MaintenanceSleep>30</MaintenanceSleep>
    <FailOver>true</FailOver>
    <Nagle>true</Nagle>
</MemCachedConfigInfo>

      (1)处为"true”的时候表示Discuz NT打开Memcached缓存功能,为"false”的时候表示关闭Memcached缓存功能。

      (2)处填写Memcached服务器的IP地址+端口,例如:127.0.0.1:11211

   三、二次开发监控Memcached状态

       Discuz NT的一个好处就是开源的,并且我们能够再上面很灵活的进行二次开发,这里,我们就以监控Memcached状态为例来做一个二次开发。具体的步骤是:

      1.下载Memcached的.Net的开发包,下载地址是:http://sourceforge.net/projects/memcacheddotnet/。

      2.在visual studio 2005或者2008中建立一个类库,例如命名为:MyBBS.BBS.Plugin.MemcachedStats,然后在项目点击右键,选择属性,将默认命名空间修改为:Discuz.Web,如图:

     

    3.将Memcached的.Net开发包解压,将将 Commons.dll,ICSharpCode.SharpZipLib.dll,log4net.dll,Memcached.ClientLibrary.dll 等放到bin目录,并且在项目中引用Memcached.ClientLibrary.dll.

    4.在项目中引用Discuz.Forum.

    5.在项目中增加类,命名为memcachedstats.cs.记得最好是小写,继承自Discuz.Forum.PageBase。然后在类中override showpage()函数,我们就可以在这里来写代码了,如下:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Collections;
using M=Memcached.ClientLibrary;

namespace Discuz.Web
{
    public class memcachedstats:Discuz.Forum.PageBase
    {
        public string MemcachedStatsOutput = string.Empty;
        protected override void ShowPage()
        {
            base.ShowPage();
            string[] servers = { "此处填写Memcachedf服务IP+端口" };
            M.SockIOPool pool = M.SockIOPool.GetInstance();
            pool.SetServers(servers);
            pool.InitConnections = 3;
            pool.MinConnections = 3;
            pool.MaxConnections = 5;

            pool.SocketConnectTimeout = 1000;
            pool.SocketTimeout = 3000;

            pool.MaintenanceSleep = 30;
            pool.Failover = true;

            pool.Nagle = false;
            pool.Initialize();
            this.pagetitle = "MemcachedStats";
            M.MemcachedClient mc = new Memcached.ClientLibrary.MemcachedClient();
            StringBuilder sb = new StringBuilder();
            Hashtable ht = mc.Stats();
            sb.AppendLine("Memcached Stats:<br>");
            sb.AppendLine("_______________________________________<br>");
            foreach (DictionaryEntry de in ht)
            {
                Hashtable info = (Hashtable)de.Value;
                foreach (DictionaryEntry de2 in info)
                {
                    sb.AppendLine(de2.Key.ToString() + ":&nbsp;&nbsp;&nbsp;&nbsp;" + de2.Value.ToString() + "<br>");
                }
            }
            MemcachedStatsOutput = sb.ToString();
        }
    }
}

    这样我们就将代码完成了,我们将Memcached服务的状态信息保存到了MemcachedStatsOutput 这个字段中了,那么我们怎么在页面上显示出来呢?在进行下一步之前,编译输出MyBBS.BBS.Plugin.MemcachedStats.dll然 后上传到论坛根目录的bin目录下。

    6.在论坛根目录下面的templete\default\中新建memcachedstats.htm,写入下面的代码:

<%template _header%>
<div id="nav">
    <div class="wrap s_clear">
    <a href="{config.forumurl}" class="title">{config.forumtitle}</a> &raquo; <strong>Memcached Stats</strong>
    </div>
</div>
<div class="wrap with_side s_clear help" id="wrap">
   <div class="side">
        <div class="sideinner">
        </div>
        </div>
        <div class="cpmain">
        <div class="cpcontent">
            <h3 class="lightlink">Memcached Stats</h3>
            <hr class="solidline"/>
            {MemcachedStatsOutput}
        </div>
        </div>
</div>
<%template _copyright%>
<%template _footer%>

     这里我们重点注意红色的部分,我们就是在这里来把我们上面的类库里面的MemcachedStatsOutput字段在这里输出的。

     7.进入论坛后台管理系统,点击“界面风格”——“模板管理”——“default”,这时我们就可以看到出现了memcachedstats这个模板了,勾中前面的复选框,然后选择“按选择的模板文件生成页面”。

     8.上面的工作完成之后,我们在浏览器中输入:您的论坛地址\memcachedstats.aspx,就可以看到统计的Memcached服务的信息了,如图:

 

四、结束语与参考信息

      怎么样,还是很简单的吧,当然这里仅仅是做了最基本的开发了,不过相信这些弄清楚了,其它的开发就不是很复杂了,大家也都可以开发出自己更多丰富多彩的功能了。

     下面列出的是其他的一些参考资料,希望对大家有帮助:

     Discuz NT 界面模板的基本语法:http://nt.discuz.net/doc/default.aspx?cid=42

     Memcached的安装:http://www.cnblogs.com/zjneter/archive/2007/07/19/822780.html

     网友编写的用php代码展示Memcached状态的代码:http://code.sixapart.com/svn/memcached/trunk/server/scripts/memcached-tool

·        ###################################################################################################

memcached 如果进程占用cpu很高

一客户占用到了 25%

把mencache内存大小从32m 改成256m 后 memcached 基本占用cpu 是0

可能分配的内存不够用了  大量的新缓存需要进入 同时大量的旧缓存又需要被淘汰出来 导致 一进一出非常频繁 从而导致服务性能下降

加大内存吧

操作如下,打开注册表,找到:
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server
其中的ImagePath项的值为:"c:\memcached\memcached.exe" -d runservice
改成:"c:\memcached\memcached.exe" -p 12345 -m 128 -d runservice

-p 12345 是端口

-m 128 是内存 128m

http://www.blogjava.net/BearRui/archive/2009/04/29/268117.html

 

运行 cmd

 D:\>cd D:\memcache

D:\memcache>memcached -d stop  #停止

D:\memcache>memcached -d start  #开始

D:\memcache>memcached -d restart  #重启


D:\memcache>

3
0
分享到:
评论
2 楼 zhangminglife 2012-11-02  
收录了,呵呵 用时候再拿出来!!呵呵
1 楼 davidchouwolf 2012-11-02  
sfaaaaaaaaaaaaaaaaaaaaaaaaaaaaa

相关推荐

    windows 上的安装Memcached及Memcached配置

    ### Memcached在Windows环境下的安装与配置详解 #### 一、Memcached的安装与基本配置 Memcached是一款高性能、分布式内存对象缓存系统,用于在动态应用中减少数据库负载,加速页面渲染,通过缓存数据库查询结果和...

    安装Memcached及Memcached配置.doc

    Memcached 安装和配置 Memcached 是一个自由的开源高速缓存系统,用于加速动态 web 应用程序的性能。它通过减少数据库负载和增加应用程序的响应速度来提高网站的性能。以下是 Memcached 的安装和配置详解。 安装 ...

    安装Memcached及Memcached配置[借鉴].pdf

    总结来说,Memcached是一个高效的内存缓存系统,它的安装和配置涉及多个步骤,包括安装依赖库、配置编译以及测试运行。在运维过程中,正确配置和管理Memcached对于优化Web应用性能、减少数据库压力至关重要。

    CentOS 安装配置memcached

    CentOS 安装配置 Memcached 在本文中,我们将详细介绍如何在 CentOS 系统上安装和配置 Memcached。Memcached 是一个高性能的分布式内存对象缓存系统,广泛应用于各种 web 应用程序中,以提高应用程序的性能和响应...

    linux下 php安装memcached扩展

    本文将详细介绍如何在 Linux 上安装和配置 PHP 的 Memcached 扩展。 #### 二、安装前准备 1. **确保环境已安装 PHP**:在开始安装 Memcached 扩展之前,请确保你的 Linux 系统已经安装了 PHP,并且版本兼容。 2. ...

    linux环境下memcached安装以及配置使用

    5. **查看Memcached配置文件** ```bash cat /etc/sysconfig/memcached ``` 在配置文件中可以看到几个重要的配置项: - `PORT`: Memcached监听的端口,默认为11211。 - `USER`: 用于运行Memcached服务的用户,...

    Memcached缓存资料

    《安装Memcached及Memcached配置.doc》 《Linux部署》 简介 memcached是一套分布式的快取系统,当初是Danga Interactive为了LiveJournal所发展的,但被许多软件(如MediaWiki)所使用。这是一套开放源代码软件,...

    Memcached安装配置及使用文档

    Memcached安装配置及使用文档,来源于网络,仅供参考

    在Linux上安装Memcached服务

    - 配置Memcached,指定libevent的安装路径:`# ./configure –with-libevent=/usr` - 编译源代码:`# make` - 安装到系统:`# make install` - 安装完成后,Memcached二进制文件通常位于`/usr/local/bin/`目录下...

    linux 安装memcached 详细

    ### Linux 下安装 Memcached 的详细步骤 #### 一、前言 Memcached 是一款高性能的分布式内存对象缓存系统,用于通过缓存数据库查询结果减少数据库负载,加速动态 Web 应用的访问速度,提高可扩展性。在 Linux 系统...

    PHP安装memcached

    - `./configure --with-php-config=/usr/local/php/bin/php-config --with-libmemcached-dir=/usr/local/libmemcached --disable-memcached-sasl`:配置编译参数,指定了PHP配置路径及`libmemcached`的路径,并禁用...

    memcached安装软件 libevent magent memcached

    本篇文章将详细讲解如何安装和配置memcached,以及与之相关的libevent和magent。 首先,我们需要了解libevent库。libevent是一个事件通知库,它允许程序处理多个网络连接,并有效地处理来自不同源的事件。在安装...

    Linux下安装memcached详细步骤

    ### Linux下安装memcached详细步骤 #### 一、前言 在Linux环境下部署memcached能够极大地提高应用程序的性能,尤其是在需要缓存...以上就是关于在Linux下安装memcached的详细步骤及注意事项。希望对大家有所帮助!

    MemCached安装与配置图解(windows).pdf

    ### MemCached在Windows环境下的安装与配置详解 #### 一、概述 MemCached是一种高性能、分布式内存对象缓存系统,可以极大地加速动态Web应用程序的速度,提高可扩展性。本文档将详细介绍如何在Windows 7 64位操作...

    Memcached安装和配置

    本文将详细介绍如何在Windows环境下安装和配置Memcached,并探讨其基本操作和状态查询。 首先,安装Memcached的步骤如下: 1. 访问 http://code.jellycan.com/memcached/ 下载适用于Windows的最新版本(例如1.2.6...

    安装memcached出现异常

    ### 安装memcached出现异常:具体问题及解决方案 #### 一、问题概述 在安装memcached的过程中,可能会遇到各种各样的错误。其中一种常见的情况是,在启动memcached服务时出现错误提示:“error while loading ...

    Windows 下安装 Memcached1

    1. **添加任务计划**:由于1.4.5及更高版本不再支持作为服务安装,可以使用任务计划程序来自动启动Memcached进程。首先,解压安装包至指定目录,然后以管理员身份运行以下命令将Memcached添加到任务计划程序中: ``...

Global site tag (gtag.js) - Google Analytics