设为首页 收藏本站
查看: 937|回复: 0

[经验分享] LNMP+Memcached

[复制链接]

尚未签到

发表于 2018-12-25 07:30:01 | 显示全部楼层 |阅读模式
  

  

  LNMP+Memcached

这里我还是使用LNMP三层结构配置的实验环境,请点击链接:http://junwang.blog.运维网.com/5050337/1390100

  以下是拓扑图:

新增一台memcached服务器:
system:        redhat 6.4_x64
ipaddress:    192.168.100.51

1、memcached服务器上
1)安装
libevent-2.0.16-stable.tar.gz
#./configure --prefix=/usr/local/libevent
# make &&make install
# echo "/usr/local/libevent/lib" >/etc/ld.so.conf.d/libevent.conf
# ldconfig -v
memcached-1.4.5.tar.gz
# ./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent/
# make &&make install

2)为memcached提供启动脚本
# vim /etc/init.d/memcached
#!/bin/bash
# Init file for memcached
# chkconfig: - 86 14
# description: Distributed memory caching daemon
#
# processname: memcached
# config: /etc/sysconfig/memcached
. /etc/rc.d/init.d/functions
## Default variables
PORT="11211"
USER="nobody"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS=""
[ -f /usr/local/memcached/memcached.conf ] && . /usr/local/memcached/memcached.conf
RETVAL=0
prog="/usr/local/memcached/bin/memcached"
desc="Distributed memory caching"
lockfile="/var/lock/subsys/memcached"
start() {
        echo -n $"Starting $desc (memcached): "
        daemon $prog -d -p $PORT -u $USER -c $MAXCONN -m $CACHESIZE
        RETVAL=$?
        echo
        [ $RETVAL -eq 0 ] && touch $lockfile
        return $RETVAL
}
stop() {
        echo -n $"Shutting down $desc (memcached): "
        killproc $prog
        RETVAL=$?
        echo
        [ $RETVAL -eq 0 ] && rm -f $lockfile
        return $RETVAL
}
restart() {
        stop
        start
}
reload() {
        echo -n $"Reloading $desc ($prog): "
        killproc $prog -HUP
        RETVAL=$?
        echo
        return $RETVAL
}
case "$1" in
  start)
        start
        ;;
  stop)
        stop
        ;;
  restart)
        restart
        ;;
  condrestart)
        [ -e $lockfile ] && restart
        RETVAL=$?
        ;;      
  reload)
        reload
        ;;
  status)
        status $prog
        RETVAL=$?
        ;;
   *)
        echo $"Usage: $0 {start|stop|restart|condrestart|status}"
        RETVAL=1
esac
exit $RETVAL

3)为memcached服务脚本提供配置文件
# vim /usr/local/memcached/memcached.conf
PORT="11211"
USER="nobody"
MAXCONN="1024"
CACHESIZE="128"

# chmod +x /etc/init.d/memcached
# chkconfig --add memcached
# service memcached start

4)验证是否正常
# netstat -tnlp 查看是否有11211端口开启
使用telent查看memcached相关状态
# telnet localhost 11211
Trying 192.168.0.102...
Connected to 192.168.0.102.
Escape character is '^]'.
stats
STAT pid 9125 #进程ID
STAT uptime 2444 #服务器运行秒数
STAT time1396572286 #服务器当前unix时间戳
STAT version 1.4.17 #服务器版本
STAT libevent 2.0.16-stable #libevent版本号
STAT pointer_size 64 #操作系统指针大小(这台服务器是64位的)
STAT rusage_user 0.091986 #进程累计用户时间
STAT rusage_system 0.107983 #进程累计系统时间
STAT curr_connections 10 #当前打开连接数
STAT total_connections 13 #曾打开的连接总数
STAT connection_structures 11 #服务器分配的连接结构数
STAT reserved_fds 20 #内部使用的FD数
STAT cmd_get 1 #执行get命令总数
STAT cmd_set 1 #执行set命令总数
STAT cmd_flush 0 #执行flush命令总数
STAT cmd_touch 0 #执行touch命令总数
STAT get_hits 1 #get命中次数
STAT get_misses 0 #get未命中次数
STAT delete_misses 0 #delete未命中次数
STAT delete_hits 0 #delete命中次数
STAT incr_misses 0 #incr未命中次数
STAT incr_hits 0 #incr命中次数
STAT decr_misses 0 #decr未命中次数
STAT decr_hits 0 #decr命中次数
STAT cas_misses 0 #cas未命中次数
STAT cas_hits 0 #cas命中次数
STAT cas_badval 0 #使用擦拭次数
STAT touch_hits 0 #touch命中次数
STAT touch_misses 0 #touch未命中次数
STAT auth_cmds 0 #认证处理的次数
STAT auth_errors 0 #认证失败次数
STAT bytes_read 7 #读取字节总数
STAT bytes_written 0 #写入字节总数
STAT limit_maxbytes 134217728 #现在的内存大小为128M
STAT accepting_conns 1 #目前接受的新接数
STAT listen_disabled_num 0 #失效的监听数
STAT threads 4 #当前线程数
STAT conn_yields 0 #连接操作主支放弃数目
STAT hash_power_level 16 #hash等级
STAT hash_bytes 524288 #当前hash表等级
STAT hash_is_expanding 0 #hash表扩展大小
STAT bytes 0 #当前存储占用的字节数
STAT curr_items 0 #当前存储数据总数
STAT total_items 0 #启动以来存储的数据总数
STAT expired_unfetched 0 #已过期但未获取的对象数目
STAT evicted_unfetched 0 #已驱逐但未获取的对象数目
STAT evictions 0 #LRU释放的对象数目
STAT reclaimed 0 #用已过期的数据条目来存储新数据的数目
END
使用quit退出当前交互模式
当然了,你的数据肯定和我的不一样,我的是做完整个实验显示的结果,所以不用纠结有的地方不一样

  

  

  

  
2、php服务器上安装配置memcache客户端:
1)安装
# pecl install memcache
说明:看到下面的信息,就说明php memcache 模块安装完成,输入yes
2)配置php
在php配置文件中加入
extension = "memcache.so"
memcache.chunk_size = 32768
  

  ======================================================================
或者,安装也可以使用源码安装                                                                                                                                ||
# tar xf memcache-3.0.8.tgz                                                                                                                                   ||
# phpize                                                                                                                                                                  ||        
# ./configure --with-php-config=/usr/local/php/bin/php-config --enable-memcache                                        ||
# make && make install                                                                                                                                         ||            
注意保存最后的一串代码                                                                                                                                           ||
/usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/                                                                       ||   
由于memcache没有自动添加ini文件                                                                                                                         ||
# mkdir /etc/php.d                                                                                                                                                 ||
# vim /etc/php.d/memcache.ini                                                                                                                             ||
extension = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/memcache.so"                         ||   
========================================================================
  然后重启php-fpm

  # service php-fpm restart

  查看一下当前php己加载的模块:
# php -m

3)测试验证
些时我们在浏览器中输入http://192.168.100.11/index.php
查看是否有下图

建立测试页面:
# vim /web/php/memcached.php

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-655445-1-1.html 上篇帖子: ubuntu 12.04 memcached安装 下篇帖子: memcached2.6.14安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表