Yii2 redis同步数据到mysql

Yii2 redis同步数据到mysql

大家好,又见面了,我是你们的朋友全栈君。

将redis数据写入mysql中:

本次案例讲解将如何将商城中商品浏览次数通过缓存记录并写入mysql中
具体的redis安装过程暂且就省略了…..

一、安装redis插件|配置redis

composer require yiisoft/yii2-redis

找到common的config文件,在components下加入redis配置参数

 'redis' => [
            'class' => 'yii\redis\Connection',
            'hostname' => 'localhost',
            'port' => 6379,
            'database' => 0,
        ],

二、建立redis
在显示商品详情页面之前建立redis记录,每当用户访问该页面,就对redis进行一个判断,如果没有redis则建立并赋值为1,如果已存在则在原数据的基础上+1

 //将商品访问写入到redis中
        $redisObj = Yii::$app->redis;
        $visitsData = $redisObj->get('goods_visits');

        //反序列化访问数据
        $visitsData = empty($visitsData)?[]:unserialize($visitsData);

        if (isset($visitsData[$id])) {
            $visitsData[$id] += 1;
        }else{
            $visitsData[$id] = 1;
        }

        //序列化后的数据格式为{商品id:浏览次数}
        $visitsData = serialize($visitsData);
        $redisObj->set('goods_visits',$visitsData);

三、将redis写入数据库中
创建一个新的控制器,通过redistomysql方法获取存在的redis进行判断,如果为空则返回true,否则同步到Mysql当中,并在同步完成之后将redis数据删除

public function actionRedistomysql()
    {
        //从redis中查询所有商品信息
        $redisObj = Yii::$app->redis;
        $visits = $redisObj->get("goods_visits");

        //三元表示判断redis是否为空
        $visitsArr = empty($visits)?[]:unserialize($visits);

        if (empty($visitsArr)) {
            return true;
        }

        //将浏览数据写入数据库
        foreach ($visitsArr as $k=>$v)
        {
            $goodsModle = Goods::findOne($k);
            $goodsModle->visites += $v;
            //如果数据存储成功则删除对应的数据
            if ($goodsModle->save() !== false) {
                unset($visitsArr[$k]);
            }
            //延迟2秒防止高频率读取数据库
            sleep(2);
        }

        //删除redis中商品浏览数据
        $redisObj->del("goods_visits");

        if (empty($visitsArr)) {
            return true;
        }

        $redisObj->set('goods_visits',serialize($visitsArr));
}

四、检测redis是否建立成功
首先访问商品详情页面,然后进入Linux服务器,(redis安装成功后)执行redis-cli,进入redis控制台,执行get goods_visits(创建的redis名),如果情况如下则刷新商品详情页面

redis1.jpg

成功页面如下:

redis2.png

到这里就完成了redis同步数据到Mysql的基本步骤,但是每一次的执行需要手动进行访问,所以这里就需要一个能让它自动执行的方法,因为本项目是在linux下运行,所以使用了crontab定时执行任务,如果是windows下则使用任务计划…..

