telnet连接操作memcache服务器详解

memcache作为一款优秀的进程外缓存,常常被运用于高并发系统架构中。这里主要谈谈怎么通过telnet工具,查看memcache运行状况并对其key进行管理维护。假设memcache安装目录:/usr/local/memcached

1、启动memcache

代码如下:

[root@localhost ~]# /usr/local/memcached/bin/memcached -d -m 512  -u root -l 192.168.119.70 -p 12000 -c 512 -P /usr/local/memcached/memcached.pid

启动参数详解
 -d:以守护进程方式启动。如果该参数没有指定,当按ctrl+c命令结束,memcache自动关闭
 -m:分配给memcache使用的最大内存数 单位是m,默认是64m
 -u: 指定运行memcache的用户
 -l: 指定监听的ip地址
 -p: 指定监听的tcp端口号,可以通过-u指定udp端口.默认是11211
 -c: 最大并发连接数
 -P: 报错进程id的文件
 memcache 启动之后,我们就可以通过telnet连接memcache,对其进行简单操作管理。

2、telnet连接memcache

代码如下:

[root@localhost ~]# telnet 192.168.119.70 12000  
Trying 192.168.119.70... 
Connected to 192.168.119.70 (192.168.119.70). 
Escape character is '^]'.

连接成功之后,即可对memcache进行操作管理了,常用的命令有:

Ⅰ、添加修改

命令格式:<command> <key> <flags> <exptime> <bytes>\r\n<data block>\r\n

<command>:add, set或 replace

<key> :缓存的名字

<flag>:16位无符号整数,和key要存储的数据一起存储,并在程序get缓存时,返回。

<exptime>:过去时间,0 表示永远不过期,如果非零,表示unix时间或距此秒数

<bytes>:存储数据的字节数

\r\n: 表示换行回车

命令结果:

STORED :表示成功

NOT_STORED : 表示失败

a)、添加缓存

代码如下:

add id 1 0 4 
1234 
STORED

如果key已经存在,则会添加失败。

b)、修改缓存

代码如下:

replace id 1 0 4 
3456 
STORED

key存在时,成功;不存在时,失败。

c)、设置缓存

代码如下:

set id 1 0 4 
2345 
STORED

key不存在时,添加【add】;已存在时,替换【replace】。

Ⅱ、读取

命令格式:get <key>+\r\n

<key>+:表示一个或多个key,多个key时,用空格隔开

a)、读取单个key的缓存

代码如下:

get id 
VALUE id 1 4 
1234 
END

b)、读取多个key的缓存

代码如下:

get id name 
VALUE id 1 4 
3456 
VALUE name 1 3 
jim 
END

Ⅲ、删除

命令格式:delete <key> \r\n

<key>:要删除的key

删除id

代码如下:

delete id  
DELETED

Ⅳ、清空所有缓存

命令格式:flush_all

代码如下:

flush_all 
OK

Ⅴ、查看缓存服务器状态

命令:stats

代码如下:

stats 
STAT pid 2711     //进程id 
STAT uptime 2453  //总的运行时间,单位描述 
STAT time 1344856333  //当前时间 
STAT version 1.4.0 //版本 
STAT pointer_size 32    //服务器指针位数,一般32位操作系统是32 
STAT rusage_user 0.002999  //进程的累计用户时间  
STAT rusage_system 1.277805  //进程的累计系统事件 
STAT curr_connections 1  //当前连接数 
STAT total_connections 11  //服务器启动后,总连接数 
STAT connection_structures 11  //连接结构的数量 
STAT cmd_get 17   //总获取次数 
STAT cmd_set 1  //总写入次数 
STAT cmd_flush 1   //总的的清空次数 
STAT get_hits 1  //总的命中次数 
STAT get_misses 7   //获取没有命中次数 
STAT delete_misses //删除没有命中次数 
STAT delete_hits 4   //删除命中次数 
STAT incr_misses //递增操作没有命中次数  
STAT incr_hits //递增操作命中次数 
STAT decr_misses //递减操作没有命中的次数 
STAT decr_hits //递减操作命中的次数 
STAT cas_misses //cas设置没有命中次数 
STAT cas_hits //cas命中次数 
STAT cas_badval //cas操作找到key,但版本过期,没有设置成功 
STAT bytes_read 455    //总共获取数据量 
STAT bytes_written 1175  //总共写入数据量 
STAT limit_maxbytes 1048576  //最大允许使用内存,单位字节 
STAT accepting_conns 1     
STAT listen_disabled_num 0 
STAT threads 5   //当前线程数 
STAT conn_yields 0 
STAT bytes 56      //已用缓存空间 
STAT curr_items 1  //当前缓存的keyvalue数 
STAT total_items 7 //总共缓存的keyvalue数,包括过期删除的 
STAT evictions //通过删除keyvalue,释放内存次数 
END

