前言


一、资源

Ref: https://www.imooc.com/video/2870

二、缓存

缓存:静态缓存、Memcache、redis缓存

Ref: [Laravel] 09 - Functional models

put(), add(), forever(), has(), get(), pull(), forget()
配置文件:[config/cache.php]

注意,本篇的缓存是php,而非基于laravel。

静态缓存


一、生成静态缓存

获取文件的当前目录:dirname(__FILE__)

目录操作:is_dir(), mk_dir()

写文件:file_put_contents ----> ref: http://www.runoob.com/php/func-filesystem-file-put-contents.html

<?php

class File {
private $_dir;
const EXT = '.txt'; public function __construct() {
$this->_dir = dirname(__FILE__) . '/files/';
}

public function cacheData($key, $value = '', $cacheTime = 0) {
$filename = $this->_dir . $key . self::EXT;

     // 写!
if($value !== '') { // 删!
if(is_null($value)) {
return @unlink($filename);
} // (1).创建目录
$dir = dirname($filename);
if(!is_dir($dir)) {
mkdir($dir, 0777);
} $cacheTime = sprintf('%011d', $cacheTime); // (2).以json字符串的形式写入到file中
return file_put_contents($filename, $cacheTime . json_encode($value));
}      --------------------------------------------------------------------------

// 读!
if(!is_file($filename)) {
return FALSE;
}
$contents = file_get_contents($filename);
$cacheTime = (int)substr($contents, 0 ,11);
$value = substr($contents, 11);
if($cacheTime !=0 && ($cacheTime + filemtime($filename) < time())) {
unlink($filename);
return FALSE;
}  
return json_decode($value, true); }
} $file = new File(); echo $file->cacheData('test1');  # 使用cacheData

cacheData的另一个使用:生成了 index_mk_cache.txt

<?php

require_once('./file.php');

$data = array(
  'id' => 1,
  'name' => 'singwa',
  'type' => array(4,5,6),
  'test' => array(1,45,67 => array(123, 'tsysa'),),
};

----------------------------------------------------
$file = new File();
if($file->cacheData('index_mk_cache', $data)) {
  echo "success";
} else {
  echo "err";
}

二、获取静态缓存

没有第二个参数,就表示是”获取“。

$file = new File();
if($file->cacheData('index_mk_cache')) {
  echo "success";
} else {
  echo "err";
}

三、删除静态缓存

删除文件的函数:

unlink($filename);

Memcache、Redis缓存


一、简介

二、开启Redis服务

  • 打开redis的端口服务
redis-server 6379.conf
  • 进入安装目录
cd /wxh/redis-stable/src
  • 进入命令行
$ redis-cli
127.0.0.1:6379

三、终端链接Redis

Set and Get

12sec后超时删除,del手动删除

四、PHP连接Redis

Step 01: 安装phpredis扩展。

Step 02:

$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->set('singwal', 123); $redis->setex('singwa2', 15, 'xxxxxx');

Step 03:

$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->get('singwal');
var_dump($redis->get('singwal');

五、操作 Memcache

方式一

连接:memcache_connect()

设置:memcache_set()

获取:memcache_get()

方式二

连接:memcache_obj->connect()

设置:memcache_obj->set()

获取:memcache_obj->get()

定时任务


一、简介

在LINUX中,周期执行的任务一般由cron这个守护进程来处理[ps -ef|grep cron]。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。
cron的配置文件称为“crontab”,是“cron table”的简写。

  • 定时格式

  • 定时例子

二、Crontab操作

  • cron服务

cron是一个linux下 的定时执行工具,可以在无需人工干预的情况下运行作业。

  service crond start    //启动服务
  service crond stop //关闭服务
  service crond restart //重启服务
  service crond reload //重新载入配置
  service crond status //查看服务状态
  • 写定时任务
sudo crontab -e
  • 列出定时任务
sudo crontab -l
  • 删掉所有的定时任务
sudo crontab -r
  • 示范

利用Crontab定时执行该文件即可

[Laravel] 11 - WEB API : cache & timer的更多相关文章

  1. [Laravel] 12 - WEB API : cache implement

    前言 Ref: https://www.imooc.com/video/2873 服务端如何为客户端(app)的首页提供数据接口, 本篇用此作为例子演示接口的实现. 单例模式 一.三大原则 单例实现 ...

  2. [Laravel] 10 - WEB API : wrapper

    前言 一.常用的解决方案 React 前端 + PHP (Laravel) 后端 Such as "some exposure to WEB API’s and/or RESTful“. 使 ...

  3. [Laravel] 13 - WEB API : update & error tracking

    前言 一.大纲 Ref: https://www.imooc.com/video/3134 版本升级分析以及数据表设计 版本升级分析 掌握如何设计版本升级数据表 版本升级接口开发以及APP演示 二.数 ...

  4. [Laravel] 14 - REST API: Laravel from scratch

    前言 一.基础 Ref: Build a REST API with Laravel API resources Goto: [Node.js] 08 - Web Server and REST AP ...

  5. [转]Web API OData V4 Keys, Composite Keys and Functions Part 11

    本文转自:https://damienbod.com/2014/09/12/web-api-odata-v4-keys-composite-keys-and-functions-part-11/ We ...

  6. 返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, .net 4.5 带来的更方便的异步操作

    原文:返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, ...

  7. Asp.Net Web API中使用Session,Cache和Application的几个方法

    在ASP.NET中,Web Api的控制器类派生于ApiController,该类与ASP.NET的Control类没有直接关系,因此不能像在Web MVC中直接使用HttpContext,Cache ...

  8. ABP 教程文档 1-1 手把手引进门之 AngularJs, ASP.NET MVC, Web API 和 EntityFramework(官方教程翻译版 版本3.2.5)含学习资料

    本文是ABP官方文档翻译版,翻译基于 3.2.5 版本 转载请注明出处:http://www.cnblogs.com/yabu007/  谢谢 官方文档分四部分 一. 教程文档 二.ABP 框架 三. ...

  9. [水煮 ASP.NET Web API2 方法论](1-1)在MVC 应用程序中添加 ASP.NET Web API

    问题 怎么样将 Asp.Net Web Api 加入到现有的 Asp.Net MVC 项目中 解决方案 在 Visual Studio 2012 中就已经把 Asp.Net Web Api 自动地整合 ...

随机推荐

  1. Mysql启动失败

    错误提示: 服务名无效 错误原因: mysql服务没有安装. 解决方法: 管理员的权限运行cmd 用dos命令进入到mysql安装目录下再进入到bin目录下 运行mysqld -install命令

  2. 2016年7款最佳 Java 框架

    毫无疑问,Java 是目前最为流行的编程语言之一,这里我们挖掘出了一些比较受欢迎的框架的有效信息,它们可以减轻全球软件开发人员的日常工作. RebelLabs的一项调查显示,通过在线Java用户论坛( ...

  3. c++内存管理的一些资料

      C++内存分配方式详解--堆.栈.自由存储区.全局/静态存储区和常量存储区 如何动态调用DLL中的导出类 在dll中导出类,并结合继承带来的问题 如何更好的架构一个界面库,欢迎大家一起讨论 pim ...

  4. AngularJS中转换响应内容

    从远程API获取到的响应内容,通常是json格式的,有时候需要对获取到的内容进行转换,比如去除某些不需要的字段,给字段取别名,等等. 本篇就来体验在AngualrJS中如何实现. 在主页面,还是从co ...

  5. android 布局文件 ScrollView 中的 listView item 显示不全解决方案

    import android.content.Context;import android.util.AttributeSet;import android.widget.ListView; /** ...

  6. Java调用使用SSL/HTTPS协议来传输的axis webservice服务

    使用SSL/HTTPS协议来传输 Web服务也可以使用SSL作为传输协议.虽然JAX-RPC并没有强制规定是否使用SSL协议,但在tomcat 下使用HTTPS协议. 1.使用JDK自带的工具创建密匙 ...

  7. Python 文件夹及文件操作

    import os import os.path from shutil import copy def copyfile(src, dst): count = 1 for filename in o ...

  8. Array and Linkedlist区别与操作的时间复杂度(转载)

    转载自:http://blog.csdn.net/tm_wb/article/details/6319146 数组链表堆栈和队列 数组链表堆栈和队列是最基本的数据结构,任何程序都会涉及到其中的一种或多 ...

  9. AndroidStudio下加入百度地图的使用(四)——路线规划

    上一章中我们已经完成了API常用的方法及常量属性的使用,这一章向大家介绍一下地图的重要功能-路线规划. (1) 定义API中的路线查询类: RoutePlanSearch mSearch = Rout ...

  10. [Functional Programming] Using Lens to update nested object

    For example, in React application, we have initial state; const data = { nextId: 4, todoFilter: 'SHO ...