使用Redis做為MySQL的快取
版權宣告:本文可能為博主原創文章,若標明出處可隨便轉載。 https://blog.csdn.net/Jailman/article/details/80047374
OS: Ubuntu 16.04.4 x64
更新並安裝必要的工具
apt update && apt upgrade -y && apt dist-upgrade -y
apt autoremove
apt autoclean
apt install gcc redis-server mysql-server libmysqld-dev libhiredis-dev -y
驗證redis
127.0.0.1:6379> hgetall w3ckey
(empty list or set)
127.0.0.1:6379>
建立mysql資料
drop database if exists mysqlRedis;
create database mysqlRedis;
use mysqlRedis;
create table test(
id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(64),
age INT,
description VARCHAR(1000),
primary key(id));
建立UDF動態庫 mysqlUDFdemo.c
#include <stdio.h>
#include <stdlib.h>
#include <mysql.h>
#include <string.h>
#include <hiredis/hiredis.h>
int gxupdate(UDF_INIT * initid, UDF_ARGS * args, char * is_null, char * error) {
redisContext * c = redisConnect("127.0.0.1", 6379);
if(c->err) {
redisFree(c);
return 1;
}
const char * command1 = "HMSET w3ckey name %s description %s likes %d visitors %d";
redisReply * r = (redisReply *) redisCommand(c, command1,
args->args[2], args->args[4], *(int *)args->args[1], *(int *)args->args[3]);
if(r == NULL) {
return 1;
}
if(!((r->type == REDIS_REPLY_STATUS) && (strcasecmp(r->str, "OK") == 0))) {
freeReplyObject(r);
redisFree(c);
return 1;
}
freeReplyObject(r);
return 0;
}
my_bool gxupdate_init(UDF_INIT * initid, UDF_ARGS * args, char * message) {
return 0;
}
編譯
gcc -shared -fPIC -I /usr/include/mysql -o udfgx.so mysqlUDFdemo.c /usr/lib/x86_64-linux-gnu/libhiredis.a
拷貝so檔案到mysql plugin
cp udfgx.so /usr/lib/mysql/plugin/
配置UDF和trigger
use mysqlRedis;
drop function if exists gxupdate;
create function gxupdate returns INTEGER soname "udfgx.so";
drop trigger if exists insert_redis;
drop trigger if exists update_redis;
drop trigger if exists delete_redis;
delimiter |
create trigger insert_redis
after insert on test
for each row
begin
declare ret int;
select gxupdate(1, NEW.id, NEW.name, NEW.age, NEW.description) into @ret;
#必須加into @ret,否則返回錯誤ERROR 1415 (0A000)
#at line 6: Not allowed to return a result set from a trigger
#insert只有NEW變數。
#update有NEW和OLD變數。
#delete只有OLD變數。
end|
create trigger update_redis
after update on test
for each row
begin
declare ret int;
select gxupdate(1, NEW.id, NEW.name, NEW.age, NEW.description) into @ret;
end|
create trigger delete_redis
after delete on test
for each row
begin
declare ret int;
select gxupdate(0, OLD.id, OLD.name, OLD.age, OLD.description) into @ret;
end|
delimiter ;
注意insert,update,delete要定義三個觸發器
檢視redis
127.0.0.1:6379> hgetall w3ckey
(empty list or set)
127.0.0.1:6379>
插入資料
mysql> insert into test (name, age, description) values ("ggglwlop", 23, "ddddgdg");
Query OK, 1 row affected (0.02 sec)
檢視redis
127.0.0.1:6379> hgetall w3ckey
1) "name"
2) "ggglwlop"
3) "description"
4) "ddddgdg"
5) "likes"
6) "27"
7) "visitors"
8) "23"
127.0.0.1:6379>
mysql的改動已經快取到了redis中
這裡有一個github上不錯的專案:
https://github.com/liukelin/canal_mysql_nosql_sync
參考:
https://blog.csdn.net/gx_1983/article/details/79033502
相關文章
- 為什麼要使用Redis做快取Redis快取
- Mybatis的二級快取、使用Redis做二級快取MyBatis快取Redis
- SpringBoot註解使用redis做快取總結Spring BootRedis快取
- spring-boot-route(十二)整合redis做為快取SpringbootRedis快取
- Springboot 整合 SpringCache 使用 Redis 作為快取Spring BootGCRedis快取
- MySQL 與 Redis 快取的同步方案MySqlRedis快取
- 如何使用 Redis 快取Redis快取
- Laravel使用Redis快取LaravelRedis快取
- 2018-11-08 拿redis 做快取Redis快取
- springboot +lettuce +redis 快取使用Spring BootRedis快取
- 在我們使用Redis作為一個LRU快取的時候,怎麼做才能更高效Redis快取
- Django(39)使用redis配置快取DjangoRedis快取
- MySQL與Redis實現二級快取MySqlRedis快取
- OpenResty+lua+redis+mysql多級快取RESTRedisMySql快取
- 談談Redis快取中MySQL的資料如何與Redis同步Redis快取MySql
- Redis的快取穿透、快取雪崩、快取擊穿的區別Redis快取穿透
- Redis快取擊穿、快取穿透、快取雪崩Redis快取穿透
- [Redis]快取穿透/快取擊穿/快取雪崩Redis快取穿透
- springboot註解方式使用redis快取Spring BootRedis快取
- SpringBoot中使用Redis實現快取Spring BootRedis快取
- JAVA快取-Redis入門級使用Java快取Redis
- SpringBoot中Shiro快取使用Redis、EhcacheSpring Boot快取Redis
- Redis快取穿透Redis快取穿透
- WEB 應用快取解析以及使用 Redis 實現分散式快取Web快取Redis分散式
- Redis快取篇(四)快取異常Redis快取
- Redis快取穿透、快取雪崩、redis併發問題分析Redis快取穿透
- 什麼是redis的快取雪崩與快取穿透Redis快取穿透
- 配置Redis作為快取(六種淘汰策略)Redis快取
- mysql查詢快取簡單使用MySql快取
- Redis詳解(十二)------ 快取穿透、快取擊穿、快取雪崩Redis快取穿透
- 什麼是redis快取雪崩、快取穿透、快取擊穿Redis快取穿透
- Redis——快取穿透、快取擊穿、快取雪崩、分散式鎖Redis快取穿透分散式
- Redis快取穿透、快取雪崩、快取擊穿好好說說Redis快取穿透
- 探討下如何更好的使用快取 —— Redis快取的特殊用法以及與本地快取一起構建多級快取的實現快取Redis
- SpringBoot+Redis作為二級快取整合的基本DemoSpring BootRedis快取
- 【Azure Redis 快取】如何得知Azure Redis服務有更新行為?Redis快取
- SpringBoot整合Redis快取Spring BootRedis快取
- redis→分散式快取Redis分散式快取