首先执行crontab -e命令进入linux定时任务设置
基本格式 :
* * * * * command(执行的方法地址,如:http://www.xxxx.com/cront/redistomysql)
分 时 日 月 周 命令
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令

访问商品详情页面,然后等到设定的时间之后查看数据库中是否数据存在,存在数据那么标识你的redis就已经设置成功了,没有数据那么就需要检查你的代码,或者设置是否正确了,本次redis的使用介绍就到此为止了。

作者:meteorites
链接:https://www.jianshu.com/p/7b58bd6c8f97
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

 
 
G
M
T

 
 

Detect languageAfrikaansAlbanianArabicArmenianAzerbaijaniBasqueBelarusianBengaliBosnianBulgarianCatalanCebuanoChichewaChinese (Simplified)Chinese (Traditional)CroatianCzechDanishDutchEnglishEsperantoEstonianFilipinoFinnishFrenchGalicianGeorgianGermanGreekGujaratiHaitian CreoleHausaHebrewHindiHmongHungarianIcelandicIgboIndonesianIrishItalianJapaneseJavaneseKannadaKazakhKhmerKoreanLaoLatinLatvianLithuanianMacedonianMalagasyMalayMalayalamMalteseMaoriMarathiMongolianMyanmar (Burmese)NepaliNorwegianPersianPolishPortuguesePunjabiRomanianRussianSerbianSesothoSinhalaSlovakSlovenianSomaliSpanishSundaneseSwahiliSwedishTajikTamilTeluguThaiTurkishUkrainianUrduUzbekVietnameseWelshYiddishYorubaZulu
 
AfrikaansAlbanianArabicArmenianAzerbaijaniBasqueBelarusianBengaliBosnianBulgarianCatalanCebuanoChichewaChinese (Simplified)Chinese (Traditional)CroatianCzechDanishDutchEnglishEsperantoEstonianFilipinoFinnishFrenchGalicianGeorgianGermanGreekGujaratiHaitian CreoleHausaHebrewHindiHmongHungarianIcelandicIgboIndonesianIrishItalianJapaneseJavaneseKannadaKazakhKhmerKoreanLaoLatinLatvianLithuanianMacedonianMalagasyMalayMalayalamMalteseMaoriMarathiMongolianMyanmar (Burmese)NepaliNorwegianPersianPolishPortuguesePunjabiRomanianRussianSerbianSesothoSinhalaSlovakSlovenianSomaliSpanishSundaneseSwahiliSwedishTajikTamilTeluguThaiTurkishUkrainianUrduUzbekVietnameseWelshYiddishYorubaZulu
 
 
 
 
 
 

 
 
 
Text-to-speech function is limited to 200 characters
 
 
Options : History : Feedback : Donate Close

转载于:https://my.oschina.net/botkenni/blog/1806112

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107549.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 面试100题及答案_三特点带你认识基层岗位常见面试题

    面试100题及答案_三特点带你认识基层岗位常见面试题第1期:JS中关闭当前的窗口的方法是:。答案:window.close();第2期:js中使字符串中的字符变为小写的方法是:。答案:toLowerCase方法;第3期:在js中,让浏览器弹出确认框的语句是:。答案:confirm;例如:window.confirm(“我就是确认框”);运行结果是浏览器弹出信息确认框,点击确定,返回true,反之返回false。第4期:把7.25四舍…

    2022年8月27日
    6
  • obligatory category_cglib为什么比jdk快

    obligatory category_cglib为什么比jdk快在一些系统代码中,随处可见的BeanCopier(源于org.springframework.cglib.beans),它主要用在将PO与DTO互转。一些人在惊叹它的高性能的同时,不曾了解它的实现原理(它不使用的反射)!它基于CGLIB代理,CGLIB(CodeGenerationLibrary)是高效的代码生成包,底层依靠ASM(开源的Java字节码编辑类库)操作字节码实现。JDK动态代…

    2025年9月15日
    5
  • 计算机二级公共基础知识笔记

    计算机二级公共基础知识笔记计算机二级公共基础知识计算机系统考点一:计算机概述1.计算机的发展历程目前公认的第一台电子数字计算机是ENIAC,它于1946年在美国宾夕法尼亚大学研制成功。根据计算机本身采用的物理器件不同,将其发展分为4个阶段第一阶段是电子管计算机时代,时间为1946年到20世纪50年代第二阶段是晶体管计算机时代,时间为20世纪50年代后期到50世纪60年代中期第三阶段是中小规模集成电路计算机时代,时间是20世纪60年代中期到20世纪70年代初期第四阶段是大规模和超大规模集成电路计算机时代,时间是20

    2022年6月9日
    38
  • 十大漏洞之逻辑漏洞

    十大漏洞之逻辑漏洞在十大漏洞中,逻辑漏洞被称为“不安全的对象引用,和功能级访问控制缺失”。现如今,越权和逻辑漏洞占用比例比较高,包括任意查询用户信息,重置任意用户密码,验证码爆破等。逻辑漏洞:常见的逻辑漏洞:交易支付,密码修改,密码找回,越权修改,越权查询,,突破限制等各种逻辑漏洞不安全的对象引用指的是平行权限的访问控制缺失A,B同为普通用户,他们之间彼此之间的个人资料应该相互保密的,A的资…

    2022年5月29日
    41
  • 指令周期,机器周期,时钟周期的概念及三者之间的关系图_总线周期和时钟周期

    指令周期,机器周期,时钟周期的概念及三者之间的关系图_总线周期和时钟周期指令周期:CPU每取出一条指令并执行这条指令,都要完成一系列的操作,这一系列操作所需要的时间通常叫做一个指令周期。换言之指令周期是取出一条指令并执行这条指令的时间。由于各条指令的操作功能不同,因此各种指令的指令周期是不尽相同的。例如一条加法指令的指令周期同一条乘法指令的指令周期是不相同的。机器周期:机器周期也称为CPU周期。在计算机中,为了便于管理,常把一条指令的执行过程划分为若干个阶段(如取指、译码、执行等),每一阶段完成一个基本操作。完成一个基本操作……

    2022年10月13日
    3
  • 定时任务框架Quartz-(一)Quartz入门与Demo搭建

    一、什么是Quartz什么是Quartz?Quartz是OpenSymphony开源组织在Jobscheduling领域又一个开源项目,完全由Java开发,可以用来执行定时任务,类似于java.util.Timer。但是相较于Timer,Quartz增加了很多功能:持久性作业-就是保持调度定时的状态;作业管理-对调度作业进行有效的管理;…

    2022年4月6日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号