本文实例讲述了PHP使用redis实现统计缓存mysql压力的方法。分享给大家供大家参考,具体如下:
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
<?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程序设计有所帮助。