Ⅵ、打印版本

命令:version

代码如下:

version 
VERSION 1.4.0

Ⅶ、打印内存信息

命令:stats slabs

代码如下:

stats slabs 
STAT 1:chunk_size 80 
STAT 1:chunks_per_page 13107 
STAT 1:total_pages 1 
STAT 1:total_chunks 13107 
STAT 1:used_chunks 1 
STAT 1:free_chunks 1 
STAT 1:free_chunks_end 13105 
STAT 1:get_hits 10 
STAT 1:cmd_set 10 
STAT 1:delete_hits 4 
STAT 1:incr_hits 0 
STAT 1:decr_hits 0 
STAT 1:cas_hits 0 
STAT 1:cas_badval 0 
STAT active_slabs 1 
STAT total_malloced 1048560 
END

3、退出telnet

代码如下:

quit

完!

(0)

相关推荐

  • 在telnet下操作memcache详解(操作命令详解)

    在定位问题.测试等时候经常需要对memcache的数据进行一些操作,但是其本身没有自带的客户端,所以只能通过telnet来进行操作. 通过telnet连接memcache. 复制代码 代码如下: telnet 127.0.0.1 11211 memcache写入操作 telnet写入memcache命令格式 复制代码 代码如下: <command name> <key> <flags> <exptime> <bytes>\r\n <data

  • 浅析memcache启动以及telnet命令详解

    1.启动Memcache 常用参数 复制代码 代码如下: -p <num> 监听的TCP端口(默认: 11211)-U <num> UDP监听端口 (默认: 11211, 0 时关闭)-d 以守护进程方式运行-u <username> 运行运行 Memcached的账户 非root用户-m <num> 最大的内存使用单位是MB 默认是64MB-c <num> 软连接数量默认是1024-v 输出警告和错误信息-vv 打印客户端的请求和返回信息-h

  • telnet连接操作memcache服务器详解

    memcache作为一款优秀的进程外缓存,常常被运用于高并发系统架构中.这里主要谈谈怎么通过telnet工具,查看memcache运行状况并对其key进行管理维护.假设memcache安装目录:/usr/local/memcached 1.启动memcache 复制代码 代码如下: [root@localhost ~]# /usr/local/memcached/bin/memcached -d -m 512  -u root -l 192.168.119.70 -p 12000 -c 512

  • C++利用MySQL API连接和操作数据库实例详解

    1.C++连接和操作MySQL的方式 系列文章: MySQL 设计和命令行模式下建立详解 C++利用MySQL API连接和操作数据库实例详解 在Windows平台,我们可以使用ADO.ODBC或者MySQL API进行连接和操作.ADO (ActiveX Data Objects,ActiveX数据对象)是Microsoft提出的一个用于存取数据源的COM组件.它提供了程序语言和统一数据访问方式OLE DB的一个中间层,也就是Microsoft提出的应用程序接口(API)用以实现访问关系或非关

  • Oracle数据操作和控制语言详解

    正在看的ORACLE教程是:Oracle数据操作和控制语言详解.SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML, 数据定义语言DDL,数据控制语言DCL.其中用于定义数据的结构,比如 创建.修改或者删除数据库:DCL用于定义数据库用户的权限:在这篇文章中我将详细讲述这两种语言在Oracle中的使用方法. DML语言 DML是SQL的一个子集,主要用于修改数据,下表列出了ORACLE支持的DML语句. 插入数据 INSERT语句常常用于向表中插入行,行中可以有特殊数据字段,或者可以

  • 基于python操作ES实例详解

    这篇文章主要介绍了基于python操作ES实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 安装 pip install elasticsearch5 # 安装对应版本的模块 创建ES对象 from elasticsearch5 import Elasticsearch # elasticsearch集群服务器的地址 ES = [ '127.0.0.1:9200' ] # 创建elasticsearch客户端 es = Elasticse

  • R语言对数据库进行操作的实例详解

    数据是关系数据库系统以规范化格式存储. 因此,要进行统计计算,我们将需要非常先进和复杂的Sql查询. 但R语言可以轻松地连接到许多关系数据库,如MySql,Oracle,Sql服务器等,并从它们获取记录作为数据框. 一旦数据在R语言环境中可用,它就变成正常的R语言数据集,并且可以使用所有强大的包和函数来操作或分析. 在本教程中,我们将使用MySql作为连接到R语言的参考数据库. RMySQL包 R语言有一个名为"RMySQL"的内置包,它提供与MySql数据库之间的本地连接. 您可以使

  • Springboot整合Netty实现RPC服务器详解流程

    目录 一.什么是RPC? 二.实现RPC需要解决那些问题? 1. 约定通信协议格式 RPC请求 RPC响应 2. 序列化方式 3. TCP粘包.拆包 4. 网络通信框架的选择 三.RPC服务端 四.RPC客户端 总结 一.什么是RPC? RPC(Remote Procedure Call)远程过程调用,是一种进程间的通信方式,其可以做到像调用本地方法那样调用位于远程的计算机的服务.其实现的原理过程如下: 本地的进程通过接口进行本地方法调用. RPC客户端将调用的接口名.接口方法.方法参数等信息利

  • Node服务端实战之操作数据库示例详解

    目录 连接数据库 insert语句 简化新增sql update语句 delete语句 连接数据库 本系列是使用node作为服务器开发的操作过程记录,记录一下主要的内容并且整理过程的脉络,以初学者的方式将学习内容记录下来,从0到1逐步的学习node,教程使用过程中用到的是基于express的node框架. const mysql = require('mysql') const db = mysql.createPool({ host: 'localhost', user: 'root', pa

  • MySQL数据库设计之利用Python操作Schema方法详解

    弓在箭要射出之前,低声对箭说道,"你的自由是我的".Schema如箭,弓似Python,选择Python,是Schema最大的自由.而自由应是一个能使自己变得更好的机会. Schema是什么? 不管我们做什么应用,只要和用户输入打交道,就有一个原则--永远不要相信用户的输入数据.意味着我们要对用户输入进行严格的验证,web开发时一般输入数据都以JSON形式发送到后端API,API要对输入数据做验证.一般我都是加很多判断,各种if,导致代码很丑陋,能不能有一种方式比较优雅的验证用户数据呢

  • php mysql PDO 查询操作的实例详解

    php mysql PDO 查询操作的实例详解 <?php $dbh = new PDO('mysql:host=localhost;dbname=access_control', 'root', ''); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $dbh->exec('set names utf8'); /*添加*/ //$sql = "INSERT INTO `user` SET `log

  • Hibernate迫切连接和普通连接的区别实例详解

    Hibernate 迫切连接和普通连接的区别 相关的介绍和解释在代码中已注释,大家可以参考. package com.baidu.test; import java.util.ArrayList; import java.util.LinkedHashSet; import java.util.List; import org.hibernate.Query; import org.hibernate.Session; import org.hibernate.SessionFactory; i

随机推荐