linux Memcached服务

简介:

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信

 

一、安装libevent

 

memcached依赖于libevent API

tar xf libevent-2.0.20-stable.tar.gz

cd libevent-2.0.20

./configure --prefix=/usr/local/libevent

make

make install

 

echo "/usr/local/libevent/lib"> /etc/ld.so.conf.d/libevent.conf

ldconfig

 

二、安装配置memcached

 

tar xf memcached-1.4.15.tar.gz

cd memcached-1.4.15

./configure --prefix=/usr/local/memcached--with-libevent=/usr/local/libevent -enable-sasl

make

make install

 

启动 memcached

/usr/local/memcached/bin/memcached -m 128-n 20 -f 1.1 -vv -u nobody –d

 

memcached参数及启动

-d                      以守护程序(daemon)方式运行

-u nobody               指定用户,如果当前为root用户,需要用该参数指定用户

-P /tmp/memcached.pid   pid到指定目录

-m 200                  数据内存数量,单位为MB,不包含memcached本身占用

-M                      内存不够时禁止LRU

-n 48                   初始chunk=key+suffix+value+32结构体,默认为48字节

-f 1.25                 增长因子,默认为1.25

-L                      启用大内存页,可以降低内存浪费,改进性能

-l 127.0.0.1            监听的IP地址,本机可以不设置此参数

-p 11211                TCP端口,默认11211

-U 11211                UDP端口,默认112110为关闭

-c 1024                 最大并发连接数,默认1024,最好设置为200  

-t 4                    线程数,默认为4memcached采用NIO,所以线程多没用

-R 20                   每个event连接最大并发数,默认20

-C                      禁用CAS命令(可以禁止版本计数,减少开销)

-S                      启用sasl进行用户认证

 

连接到 memcached

telnet localhost 11211

 

基本 memcached 客户机命令

   set          添加新的键值对,如果以存在,将会重写

   add          当缓存中不存在键时,add命令才会向缓存中添加一个键值对。如果缓存中已经存在键,则之前的值将仍然保持相同,并且将获得响应NOT_STORED

   replace      仅当键已经存在时,replace命令才会替换缓存中的键。如果缓存中不存在键,那么您将从 memcached 服务器接受到一条 NOT_STORED响应。

   get          命令用于检索与之前添加的键值对相关的值。

   gets         get,但返回的信息要多余get

   delete       用于删除memcached 中的任何现有值。您将使用一个键调用 delete,如果该键存在于缓存中,则删除该值。如果不存在,则返回一条NOT_FOUND 消息。

   append       在一个存在的项后增加数据

   prepend      在一个存在的项首增加数据

   stats        当前memcached实例信息

   flush_all    清理缓存中的所有键值对

   stats slabs  显示slabs信息,可以获取每个slabschunksize长度,从而确定数据到底保存在哪个slab

   stats items  显示slabitem数目

 

查看、关闭memcached

ps -ef|grep memcache #查看其进程

kill `cat /tmp/memcached.pid`#关闭其进程

 

三、安装PHPmemcache扩展

 

tar xf memcache-2.2.5.tgz

cd memcache-2.2.5

/usr/local/php/bin/phpize

./configure--with-php-config=/usr/local/php/bin/php-config --enable-memcache

make

make install

 

vim /usr/local/php/lib/php.ini

extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

(上面红色字体来源安装后的提示)

 

四、Nginx整合memcached:

 

server {

       listen       80;

       server_name  www.benet.com;

 

       #charset koi8-r;

 

       #access_log logs/host.access.log  main;

 

       location / {

                set $memcached_key $uri;

                memcached_pass     127.0.0.1:11211;

                default_type       text/html;

                error_page         404 @fallback;

       }

 

       location @fallback {

                proxy_pass http://192.168.1.10;

       }

}











