memcached

数据结构模型:

结构化数据:关系型数据库;mysql、mariadb、oracledb

半结构化数据:xml、json、nosql

非结构化数据:文件系统;

缓存系统的种类:
代理式缓存;
旁路式缓存;
memcached的特性:
k/v缓存:可序列化数据;存储项:key/value,标志,过期时间;
功能的实现一半依赖于服务端,一半依赖客户端;
分布式缓存;互不通信的分布式集群;
O(1)的执行效率;
清理过期数据:LRU(最近最少使用算法):a、缓存项过期;b、缓存空间用尽;

分布式系统主机路由:1、取模法;2、一致性hash;

安装memcached:监听端口:11211/tcp, 11211/udp
# yum install memcached
service unit: /var/lib/systemd/systemd/memcached.service 其配置文件/etc/sysconfig/memcached
命令:
存储类命令:set, add, replace(重新定义), append(后插), prepend(前插)
获取数据类命令:get, delete, incr(增加几个值)/decr(减少几个值)
统计类命令:stats,  stats items, stats slabs, stats sizes
清空:flush_all
memcached程序的常用选项:
-l  IP:监听的IP地址;
-m <num>:用于缓存数据的内存空间大小,单位为MB,默认为64;
-c <num>:最大并发连接数;默认为1024;
-p PORT:tcp端口
-U PORT:UDP端口;0为关闭;
-t <num>:用于处理请求的最大线程数;
-M:内存耗尽时返回错误信息,而不是LRU算法清理;
-f <num>: growth factor, 增长因子;默认为1.25倍;
-n <num>:指明最小的slab大小,默认是96;
-S:借助sasl认证
php连接memcached服务器的扩展:memcache:php-pecl-memcache;
libmemcached:提供了相关的memcached管理工具
python-memcache:python连接memcached服务的扩展
默认没有认证功能,但可借助于sasl实现认证
sasl:simple authentication layer简单认证安全层
示例:lamp基于memcached做php的会话保持;

前提:
1、配置各php支持使用memcache;
2、安装配置好memcached服务器,这里假设其地址为172.16.200.11,端口为11211;

一、配置php将会话保存至memcached中

编辑php.ini文件,确保如下两个参数的值分别如下所示:
session.save_handler = memcache
session.save_path = “tcp://172.16.200.11:11211?persistent=1&weight=1&timeout=1&retry_interval=15”

二、测试

新建php页面setsess.php,为客户端设置启用session:
<?php
session_start();
if (!isset($_SESSION[‘www.MageEdu.com’])) {
$_SESSION[‘www.MageEdu.com’] = time();
}
print $_SESSION[‘www.MageEdu.com’];
print “<br><br>”;
print “Session ID: ” . session_id();
?>

新建php页面showsess.php,获取当前用户的会话ID:
<?php
session_start();
$memcache_obj = new Memcache;
$memcache_obj->connect(‘172.16.200.11’, 11211);
$mysess=session_id();
var_dump($memcache_obj->get($mysess));
$memcache_obj->close();
?>

<?php
// Generating cookies must take place before any HTML.
// Check for existing “SessionId” cookie
$session = $HTTP_COOKIE_VARS[“SessionId”];
if ( $session == “” ) {
// Generate time-based unique id.
// Use user’s IP address to make more unique.
$session = uniqid ( getenv ( “REMOTE_ADDR” ) );
// Send session id – expires when browser exits
SetCookie ( “SessionId”, $session );
}
?>
<HTML>
<HEAD><TITLE>Session Test</TITLE></HEAD>
<BODY> <br> 16 Current session id: <?php echo $session ?>
</BODY></HTML>

示例:LNMMP,反代ha1和ha2做keepalived高可用;负载均衡rs1和rs2,利用memcached做php session保持;如图
1
memcached、mariadb-server、nfs:ip  192.168.71.40
#

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/102886

(0)
N26-深圳-城市蜗牛N26-深圳-城市蜗牛
上一篇 2018-07-13 20:54
下一篇 2018-07-14 18:26

相关推荐

  • Linux 系统启动故障恢复

    如果你的Linux系统一直重启或者因为某些服务无法开启的问题导致机器故障不能正常使用,那我们就从系统启动模式来考虑,是不是/etc/inittab文件下默认被设置成为6模式,或者/etc/crontab文件中是否加入的能导致系统一直重启的命令,或者说在系统启动中因为一个服务一直打不开导致系统卡在服务启动界面而无法进入系统,那我们就来看看这些让人哭笑不得的问题怎么解决!

    2018-05-10
  • VMware安装CentOS6系统图文详解

    在VMware上安装CentOS6系统,分两个步骤,根据自己的需求创建虚拟机,然后将CentOS6系统光盘挂载到虚拟机中安装系统。 一:创建虚拟机 点击创建虚拟机   这里我们选择系统推荐的典型模式。   我们这里先不选择安装程序光盘映像文件,随后再安装系统,选择下面一项。 操作系统选择Linux  CentOS 64位的。 由于我们计划…

    2018-03-31
  • 8. systemd的新特性及awk用法

    1、简述systemd的新特性及unit常见类型分析,能够实现编译安装的如nginx\apache实现通过systemd来管理
    2、描述awk命令用法及示例(至少3例)
    3、描述awk函数示例(至少3例)

    2018-07-07
  • MySQL用户和权限管理

    MySQL用户和权限管理

    2018-06-15
  • 追风筝的人

    IO重定向 管道 tr 用户管理 组管理 文件权限管理 文本处理工具
    Grep和正则表达式 扩展的正则表达式和VIM

    Linux笔记 2018-04-08
  • Linux文件管理及bash基础特性

      1、Linux系统文件管理类命令及其常用方法、相关示例演示。 Linux系统文件管理类命令主要有cp、mv、rm ①     cp命令:copy cp命令用于复制文件或目录,分单源、多源复制两种情况。 单源复制: 命令格式:cp [OPTION]… [-T] SOURCE DEST 如果DEST不存在,则先创建此文件,并复制源文件的…

    2018-07-01