Rumah >pangkalan data >Redis >Redis: alat yang berkuasa untuk cache berprestasi tinggi

Redis: alat yang berkuasa untuk cache berprestasi tinggi

PHPz
PHPzasal
2023-11-07 08:28:101310semak imbas

Redis: alat yang berkuasa untuk cache berprestasi tinggi

Redis: Alat untuk caching berprestasi tinggi, contoh kod khusus diperlukan

Pengenalan:
Dalam kehidupan moden yang serba pantas, prestasi dan kecekapan telah menjadi matlamat penting yang diusahakan oleh perusahaan dan individu. Untuk sejumlah besar data yang kerap diakses, cara menyimpan dan mengaksesnya dengan cekap telah menjadi cabaran penting. Sebagai alat caching berprestasi tinggi, Redis digunakan secara meluas dalam pelbagai aplikasi Internet. Artikel ini akan meneroka ciri caching Redis dan contoh kod cara menggunakan Redis.

1. Ciri-ciri Redis Cache

  1. Cache: Redis ialah sistem storan data dalam memori yang boleh menyimpan dan membaca data pada kelajuan tinggi. Berbanding dengan pangkalan data hubungan tradisional, Redis mempunyai prestasi baca dan tulis yang lebih tinggi.
  2. Storan Nilai-Kekunci: Redis menggunakan model storan Nilai-Kekunci yang ringkas, menjadikannya lebih mudah untuk menyimpan dan mendapatkan data dengan menyediakan struktur data yang mudah dan berkesan, seperti rentetan, jadual cincang, senarai, dsb.
  3. Storan berterusan: Selain menyimpan data dalam memori, Redis juga menyokong data berterusan ke cakera. Walaupun selepas bekalan elektrik terputus atau dimulakan semula, data masih boleh dipulihkan.
  4. Mod terbitkan-langganan: Redis menyokong mod terbitkan-langganan, yang boleh melaksanakan operasi tolakan dan langganan mesej masa nyata, meningkatkan prestasi masa nyata dan kelajuan tindak balas aplikasi.

2. Contoh penggunaan cache Redis
Berikut akan memperkenalkan beberapa senario penggunaan biasa Redis dan memberikan contoh kod yang sepadan.

  1. Caching hasil pertanyaan
    Dalam aplikasi web, beberapa hasil pertanyaan dibaca dengan kerap tetapi jarang berubah. Menggunakan Redis untuk cache hasil pertanyaan ini boleh mengurangkan tekanan capaian pada pangkalan data dan meningkatkan prestasi sistem. Berikut ialah kod contoh berasaskan Java:
String queryKey = "user:1:info";
String result = redis.get(queryKey);
if(result == null){
    // 从数据库中读取数据
    result = db.query("SELECT * FROM user WHERE id = 1");
    // 将查询结果写入Redis缓存中,设置过期时间为1小时
    redis.setex(queryKey, 3600, result);
} else {
    // 缓存命中,直接使用缓存数据
    System.out.println("Cache hit!");
}
  1. Caching senarai artikel popular
    Dalam laman web berita atau blog, selalunya perlu untuk memaparkan senarai artikel popular, yang disusun mengikut bilangan paparan atau komen pada artikel. Fungsi ini boleh dilaksanakan dengan mudah menggunakan struktur data set yang dipesan Redis. Berikut ialah kod sampel berdasarkan Python:
# 获取热门文章列表
def get_hot_articles(num):
    articles = redis.zrevrange("hot:articles", 0, num-1)
    return articles

# 更新文章的热度
def increase_article_score(article_id):
    redis.zincrby("hot:articles", 1, article_id)

# 示例代码
# 文章被访问时,更新文章热度
def view_article(article_id):
    increase_article_score(article_id)
    # 其他业务逻辑
  1. Mengcache data sesi
    Dalam aplikasi web yang diedarkan, untuk memastikan pengguna log masuk, data sesi perlu dikongsi antara perkhidmatan yang berbeza. Menggunakan Redis untuk menyimpan data sesi adalah mudah dan cekap. Berikut ialah kod sampel berdasarkan Node.js:
// 存储会话数据
function save_session(session_id, user_info){
    redis.hset("session:" + session_id, "user_info", JSON.stringify(user_info));
}

// 获取会话数据
function get_session(session_id){
    return redis.hget("session:" + session_id, "user_info");
}

// 示例代码
// 用户登录成功后,保存会话数据
save_session("session_id", { user_id: 1, username: "admin" });

// 获取会话数据,并验证用户身份
var session_data = JSON.parse(get_session("session_id"));
console.log("User info: ", session_data);

Kesimpulan:
Redis, sebagai alat caching berprestasi tinggi, boleh meningkatkan prestasi dan kelajuan tindak balas sistem dengan banyak. Dengan menggunakan ciri Redis dan contoh kod yang sepadan, kami boleh lebih memahami dan menggunakan caching Redis serta membawa pengalaman storan dan akses data yang cekap kepada aplikasi kami.

Atas ialah kandungan terperinci Redis: alat yang berkuasa untuk cache berprestasi tinggi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn