热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

jpgraph缓存系统使用说明

在之前的phpjpgraph教程中,有提到过使用jpgraph在生成大量图表时负担是非常重的,为了减轻WEB服务器上使用jpgraph的负载一般有两种方法:提供专门的jpgraph服务器来进行图表生成;或者使用合理的缓存机制来缓解压力。对于大部分PHP开
在之前的php jpgraph教程中,有提到过使用jpgraph在生成大量图表时负担是非常重的,为了减轻WEB服务器上使用jpgraph的负载一般有两种方法:提供专门的jpgraph服务器来进行图表生成;或者使用合理的缓存机制来缓解压力。对于大部分PHP开发者来说利用缓存机制减轻jpgraph负载是最实用的方法。jpgraph类库支持两种显著提高性能的方法,即使用本教程所描述的内建缓存系统以及使用PHP加速器NuSphere PHP加速器。下图给出了jpgraph类库中缓存系统的概述:


jpgraph类库缓存机制图解

jpgraph类库缓存机制图解



  启用jpgraph类库缓存系统

  启用或关闭jpgraph缓存系统是通过jpg-config.php中的三个定义进行控制的

1
2
3
4
5
1、DEFINE("USE_CACHE",true)

2、DEFINE("READ_CACHE",true)

3、DEFINE("CACHE_DIR","/tmp/jpgraph_cache/")

  以上三个开关中USE_CACHE是开启缓存系统的主开关,必须设置为true。

  第二个开关READ_CACHE很少需要改变。第二个开关,基本上告诉JpGraph是否应该不断查询高速缓存中的内容。设置为false,主开关设置为true,将在缓存中总是产生一个新的更新的图像文件,这个新图像将发送回浏览器。

  第三个定义不是真正的开关而是一个指定目录以告知jpgraph类库使用什么目录作为缓存目录(即缓存图像存储的地方),缓存目录(CACHE_DIR)可以设置为任意目录但是需要牢记的是缓存目录对于运行的PHP程序必须可读写。

  jpgraph缓存目录提示:给定的目录名必须是一个绝对目录路径而不是一个文件的相对根目录。

  缓存文件的权限限制

  注:本节仅适用于Unix的衍生系统其具有组和文件所有权的概念。

  有两个额外的设置将允许控制组合文件的权限设置

1
2
3
DEFINE('CACHE_FILE_GROUP','www')

DEFINE('CACHE_FILE_MOD',0664)

  CACHE_FILE_GROUP指定哪个组应设置缓存图像文件。如果为空,则组将和运行的PHP程序相同。CACHE_FILE_MOD指定图像文件的文件权限。如果为空,PHP使用的默认权限将被设置在文件上。

  当PHP运行在命令行(使用PHP的CLI版本)文件的权限和组通常会设置运行PHP suer之一。请记住,一般的普通用户不允许更改组“WWW”(默认Apache2的目录)。

  在程序中使用缓存

  jpgraph类库启用缓存时主要有以下原则

  图表程序第一次被调用的时候与往常一样,脚本将会运行到最后将图片返回至游览器。但是,如果启用缓存,JpGraph将自动获得存储在缓存目录中生成的图像的副本。

  当图表脚本下一次执行时检查看看是否在缓存目录中已经生成这个图表脚本对应的图片。

  如果存储在缓存目录中的图片是可用的,jpgraph类库将检查图片的新旧程度。如果图片的新旧度超过规定,图表脚本将像往常一样产生最新的图片并存储在缓存目录中。

  如果在缓存目录中的图片是当前的,则将不会执行脚本的剩余部分,而是直接读取图片并送至游览器。

  通过上面的描述可以看到需要指定几个参数,比如,存储图片时需要使用什么名称,超过多少时间时图片被认定已陈旧。

  第一个参数,文件名,可以手动指定或jpgraph类库可以基于图表脚本的名称自动创建一个文件名。

  所有这些参数都是在初始化一个图表实例时通过调用Graph()指定的。下面的实例中将使用jpgraph类库自动定义的缓存文件名,同时设定缓存中的图片只有60分钟的有效期,超过将需要更新。

1
2
3
4
5
6
7
8
9

// ... includes
 
$graph = new Graph($width, $height, 'auto', 60);
 
// ... rest of the graph script
 
