以前有同事需要我清除memcache缓存,我总是直接使用kill命令结束掉这个进程,后来才知道有更简单的方法,来清除memcachd的缓存,记录一下,以备不时之需:
1.首先使用ssh命令登录到memcached所在服务器,命令如下:
代码如下 | 复制代码 |
#ssh root@192.168.1.1 |
输入root密码后可登录对应的服务器;
2.使用telnet命令后接tomcat服务配置文件中指定的memcached启动端口:
代码如下 | 复制代码 |
#telnet localhost 11211 |
之后显示:
Trying 127.0.0.1…
Connected to localhost.localdomain (127.0.0.1).
Escape character is ‘^]’.
3.此时输入如下内容并回车即可清除缓存内容:
代码如下 | 复制代码 |
flush_all |
4.最后退出telnet使用quit命令,再exit退出远程主机。
清除过期缓存
代码如下 | 复制代码 |
/** * Memcached的过期内存回收 */ class mem_dtor extends Memcache { private $server_id; public function __construct($host,$port) { $this->server_id = "$host:$port"; $this->connect($host,$port); } // 回收所有过期的内存 public function gc() { $t = time(); $_this = $this; $func = function($key,$info) use ($t,$_this) { if($info[1] - $t delete($key); } }; $this->lists($func); } // 查看所有缓存内容的信息 public function info() { $t = time(); $func = function($key,$info) use ($t) { echo $key,' => Exp:',$info[1] - $t,"n"; //查看缓存对象的剩余过期时间 }; $this->lists($func); } private function lists($func) { $sid = $this->server_id; $items = $this->getExtendedStats('items'); //获取memcached状态 foreach($items[$sid]['items'] as $slab_id => $slab) //获取指定server id 的 所有Slab { $item = $this->getExtendedStats('cachedump',$slab_id,0); //遍历所有Slab foreach($item[$sid] as $key => $info) //获取Slab中缓存对象信息 { $func($key,$info); } } } } $mem = new mem_dtor('127.0.0.1',11211); $mem->info();//查看状态 $mem->gc(); //回收 |
memcache缓存的批量删除方案
memcache默认只支持使用delete(key)和 flush_all,这两种方法都太极端了,不能满足用户的特定需求,如:批量删除‘aaaaaaaa_'开头的所有缓存,这个时候该怎么办?
1 getExtendStats 遍历所有item,删除指定的key(不推荐)
网上有对应的php代码和perl程序,感兴趣的可以看看,在本地测试时可以使用,但是在真是服务器上请不要使用。
2 memcache结合DB
方法:每次set缓存时,将key值存入数据库,在要删除缓存时查询数据库,查询出对应的信息,在memcache中将其删除
缺点:浪费数据裤磁盘
3 memcache伪命名空间(推荐)
memcache默认不提供命名空间,但可以设置一个全局变量,来模拟命名空间,代码如下:
代码如下 | 复制代码 |
<?php
|
以上是个人见解,欢迎拍板
网页截屏以前我们只能在asp.net中实现,下面我来介绍在linux中利用一个插件让php也可以实现网页截屏吧,希望对大家有帮助。服务器端
为实现截图的程序必须借助服务器端程序:http://code.google.com/p/wkhtmltopdf/
可将网页转换为pdf或者图片,32和64位有区别,找个适合自己服务器的版本。
安装
安装过程十分简单:解压 -> 找个合适的路径放下…
执行
命令行调用1
代码如下 | 复制代码 |
/servers/app/qtwebkit/wkHtmlToImage 111cn.net www.111cn.net.png |
默认的清晰度比较高,图片会很大,生成图片需要一定的时间。
php
代码如下 | 复制代码 |
exec('/servers/app/qtwebkit/wkHtmlToImage 111cn.net www.111cn.net.png'); |
具体的使用方法
代码如下 | 复制代码 |
<?php |
中文乱码问题
主要看服务器是否支持中文语言,如果截图中出现乱码,直接装个中文包就好了。
代码如下 | 复制代码 |
yum install fonts-chinese |
一个客户反应网站乱码,使用了zend optimizer加密,检查了下vps发现没装zend optimizer,安装后即可解决乱码问题
代码如下 | 复制代码 |
cd /usr/local/directadmin/custombuild/ vim ./options.conf |
找到zend = no改成zend =yes,然后再执行./build zend,完成后会看到下面的提示
代码如下 | 复制代码 |
|
然后重启下apache即可
代码如下 | 复制代码 |
|
函数
代码如下 | 复制代码 |
/** |
调用方法
代码如下 | 复制代码 |
$url = 'http://www.111cn.net'; |
上面只是一个简单的实例,如果我们想应用可参考我自己写的采集程序了。
1,获取目标网页数据;
2,截取相关内容;
3,写入数据库/生成HMTL文件;
下面就按照步骤来试试!
获取目标网页数据
1, 确定好,要获取的网页地址甚至形式,这里我们采用的网址是:/index.html?pageconfig=catalog_byproducttype&intProductTypeID=1&strStartChar=A&intResultsPage=1&tr=59
这个页面是有分页的,根据规律,我们找到只需要改变page参数就可以翻页!即:
我 们的网页形式是:/index.html?pageconfig=catalog_byproducttype& amp;intProductTypeID=1&strStartChar=A&intResultsPage= NUMBER &tr=59
红色部分是当前页码对应值!只需要改变该值就可以了!
2,获取页面内容:自然要用到PHP函数了!这里,两个函数都可以!他们分别是:
file_get_contents() 把整个文件读入一个字符串中。和 file() 一样,不同的是file_get_contents() 把文件读入一个字符串。file_get_contents() 函数是用于将文件的内容读入到一个字符串中的首选方法。如果操作系统支持,还会使用内存映射技术来增强性能。语法: file_get_contents( path , include_path , context , start , max_length ) curl() 了解详细,请参阅官网文档:http://cn.php.net/curl fopen()函数打开文件或者 URL。如果打开失败,本函数返回 FALSE。语法: fopen(filename,mode,include_path,context) 当然,我们采用的是第一个!其实,所有的都差不多,有兴趣的童子可以常识常识其他的!
代码如下 | 复制代码 |
<?php |
运行PHP程序,上面的代码可以显示出整个网页!由于原网页采用的是绝地路径,所以现在显示的效果和原来的是一模一样的!
接下来就是要,截取内容了!截取内容的方法也有很多,今天介绍的一种比较简单:
代码如下 | 复制代码 |
<?php $oldcontent = file_get_contents(“http://www.abcam.cn/index.html?pageconfig=catalog_byproducttype&intProductTypeID=1&strStartChar=A&intResultsPage=2&tr=59″); $oldcontent; $pfirst = ‘<table border=”0″ cellspacing=”0″ cellpadding=”0″> <tr> <th style=”padding-left: 0px;”><p style=”font-size:12px”><strong>Code</strong></p></th>’; $plast = ‘Goat polyclonal’; $b= strpos($oldcontent,$pfirst); $c= strpos($oldcontent,$plast); echo substr($oldcontent,$b,$c-1); ?> |
输出的,即为所需要的结果!
写入数据库和写入文件都是比较简单的!这里就写入文件了!
代码如下 | 复制代码 |
<?php $oldcontent = file_get_contents(“index.html?pageconfig=catalog_byproducttype&intProductTypeID=1&strStartChar=A&intResultsPage=2&tr=59″); $oldcontent; $pfirst = ‘<table border=”0″ cellspacing=”0″ cellpadding=”0″> <tr> <th style=”padding-left: 0px;”><p style=”font-size:12px”><strong>Code</strong></p></th>’; $plast = ‘Goat polyclonal’; $b= strpos($oldcontent,$pfirst); $c= strpos($oldcontent,$plast); $a = substr($oldcontent,$b,$c-1); $file = date(‘YmdHis’).”.html”; $fp = fopen($file,”w+”); if(!is_writable($file)){ die(“File “.$file.” can not be written”); } else { file_put_contents($file, $a); echo “success”; } fclose($fp); ?> |
OK,继续上班,今天的截取就到这里,下次就说说正则表达式提取内容
要实现无刷新文件上传我们有一种假像的做法就是使用iframe框架实现文件上传,另一种就是利用ajax实现文件上传了,这两种方法都可以达到无刷新文件上传功能。一个最原始最简单的iframe上传例子:
前台上传页面index.html,主要是一个表单与一个js回调函数。上传文件时,form表单的method、 enctype属性必须和下面代码一样。然后将target的值设为iframe的name,这样就可以实现无刷新上传文件。
代码如下 | 复制代码 |
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
后台上传处理页面uploadfile.php,这段代码为简单的上传代码,没有进行错误及异常处理。上传代码执行完成后,要告诉父页面已经上传完毕了,因此,在这个页面里调用父页面的回调函数CallbackFunction,这个函数可以有参数,形式自己定义。
代码如下 | 复制代码 |
<?php |
以上是用iframe实现无刷新上传文件的简单方法,想要健壮的程序的话需要再细化