django其他缓存方法:(https://www.cnblogs.com/jishuweiwang/p/6110809.html

memcached版本 <1.5

1. memcached缓存系统安装

  ·在百度中下载 memcached 安装文件(http://www.runoob.com/memcached/window-install-memcached.html

  ·windows安装(linux安装:http://www.runoob.com/memcached/memcached-install.html):

1> 进入 memcached 目录

     2> 在终端输入:

    · memcachd.exe -d install:安装

    · memcached.exe -d uninstall:卸载

  命令说明:

  · memcached -d start:启动服务

  · memcached -d stop:关闭服务

  · 命令选项:

    · -p使用的TCP端口。默认为11211
    · -m最大内存大小。默认为64M
    · -vv用very vrebose模式启动,调试信息和错误输出到控制台
    · -d作为daemon在后台启动
    · -c最大运行的并发连接数,默认是1024,按照服务器的负载量来设定
    · -P设置保存Memcache的pid文件
    · -l监听的服务器IP地址,如果有多个地址的话
    · -u运行Memcache的用户,默认不能用root启动,所以当前用户为root用户时,需要用-u参数来指定

2. 在django中使用 memcached:

  · 首先要在django运行环境中安装:python-memcached(命令:pip install python-memcached)

    注意:如果没有安装会提示:找不到模块:memcache

· 然后在django中的.py文件中导入:from django.core.cache import cache 模块

  · 在 settings.py 文件中加入配置:

    CACHES = {

      'default': {

         'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',

        'LOCATION': [

          '172.19.26.240:11211', # 缓存地址1

          '172.19.26.242:11211', # 缓存地址2

         ]

        }

       }

   CACHES配置参数说明:

    每个缓存后端都可以设置附加参数,控制缓存行为。可配置如下参数:

    1)TIMEOUT

      cache 默认过期时间(seconds),未设置则为300s(5mins)

    2)OPTIONS

      可选项配置,不同的后端,可选项配置不同

    3)KEY_PREFIX

      默认会被自动加到所有缓存 keys 的前端

    4)VERSION

      默认缓存 keys 的 version

    5)KEY_FUNCTION

      生成最终缓存 keys 的函数路径

    6)像locmem, filesystem 和 database 缓存都实现了 cull 策略,参数如下:
     culling 策略参数(OPTIONS中):
      MAX_ENTRIES
      删除旧数据之前,允许在缓存中存放的最大数量,默认:300
      CULL_FREQUENCY
      当缓存数目达到 MAX_ENTRIES 时,就会删除部分缓存,删除率为1/CULL_REQUENCY, 如果 CULL_FREQUENCY = 2 ,当达到 MAX_ENTRIES 时,就会删除一半数据。默认值:3

    CACHES 配置参数概述 - 示例

    CACHES = {
      'default': {
        'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
        'LOCATION': '/var/tmp/django_cache',
        'TIMEOUT': 60,
      'OPTIONS': {
        'MAX_ENTRIES': 1000
      }
    }
   }

   注意:无效的参数会被忽略,不会影响整个项目

3. memcached的安全性:

  1>方法1:使用 -l 参数设置为只有本地可以连接:这种方式就只能通过本机才能连接,别的机器都不能访问,可以达到最好的安全性

  2>方法2:使用防火墙来关闭指定端口的访问

    ufw enable # 开启防火墙

    ufw disable # 关闭防火墙

    ufw default deny # 防火墙以禁止的方式打开,默认是关闭那些没有开启的端口

    ufw deny 端口号 # 关闭某个端口

    ufw allow 端口号 # 开启某个端口

4. memcached中的API接口:

  地址:http://www.runoob.com/Memcached/Memcached-tutorial.html

  在django中导入from django.core.cache import cache模块后,使用cache.memcached中的方法即可

  

    

