Memcached命令行, Memcached数据导出和导入, php连接memcached, memcached中存储sessions

2024-03-16 17:38

本文主要是介绍Memcached命令行, Memcached数据导出和导入, php连接memcached, memcached中存储sessions,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Memcached命令行

[root@draft ~]# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
set key1 1 0 3  
abc
STORED
get key1
VALUE key1 1 3
abc
END
replace key1 1 100 3
def
STORED
get key1
VALUE key1 1 3
def
END
add key2 1 20 2
ab
STORED
get key2
VALUE key2 1 2
ab
END
get key2
END
get key1
ENDset key3 1 0 3
ghj
STORED
get key3
VALUE key3 1 3
ghj
END
delete key3
DELETED
get key3
END

Memcached语法规则

  <command name> <key> <flags> <exptime> <bytes>\r\n <data block>\r\n   注:\r\n在windows下是Enter键    <command name> 可以是set, add, replace   set表示按照相应的<key>存储该数据,没有的时候增加,有的时候覆盖   add表示按照相应的<key>添加该数据,但是如果该<key>已经存在则会操作失败   replace表示按照相应的<key>替换数据,但是如果该<key>不存在则操作失败。   <key> 客户端需要保存数据的key  <flags> 是一个16位的无符号的整数(以十进制的方式表示)。 该标志将和需要存储的数据一起存储,并在客户端get数据时返回。 客户端可以将此标志用做特殊用途,此标志对服务器来说是不透明的。   <exptime> 为过期的时间。 若为0表示存储的数据永远不过期(但可被服务器算法:LRU 等替换)。 如果非0(unix时间或者距离此时的秒数),当过期后,服务器可以保证用户得不到该数据(以服务器时间为标准)<bytes> 需要存储的字节数,当用户希望存储空数据时<bytes>可以为0   <data block>需要存储的内容,输入完成后,最后客户端需要加上\r\n(直接点击Enter)作为结束标志。  

Memcached 导出导入

[root@draft ~]# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
set k1 1 3600 3
abc
STORED
set k2 1 300 3
cde
STORED
set k3 1 0 3
efg
STORED
get k1
VALUE k1 1 3
abc
END
get k3
VALUE k3 1 3
efg
END
^]telnet> quit
Connection closed.
[root@draft ~]# memcached-tool 127.0.0.1:11211 dump
Dumping memcache contentsNumber of buckets: 1Number of items  : 3
Dumping bucket 1 - 3 total items
add k2 1 1575960644 3
cde
add k1 1 1575963927 3
abc
add k3 1 1575960294 3   #不过期的项目,备份时变成时间戳,恢复后变成过期;
efg
[root@draft ~]# memcached-tool 127.0.0.1:11211 dump > dump.txt  #备份;
Dumping memcache contentsNumber of buckets: 1Number of items  : 3
Dumping bucket 1 - 3 total items
[root@draft ~]# systemctl restart memcached   #重启清除数据,不重启会导不进去;
[root@draft ~]# memcached-tool 127.0.0.1:11211 stats
#127.0.0.1:11211   Field       Valuecurr_items           0
[root@draft ~]# nc 127.0.0.1 11211 < dump.txt  #恢复;
STORED
STORED
STORED
[root@draft ~]# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
get k1
VALUE k1 1 3
abc
END
get k2
VALUE k2 1 3
cde
END
get k3   #过期值为空;
END

PHP5.6连接memcached

  1006  2019/12/06 19:57:35wget -c http://www.apelearn.com/bbs/data/attachment/forum/memcache-2.2.3.tgz tar zxf memcache-2.2.3.tgz1052  2019/12/06 20:31:48cd /root/memcache   #进入解压后的包;1054  2019/12/06 20:32:33/usr/local/php-fpm/bin/phpize  #运行phpize,生成configure文件;yum install -y m4			#可能需要这个包;yum install -y autoconf   #可能需要这个包;1056  2019/12/06 20:33:31./configure --with-php-config=/usr/local/php-fpm/bin/php-config  #路径是php的目录;1058  2019/12/06 20:33:43make1059  2019/12/06 20:33:52make install
Installing shared extensions:     /usr/local/php-fpm/lib/php/extensions/no-debug-non-zts-20131226/      #最后输出语句;
[root@draft memcache-2.2.3]# ls /usr/local/php-fpm/lib/php/extensions/no-debug-non-zts-20131226/   #在目录下生成so文件;
memcache.so  opcache.a  opcache.so1064  2019/12/06 20:36:28vim /usr/local/php-fpm/etc/php.ini   #配置文件路径;extension=memcache.so  #添加这个语句;  [root@tanyvlinux3 no-debug-zts-20180731]# /usr/local/php/bin/php -i |grep dir  #查询模块目录
extension_dir => /usr/local/php-fpm/lib/php/extensions/no-debug-non-zts-20131226 => /usr/local/php-fpm/lib/php/extensions/no-debug-non-zts-20131226[root@tanyvlinux3 no-debug-zts-20180731]# /usr/local/php/bin/php -i |grep ini    #查询ini信息;
Configuration File (php.ini) Path => /usr/local/php-fpm/etc
Loaded Configuration File => /usr/local/php-fpm/etc/php.ini1073  2019/12/06 20:42:33service php-fpm restart
[root@draft ~]# /usr/local/php-fpm/bin/php -m |grep memcache  #查看模块是否增加;
memcache
  • 测试连接