本文转自 meteor_hy 51CTO博客,原文链接:http://blog.51cto.com/zuoshou/1665344,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
Linux 网络安全 Docker
盘古栈云,创建带ssh服务的linux容器
创建带ssh服务的linux容器
287 146
|
3月前
|
缓存 安全 Linux
六、Linux核心服务与包管理
在没有网络的情况下,使用系统安装光盘是获取RPM包的常用方法。场景二:配置本地文件镜像源 (使用系统安装光盘/ISO)(检查RPM包的GPG签名以保证安全) 或。YUM/DNF包管理工具 (yum/dnf)(此处可以放置您为本主题制作的思维导图)处理依赖问题的危险选项 (应极力避免)(覆盖文件、替换已安装包)。(list) 则是列出文件。(query file) 是。(假设系统安装光盘已挂载到。信息 (verbose)。(upgrade) 选项。(all) 已安装的包。(package) 选项
349 11
|
8月前
|
Linux Shell
在Linux、CentOS7中设置shell脚本开机自启动服务
以上就是在CentOS 7中设置shell脚本开机自启动服务的全部步骤。希望这个指南能帮助你更好地管理你的Linux系统。
661 25
|
9月前
|
Linux iOS开发 MacOS
Gitea Enterprise 23.4.0 (Linux, macOS, Windows) - 本地部署的企业级 Git 服务
Gitea Enterprise 23.4.0 (Linux, macOS, Windows) - 本地部署的企业级 Git 服务
266 0
Gitea Enterprise 23.4.0 (Linux, macOS, Windows) - 本地部署的企业级 Git 服务
在Linux中,怎么把脚本添加到系统服务里,即用 service 来调用?
在Linux中,怎么把脚本添加到系统服务里,即用 service 来调用?
|
11月前
|
Linux Docker 容器
Linux 中停止 Docker 服务报 warning 导致无法彻底停止问题如何解决?
在 Linux 系统中,停止 Docker 服务时遇到警告无法彻底停止的问题,可以通过系统管理工具停止服务、强制终止相关进程、检查系统资源和依赖关系、以及重置 Docker 环境来解决。通过以上步骤,能够有效地排查和解决 Docker 服务停止不彻底的问题,确保系统的稳定运行。
762 19
|
11月前
|
监控 Linux
Linux systemd 服务启动失败Main process exited, code=exited, status=203/EXEC
通过以上步骤,可以有效解决 systemd 服务启动失败并报错 `Main process exited, code=exited, status=203/EXEC` 的问题。关键在于仔细检查单元文件配置、验证可执行文件的有效性,并通过日志分析具体错误原因。确保可执行文件路径正确、文件具有执行权限,并且可以独立运行,将有助于快速定位和解决问题。
4778 7
|
Linux 应用服务中间件 Shell
linux系统服务二!
本文详细介绍了Linux系统的启动流程,包括CentOS 7的具体启动步骤,从BIOS自检到加载内核、启动systemd程序等。同时,文章还对比了CentOS 6和CentOS 7的启动流程,分析了启动过程中的耗时情况。接着,文章讲解了Linux的运行级别及其管理命令,systemd的基本概念、优势及常用命令,并提供了自定义systemd启动文件的示例。最后,文章介绍了单用户模式和救援模式的使用方法,包括如何找回忘记的密码和修复启动故障。
291 5
linux系统服务二!
|
Linux 应用服务中间件 Shell
linux系统服务!!!
本文详细介绍了Linux系统(以CentOS7为例)的启动流程,包括BIOS自检、读取MBR信息、加载Grub菜单、加载内核及驱动程序、启动systemd程序加载必要文件等五个主要步骤。同时,文章还对比了CentOS6和CentOS7的启动流程图,并分析了启动流程的耗时。此外,文中还讲解了Linux的运行级别、systemd的基本概念及其优势,以及如何使用systemd管理服务。最后,文章提供了单用户模式和救援模式的实战案例,帮助读者理解如何在系统启动出现问题时进行修复。
236 3
linux系统服务!!!
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####