首页 > 后端开发 > php教程 > PHP使用redis实现统计缓存mysql压力的方法_php技巧

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-05-16 20:04:39
原创
1543 人浏览过

本文实例讲述了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

<&#63;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&#63;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程序设计有所帮助。

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
怎么学好php
来自于 1970-01-01 08:00:00
0
0
0
PHP扩展intl
来自于 1970-01-01 08:00:00
0
0
0
php数据获取?
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板