[root@draft ~]# curl www.apelearn.com/study_v2/.memcache.txt > 1.php 2>/dev/null   #下载测试php文件或直接生成;
[root@draft ~]# cat 1.php   #程序的意思就是使用Memcache作为变量(增加模块后,可调用Memcache作为变量),新建显示,删除显示,另外可存入不同数据类型;
<?php
//连接Memcache Memcache
$mem = new Memcache;
$mem->connect("localhost", 11211);
//保存数据
$mem->set('key1', 'This is first value', 0, 60);
$val = $mem->get('key1');
echo "Get key1 value: " . $val ."<br>";
//替换数据
$mem->replace('key1', 'This is replace value', 0, 60);
$val = $mem->get('key1');
echo "Get key1 value: " . $val . "<br>";
//保存数组数据
$arr = array('aaa', 'bbb', 'ccc', 'ddd');
$mem->set('key2', $arr, 0, 60);
$val2 = $mem->get('key2');
echo "Get key2 value: ";
print_r($val2);
echo "<br>";
//删除数据
$mem->delete('key1');
$val = $mem->get('key1');
echo "Get key1 value: " . $val . "<br>";
//清除所有数据
$mem->flush();
$val2 = $mem->get('key2');
echo "Get key2 value: ";
print_r($val2);
echo "<br>";
//关闭连接
$mem->close();
?>[root@draft ~]# /usr/local/php-fpm/bin/php 1.php   #运行结果;
Get key1 value: This is first value<br>Get key1 value: This is replace value<br>Get key2 value: Array
([0] => aaa[1] => bbb[2] => ccc[3] => ddd
)
<br>Get key1 value: <br>Get key2 value: <br>
  • php7使用的包
 1018  2019/12/06 20:09:53git clone https://github.com/websupport-sk/pecl-memcache memcache   #php7要使用这个包;使用memcache的较新版本;https://pecl.php.net/package/memcached  #要区分开两个工具;https://pecl.php.net/package/memcache

使用Memcached存放session

  • 修改php的pool文件(最后两行),php5是修改php-fpm.conf文件(也是相当于php7的pool文件)
注意最后一行的分号,IP;[root@draft php-fpm]# cat /usr/local/php-fpm/etc/php-fpm.conf
[global]
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
php_value[session.save_handler] = memcache
php_value[session.save_path] = " tcp://127.0.0.1:11211 "
  • 使用php页面测试session,页面内容如下
    [root@draft php-fpm]# cat /usr/share/nginx/html/2.php
<?php 
session_start(); 
if (!isset($_SESSION['TEST'])) { 
$_SESSION['TEST'] = time(); 
} 
$_SESSION['TEST3'] = time(); 
print $_SESSION['TEST']; 
print "<br><br>"; 
print $_SESSION['TEST3']; 
print "<br><br>"; 
print session_id(); 
?> 

请自行做好web,web与php连接的相关事项

  • 测试
[root@draft php-fpm]# curl 127.0.0.1/2.php
1576123039<br><br>1576123039<br><br>85b014km0h019vp7b63t68aif2   #正常的结果;
[root@draft php-fpm]# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
get 85b014km0h019vp7b63t68aif2    #get一个键;
VALUE 85b014km0h019vp7b63t68aif2 0 37    
TEST|i:1576123039;TEST3|i:1576123039;   #返回值;session已存在memcached中;
END
^]      telnet> quit
Connection closed.
[root@draft php-fpm]# memcached-tool  127.0.0.1:11211 dump   #使用dump查看memcached储存的值;
Dumping memcache contentsNumber of buckets: 2Number of items  : 2
Dumping bucket 1 - 1 total items
add key1 0 1576066113 3
123
Dumping bucket 3 - 1 total items
add 85b014km0h019vp7b63t68aif2 0 1576088482 37
TEST|i:1576123039;TEST3|i:1576123039;
  • 对比不修改session语句时(恢复php配置文件,php-fpm.conf),php生成的session文件都保存在/tmp下;
[root@draft php-fpm]# curl 127.0.0.1/2.php
1576124128<br><br>1576124128<br><br>n1b6rhium4i8rae5ajt390bfj6 
[root@draft php-fpm]# ll /tmp/sess_n1b6rhium4i8rae5ajt390bfj6 
-rw-------. 1 php-fpm php-fpm 37 12月 12 12:15 /tmp/sess_n1b6rhium4i8rae5ajt390bfj6

这篇关于Memcached命令行, Memcached数据导出和导入, php连接memcached, memcached中存储sessions的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/816221

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os