$graph->Stroke();
?>

  这意味着当程序被再次调用时,在60分钟内,将在初始化函数Graph()调用后直接返回图片而不需要执行脚本中的其他代码。对于基本的缓存使用方法这些是必须的,启用缓存并提供文件名和超时值,其余都通过类库来处理。

  jpgraph缓存使用提示:如果你想“永远”不超时,你可以指定0(或保留参数为空)的超时值。要重新生成图像,你将不得不手动从缓存中删除的图像文件。

  人工控制缓存图片

  这些实用功能在3.0.5版本中已添加、在之前的版本中也是可能实现的,但需要更多的代码。如果你需要这个功能,请更新到最新版本。

  人工需要做两部分

  1、检查缓存中是否存在缓存图片并且是有效时间内的。

  2、如果是,则将图片文件送至游览器。如果缓存文件已超时,那么就需要像往常一样构造图表并自动将图片存储在缓存中。下面的实例说明了这种情况

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

$width = ...;
$height = ...;
$cachefilename = GenImgName();
$graph = new Graph($width,$height);
 
//检查缓存文件是否存在,是否有效
$valid = $graph->cache->IsValid($cachefilename);
 
if( $valid ) {
    // 如果有效可以做任何事情,比如在下面的函数中实现,然后将图表返回至游览器
    doSomeProcessingIfNecessary();
 
    $graph->cache->StreamImgFile($graph->img,$cachefilename);
} else {  
    //如果缓存文件不存在或不有效,就需要向往常一样构建图表
 
    // 告诉jpgraph我们需要缓存此文件
    $timeout = ...;
    $graph->SetupCache($cachefilename,$timeout);
 
    //图表程序的剩余部分
    ...
    // 像往常一样返回图表,同时也会在缓存目录中存储一份副本
    $graph->Stroke();
}
?>

  使用缓存客户端CSIM,详细的将会在后续介绍,这里只要了解一下即可

  您还可以使用图像缓存系统(CSIM)。缓存系统接口在这种情况下稍有不同,因为缓存需要存储缓存图像和缓存的图像映射。

  由于增加了复杂性,CSIM脚本不发送回图像,而是一个预先格式化的HTML页面。与非CSIM缓存主要有两个主要区别:

  1、缓存版本将不会存储在之前定义的缓存目录中。其使用不同的缓存目录。

  2、脚本想要与CSIM一起使用缓存系统需要调用格外的方法,CheckCSIMCache()来检查缓存。

  缓存客户端CSIM使用提示:当使用CSIM时在脚本最后必须调用Graph::StrokeCSIM()方法而不是Graph::Stroke()

  使用CSIM缓存你需要调用Graph::CheckCSIMCache()。由于使用非CSIM缓存时,需要提供缓存文件名和可选项超时时间,如果没有指定默认超时时间是60分钟。

  使用CSIM不发送图片至游览器的理由是其发送一个HTML页面,其中包换了图像映射的坐标和”” 的标签,其将引用图片脚本,但是如果缓存中有图片则将引用静态图片。

  根据jpgraph类库的安装CSIMCACHE_DIR的定义也有要求。其必须是普通HTTP/PHP程序可以访问的一个目录,默认情况下,如果不指定,则将创建一个csimcache目录。默认设置的缺点是目录必须也是PHP程序可写的目录,最佳的办法是重新使用标准缓存相同的目录。但是也需要PHP和HTTP服务器通过htdocs root访问。

  CheckCSIMCache()方法将会检查现有缓存版本的缓存,如果发现则将返回并停止脚本的执行。所以这个调用必须在创建图表实例$graph = Graph($width,$height)之后首先调用。

  使用CSIM和缓存的程序脚本的总体结构如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

require_once( 'jpgraph.php');
 
// ... any necessary includes
 
$width = ...
$height = ...
$graph = new Graph($width,$height);
 
// 检查缓存并设定10分钟的有效期
$graph->CheckCSIMCache('csim_image1',10);
 
//如果缓存存在,这里将停止执行脚本并将缓存的HTML文件送至游览器
 
// 构造和初始化
 
// 最后返回HTML文件
$graph->StrokeCSIM();
?>

  注意不需要传递任何参数给最后的调用StrokeCSIM()函数。CSIM缓存通过在缓存目录中存储两个文件来工作,一个文件是图片,另一个文件对应于图片映射的HTML文件。HTML文件引用静态图片文件。


推荐阅读
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 探讨了小型企业在构建安全网络和软件时所面临的挑战和机遇。本文介绍了如何通过合理的方法和工具,确保小型企业能够有效提升其软件的安全性,从而保护客户数据并增强市场竞争力。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 本文探讨了如何优化和正确配置Kafka Streams应用程序以确保准确的状态存储查询。通过调整配置参数和代码逻辑,可以有效解决数据不一致的问题。 ... [详细]
author-avatar
Posion丶丨
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有