首页 > 系统服务 > 详细

Memcached (二)YUM安装和编译安装

时间:2017-02-27 11:09:40      阅读:219      评论:0      收藏:0      [点我收藏+]


YUM安装:

它依赖于libevent,不过这个一般都是系统自带的。另外我这里把Memcached安装到一个单独的服务器,其实生产环境中它也是单独部署的。

一般epel源中会有memcached,我们来看一下

yum list all memcached*

技术分享

安装

技术分享

rpm -ql memcached  看一下生成的文件

第一个是服务脚本文件、第二个是配置文件、第三个和第四个是工具

技术分享

启动,用命令启动需要指定用户,YUM安装时会自动创建memcached用户。-vv是显示启动过程。由于没有加-d参数,所以是前台运行。

这里可以看到内存分配过程,默认的内存最大64M,默认chunk大小48字节,增长因子是1.25倍。

第一个是96,后面的10922是说分配了多少个96字节的chunk

第二个是120,它是961.25倍,后面的8738是分配了多少个96字节的chunk

后面一次类推。

技术分享

配置文件的内容也比较少

技术分享

我们以服务的形式启动

service memcached start

技术分享

查看启动端口

技术分享


编译安装:

从这里下载最新版Memcached:http://memcached.org/

从这里下载libeventhttp://libevent.org/  

先编译安装libevent:因为编译安装memcached它会依赖这个库。

[]# tar -xzf libevent-2.1.8-stable.tar.gz 
[]# cd libevent-2.1.8-stable
[]# ./configure --prefix=/usr/local/libevent

技术分享

make && make install

技术分享

安装完成

技术分享

安装Memcached

[]# tar -xzf memcached1.4.34.tar.gz
[]# cd memcached1.4.34
[]# ./configure --prefix=/usr/local/memcached1.4.34 --with-libevent=/usr/local/libevent/

技术分享

make && make install

技术分享

安装完毕

技术分享创建运行账号

groupadd -r memcached
useradd -r -g memcached -s /sbin/nologin memcached

技术分享

启动memcached,要切换到安装目录中的bin目录中,因为没有配置环境变量

./memcached -u memcached -d

技术分享

添加一个环境变量

这样以后再执行memcached命令是就不需要切换目录了

vim /etc/profile.d/memcached.sh

添加下面的内容:
#!/bin/bash
MC_PATH=/usr/local/memcached1.4.34
export PATH=$PATH:$MC_PATH/bin

chmod +x /etc/profile.d/memcached.sh
. /etc/profile.d/memcached.sh

技术分享

验证一下

技术分享

设置成系统服务

memcached源码包中的scripts目录中自带这样一个脚本,拷贝到/etc/rc.d/init.d中即可

技术分享

cp memcached.sysv /etc/rc.d/init.d/memcached
chmod +x /etc/rc.d/memcached
chkconfig --add /etc/rc.d/memcached
chkconfig --list | grep memcached
chkconfig memcached on

技术分享

下面可以根据你的需要修改一下这个脚本,主要是启动参数

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

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

#设置你想要端口
PORT=11211
#设置运行账号
USER=memcached
#指定最大连接数量
MAXCONN=1024
#指定memcached使用的最大内存
CACHESIZE=64
OPTIONS=""
#指定安装路径
MEMCACHED_BIN_PATH=/usr/local/memcached1.4.34/bin

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

# Check that networking is up.
if [ "$NETWORKING" = "no" ]
then
    exit 0
fi

RETVAL=0
prog="memcached"

#这里引用了一些变量用于设置启动参数,你可以自行添加其他启动参数在这里引用
start () {
    echo -n $"Starting $prog: "
    # 确保这个目录 /var/run/memcached 存在,并且memcached用户有权限读写
    chown $USER /var/run/memcached
    #这里写全路径否则找不到,如果你觉得路径太长你可以写一个变量在这里引用。
    #daemon $MEMCACHED_BIN_PATH/memcached -d -p ......
    daemon /usr/local/memcached1.4.34/bin/memcached -d -p $PORT -u $USER  -m $CACHESIZE -c $MAXCONN -P /var/run/memcached/memcached.pid $OPTIONS
    RETVAL=$?
    echo
    [ $RETVAL -eq 0 ] && touch /var/lock/subsys/memcached
}
stop () {
    echo -n $"Stopping $prog: "
    killproc memcached
    RETVAL=$?
    echo
    if [ $RETVAL -eq 0 ] ; then
        rm -f /var/lock/subsys/memcached
        rm -f /var/run/memcached/memcached.pid
    fi
}

restart () {
    stop
    start
}


# See how we were called.
case "$1" in
    start)
        start
        ;;
    stop)
    stop
    ;;
    status)
    status memcached
    ;;
    restart|reload)
    restart
    ;;
    condrestart)
    [ -f /var/lock/subsys/memcached ] && restart || :
    ;;
    *)
    echo $"Usage: $0 {start|stop|status|restart|reload|condrestart}"
    exit 1
esac

exit $?

建立目录

技术分享

KILL掉之前启动的进程,然后我们用服务脚本进行启动

技术分享

本文出自 “小恶魔的家” 博客,请务必保留此出处http://littledevil.blog.51cto.com/9445436/1901472

Memcached (二)YUM安装和编译安装

原文:http://littledevil.blog.51cto.com/9445436/1901472

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!