zoukankan      html  css  js  c++  java
  • memcached在linux安装

    服务器端主要是安装memcache服务器端.
    下载:http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz
    另外,Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent,libevent的最新版本是libevent-1.3。(如果你的系统已经安装了libevent,可以不用安装)
    官网:http://www.monkey.org/~provos/libevent/
    下载:http://www.monkey.org/~provos/libevent-1.3.tar.gz

    用wget指令直接下载这两个东西.下载回源文件后。
    1.先安装libevent。这个东西在配置时需要指定一个安装路径,即./configure –prefix=/usr;然后make;然后make install;
    2.再安装memcached,只是需要在配置时需要指定libevent的安装路径即./configure –with-libevent=/usr;然后make;然后make install;
    这样就完成了Linux下Memcache服务器端的安装。详细的方法如下:

    1.分别把memcached和libevent下载回来,放到 /tmp 目录下:
    # cd /tmp
    # wget http://www.danga.com/memcached/dist/memcached-1.2.0.tar.gz
    # wget http://www.monkey.org/~provos/libevent-1.2.tar.gz

    2.先安装libevent:
    # tar zxvf libevent-1.2.tar.gz
    # cd libevent-1.2
    # ./configure –prefix=/usr
    # make
    # make install

    3.测试libevent是否安装成功:
    # ls -al /usr/lib | grep libevent
    lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent-1.2.so.1 -> libevent-1.2.so.1.0.3
    -rwxr-xr-x 1 root root 263546 11?? 12 17:38 libevent-1.2.so.1.0.3
    -rw-r–r– 1 root root 454156 11?? 12 17:38 libevent.a
    -rwxr-xr-x 1 root root 811 11?? 12 17:38 libevent.la
    lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent.so -> libevent-1.2.so.1.0.3
    还不错,都安装上了。

    4.安装memcached,同时需要安装中指定libevent的安装位置:
    # cd /tmp
    # tar zxvf memcached-1.2.0.tar.gz
    # cd memcached-1.2.0
    # ./configure –with-libevent=/usr
    # make
    # make install
    如果中间出现报错,请仔细检查错误信息,按照错误信息来配置或者增加相应的库或者路径。
    安装完成后会把memcached放到 /usr/local/bin/memcached ,

    5.测试是否成功安装memcached:
    # ls -al /usr/local/bin/mem*
    -rwxr-xr-x 1 root root 137986 11?? 12 17:39 /usr/local/bin/memcached
    -rwxr-xr-x 1 root root 140179 11?? 12 17:39 /usr/local/bin/memcached-debug

    启动Memcached服务
    1.启动Memcache的服务器端:
    # /usr/local/bin/memcached -d -m 10 -u root -l 192.168.141.64 -p 12000 -c 256 -P /tmp/memcached.pid

    -d选项是启动一个守护进程,
    -m是分配给Memcache使用的内存数量,单位是MB,我这里是10MB,
    -u是运行Memcache的用户,我这里是root,
    -l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.0.200,
    -p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,
    -c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,
    -P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid,

    2.如果要结束Memcache进程,执行:

    # kill `cat /tmp/memcached.pid`

    也可以启动多个守护进程,不过端口不能重复。

    测试Memcached:

    [root@localhost /]# telnet 192.168.141.64 12000
    Trying 192.168.141.64...
    Connected to 192.168.141.64 (192.168.141.64).
    Escape character is '^]'.
    set key1 0 60 4
    zhou
    STORED
    get key1
    VALUE key1 0 4
    zhou
    END


    至此Memcached安装成功!

    常见问题:

    1.如果启动Memcached服务的时候遇到了

    /usr/local/bin/memcached: error while loading shared libraries: libevent-1.2.so.1: cannot open shared object file: No such file or directory;

    解决方案:

    [root@localhost bin]# LD_DEBUG=libs memcached -v  #查看memcached需要加载那些lib.

    [root@localhost bin]# ln -s /usr/lib/libevent-1.2.so.1 /usr/lib64/libevent-1.2.so.1
    [root@localhost bin]# /usr/local/bin/memcached -d -m 100 -u root -p 12000 -c 1000 -P /tmp/memcached.pid
    [root@localhost bin]# ps -aux

    可以看到启动的Memcached服务了.

    方式二

    将libevent-1.3c.so.1拷贝到任何一个列出的lib 下就可以了。
    或者 软链接
    ln -s /Data/libevent/lib/libevent-1.3b.so.1 /usr/lib/libevent-1.3c.so.1 
    或者 修改vi /etc/profile文件。
    export LIBRARY_PATH=:/usr/local/lib:"/usr/local/BerkeleyDB.4.3/lib":/usr/local/lib:/opt/Ice-3.1/lib:/usr/lib:/home/mahaibo/install/lib

    2.把Memcached服务加载到Linux的启动项中.万一机器断电系统重启.那么Memcached就会自动启动了.

    假如启动Memcache的服务器端的命令为:
    # /usr/local/bin/memcached -d -m 10 -u root -l 192.168.141.64 -p 12000 -c 256 -P /tmp/memcached.pid容来自17jquery

    想开机自动启动的话,只需在/etc/rc.d/rc.local中加入一行,下面命令
    /usr/local/bin/memcached -d -m 10 -p 12000 -u apache -c 256 
    上面有些东西可以参考一下:即,ip不指定时,默认是本机,用户:最好选择是:apache / deamon / nobody

    这样,也就是属于哪个用户的服务,由哪个用户启动。


    其它:

    [root@pyap01 ~]# memcached -h
    memcached 1.4.24
      -p <num> TCP port number to listen on (default: 11211)
      -U <num> UDP port number to listen on (default: 11211, 0 is off)
      -s <file> UNIX socket path to listen on (disables network support)
      -A enable ascii "shutdown" command
      -a <mask> access mask for UNIX socket, in octal (default: 0700)
      -l <addr> interface to listen on (default: INADDR_ANY, all addresses)
        <addr> may be specified as host:port. If you don't specify
        a port number, the value you specified with -p or -U is
        used. You may specify multiple addresses separated by comma
        or by using -l multiple times
      -d run as a daemon
      -r maximize core file limit
      -u <username> assume identity of <username> (only when run as root)
      -m <num> max memory to use for items in megabytes (default: 64 MB)
      -M return error on memory exhausted (rather than removing items)
      -c <num> max simultaneous connections (default: 1024)
      -k lock down all paged memory. Note that there is a
        limit on how much memory you may lock. Trying to
        allocate more than that would fail, so be sure you
        set the limit correctly for the user you started
        the daemon with (not for -u <username> user;
        under sh this is done with 'ulimit -S -l NUM_KB').
      -v verbose (print errors/warnings while in event loop)
      -vv very verbose (also print client commands/reponses)
      -vvv extremely verbose (also print internal state transitions)
      -h print this help and exit
      -i print memcached and libevent license
      -V print version and exit
      -P <file> save PID in <file>, only used with -d option
      -f <factor> chunk size growth factor (default: 1.25)
      -n <bytes> minimum space allocated for key+value+flags (default: 48)
      -L Try to use large memory pages (if available). Increasing
        the memory page size could reduce the number of TLB misses
        and improve the performance. In order to get large pages
        from the OS, memcached will allocate the total item-cache
        in one large chunk.
      -D <char> Use <char> as the delimiter between key prefixes and IDs.
        This is used for per-prefix stats reporting. The default is
        ":" (colon). If this option is specified, stats collection
        is turned on automatically; if not, then it may be turned on
        by sending the "stats detail on" command to the server.
      -t <num> number of threads to use (default: 4)
      -R Maximum number of requests per event, limits the number of
        requests process for a given connection to prevent
        starvation (default: 20)
      -C Disable use of CAS
      -b Set the backlog queue limit (default: 1024)
      -B Binding protocol - one of ascii, binary, or auto (default)
      -I Override the size of each slab page. Adjusts max item size
        (default: 1mb, min: 1k, max: 128m)
      -F Disable flush_all command
      -o Comma separated list of extended or experimental options
      - (EXPERIMENTAL) maxconns_fast: immediately close new
        connections if over maxconns limit
      - hashpower: An integer multiplier for how large the hash
        table should be. Can be grown at runtime if not big enough.
        Set this based on "STAT hash_power_level" before a
        restart.
      - tail_repair_time: Time in seconds that indicates how long to wait before
        forcefully taking over the LRU tail item whose refcount has leaked.
        Disabled by default; dangerous option.
      - hash_algorithm: The hash table algorithm
        default is jenkins hash. options: jenkins, murmur3
      - lru_crawler: Enable LRU Crawler background thread
      - lru_crawler_sleep: Microseconds to sleep between items
        default is 100.
      - lru_crawler_tocrawl: Max items to crawl per slab per run
        default is 0 (unlimited)
      - lru_maintainer: Enable new LRU system + background thread
      - hot_lru_pct: Pct of slab memory to reserve for hot lru.
        (requires lru_maintainer)
      - warm_lru_pct: Pct of slab memory to reserve for warm lru.
        (requires lru_maintainer)
      - expirezero_does_not_evict: Items set to not expire, will not evict.
        (requires lru_maintainer)

  • 相关阅读:
    视频监控中运动物体检测与跟踪----相邻帧差法和三帧差法
    辨异 —— 近义词(词组)
    H264 编解码框架简单介绍
    一个build.xml实例
    SQL server 错误代码对比表
    怎样使用oracle 的DBMS_SQLTUNE package 来执行 Sql Tuning Advisor 进行sql 自己主动调优
    Android中ExpandableListView控件基本使用
    c++中sort()及qsort()的使用方法总结
    Oracle动态SQL语句
    Oracle Minus 取差集
  • 原文地址:https://www.cnblogs.com/heric/p/5794253.html
Copyright © 2011-2022 走看看