django之memcached缓存系统的更多相关文章

  1. 6.memcached缓存系统

    1.memcached的安装和参数 memcached缓存系统一般还是部署在linux服务器上,所以这里只介绍linux上memcache的安装 首先切换到root用户,然后apt-get insta ...

  2. Linux下搭建Memcached缓存系统

    首先说下抱歉,博主近期单位经常加班.博客更新有点慢.希望大家理解,草稿箱里存了不少内容,等不忙时候一点点填坑~ 在一般的站点开发学习时候.都会把数据存放在RDBMS(关系型数据库系统(Relation ...

  3. Memcached 缓存系统简介

    memcached官网:http://memcached.org/ What is Memcached? Memcached是一个自由开源的,高性能,高并发,分布式内存对象缓存系统. Memcache ...

  4. (转)实战Memcached缓存系统(1)Memcached基础及示例程序

    1.Cache定义 (1)狭义概念:用于CPU的相对高速处理与主存(Main Memory)的相对低速处理的之间起到协调功能的硬件设备. (2)广义概念:用于速度相差较大的两种硬件之间,起到协调两者数 ...

  5. (转)实战Memcached缓存系统(7)Memcached的一些基础FAQ

    1. Memcached是什么? Memcached是分布式的内存对象缓存系统. 2. Memcached的基本数据结构是什么? Memcached是基于Key/Value对的HashMap.每一对, ...

  6. Django 学习之---缓存系统

    一.浏览器缓存机制 Cache-control策略(重点关注) Cache-Control与Expires的作用一致,都是指明当前资源的有效期,控制浏览器是否直接从浏览器缓存取数据还是重新发请求到服务 ...

  7. (转)实战Memcached缓存系统(8)Memcached异步实时读写问题的解决方案SAC

    在使用Memcached时,一般实时读写的场景并不多见.但多是Memcached写入后,在一定时间后才会有读操作.但是如果应用场景,是写入后瞬间即会有读操作呢?似乎没有什么特别之处,我们依然可以这样写 ...

  8. (转)实战Memcached缓存系统(4)Memcached的CAS协议

    1. 什么是CAS协议 很多中文的资料都不会告诉大家CAS的全称是什么,不过一定不要把CAS当作中国科学院(China Academy of Sciences)的缩写.Google.com一下,CAS ...

  9. (转)实战Memcached缓存系统(3)Memcached配置参数初解

    一.基本参数 在我们第一次安装Memcached时,一般都是用过这个命令: memcached -m 512 -u root -d -l 127.0.0.1 -p 11211 我们先来解释这几个参数的 ...

随机推荐

  1. 【剑指Offer】包含min函数的栈 解题报告

    [剑指Offer]包含min函数的栈 解题报告 标签(空格分隔): 牛客网 题目地址:https://www.nowcoder.com/questionTerminal/beb5aa231adc45b ...

  2. Nginx应用场景配置

    Nginx应用全入门 基础回顾 Nginx是什么? Nginx是一个高性能的HTTP和反向代理web服务器,特点是内存少,并发能力强 Nginx能做什么 Http服务器(Web服务器) 反向代理服务器 ...

  3. Redis常见使用场景

    缓存 数据共享分布式 分布式锁 全局ID 计数器 限流 位统计 购物车 用户消息时间线timeline 消息队列 抽奖 点赞.签到.打卡 商品标签 商品筛选 用户关注.推荐模型 排行榜 1.缓存 St ...

  4. HAT

    目录 概 主要内容 代码 Rade R. and Moosavi-Dezfooli S. Helper-based adversarial training: reducing excessive m ...

  5. [炼丹术]YOLOv5目标检测学习总结

    Yolov5目标检测训练模型学习总结 一.YOLOv5介绍 YOLOv5是一系列在 COCO 数据集上预训练的对象检测架构和模型,代表Ultralytics 对未来视觉 AI 方法的开源研究,结合了在 ...

  6. [zbar]zbar条码扫描器解析示例

    // // Created by leoxae on 2020/3/30. // #include "BarCodeRecogntion.h" string BarCode::Ba ...

  7. Arm64架构下编译便携Python

    这段时间,我一直忙于将 Rainbond 源码构建模块移植到 Arm64/aarch64 架构中.对于 Python 项目而言,可以直接通过源代码编译成为可运行在各种容器平台之上的容器镜像.这个过程不 ...

  8. c++—通讯录管理系统

    一.运用所学的结构体.地址指针等基础知识,完成通讯录管理系统 二.系统主要有以下6个功能: 1.添加联系人2.显示联系人 3.删除联系人 4.查找联系人5.修改联系人 6.清空联系人 1 #inclu ...

  9. Java程序设计基础笔记 • 【第3章 运算符与表达式】

    全部章节   >>>> 本章目录 3.1 运算符(一) 3.1.1 赋值运算符 3.1.2 算数运算符 3.1.3 复合运算符 3.1.4 实践练习(一) 3.1.5 实践练习 ...

  10. C#中的显式转换

    大多数编程语言都支持显示转换,也称为强制转换,它与隐式转换相呼应,比如,一般的,整型可以通过隐式转换成浮点型,而浮点型需要通过强制转换成整型: int i = 32; double d = i;//整 ...