首页 > 网站 > 建站经验 > 正文

PHP使用redis实现统计缓存mysql压力的方法

2024-04-25 20:43:21
字体:
来源:转载
供稿:网友

 

本文实例讲述了PHP使用redis实现统计缓存mysql压力的方法。分享给大家供大家参考,具体如下:

<?php

header("Content-Type:text/html;charset=utf-8");

include 'lib/mysql.class.php';

$mysql_obj = mysql::getConn();

//redis

$redis = new Redis();

$redis->pconnect('127.0.0.1', 6379);

if(isset($_SERVER['HTTP_REFERER'])){

$url_md5 = md5($_SERVER['HTTP_REFERER']);

}

$adve_key = 'adve';

$adve_key_exists = 'adve_exists';

if(!$redis->exists($adve_key_exists)){

$list = $mysql_obj->fetch_array("select * from user_online_adve");

if($list){

foreach ($list as $key => $value) {

$url_hash = md5($value['adve_url']);

$adve_hash_key = $adve_key.":".$url_hash;

$id = $value['id'];

$redis->set($adve_hash_key,$id);

$redis->set($adve_key_exists,true);

//$redis->hmset($adve_hash_key, array('id' =>$id));

//print_r($redis->get($adve_hash_key));

}

}

}

$adve_new_key = $adve_key.':'.$url_md5;

if($redis->exists($adve_new_key)){

$adve_plus = $adve_new_key.":plus" ;

if(!$redis->exists($adve_plus)){

$redis->set($adve_plus,1);

}else{

$redis->incr($adve_plus);

$num = $redis->get($adve_plus);

if($num >10){

$id = $redis->get($adve_new_key);

// insert to sql;

$mysql_obj->query("update user_online_adve set adve_num=adve_num+$num where id=$id");

$redis->set($adve_plus,1);

}

}

}

header('HTTP/1.0 301 Moved Permanently');

header('Location: https://itunes.apple.com/cn/app/san-guo-zhi15-ba-wangno-da-lu/id694974270?mt=8');

/*

if(){

$adve_plus = $adve_key.":plus" ;

if($redis->exists($adve_plus)){

$redis->incr($adve_plus);

}else{

$redis->set($adve_plus,1);

}

echo $redis->get($adve_plus);

}

foreach ($list as $key => $value) {

$url_hash = md5($value['adve_url']);

$id = $value['id'];

$adve_num = $value['adve_num'];

$adve_plus = $adve_key.":plus" ;

if($redis->exists($adve_plus)){

$redis->incr($adve_plus);

}else{

$redis->set($adve_plus,1);

}

echo $redis->get($adve_plus);

//if($redis->)

//$redis->hmset($adve_key, array('id' =>$id, 'adve_num'=>$adve_num));

//print_r($redis->hmget("adve:$url_hash", array('adve_num')));

}

print_r($list);

*/

希望本文所述对大家php程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表