Rumah  >  Artikel  >  pangkalan data  >  Bagaimana Redis melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi

Bagaimana Redis melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi

PHPz
PHPzasal
2023-11-07 12:59:001144semak imbas

Bagaimana Redis melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi

Redis ialah cache sumber terbuka, stor nilai kunci dan sistem pemesejan. Ia telah dicipta oleh Salvatore Sanfilippo pada tahun 2009 dan secara beransur-ansur menjadi salah satu penyelesaian caching dan penyimpanan data yang paling biasa digunakan dalam aplikasi web.

Redis menyediakan pelbagai struktur data, termasuk rentetan, cincang, senarai, set dan set tertib. Struktur data ini mempunyai ciri yang sangat baik seperti prestasi baca/tulis pantas, storan berterusan dan sokongan kluster Ia boleh digunakan untuk menyimpan data respons dalam aplikasi web, menyimpan data sesi, mesej baris gilir, dsb.

Berikut akan memperkenalkan cara menggunakan Redis untuk melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi dan menyediakan contoh kod khusus.

  1. Initialize sambungan Redis

Sebelum menggunakan Redis, anda perlu mewujudkan sambungan dengan perpustakaan pemacu yang sepadan. Mengambil Python sebagai contoh, anda boleh menggunakan perpustakaan redis-py:

import redis

r = redis.Redis(host='localhost', port=6379, db=0)

Dalam contoh ini, kami menyambung ke pelayan Redis yang dijalankan secara tempatan, menggunakan port lalai dan pangkalan data ke-0.

  1. Tetapkan data cache

Sebelum menulis data ke cache aplikasi, data perlu bersiri. Redis menyokong pelbagai kaedah bersiri, termasuk rentetan, JSON, jeruk, dll.

Berikut ialah contoh menulis rentetan "Hello, Redis Cache" ke cache:

import json

data = 'Hello, Redis Cache'
key = 'mykey'

serialized_data = json.dumps(data)

r.set(key, serialized_data)

Kod ini menukar data rentetan ke dalam format JSON dan menggunakan SET Redis Perintah itu ditulis ke cache.

  1. Dapatkan data cache

Mendapatkan data cache daripada Redis juga merupakan operasi biasa. Anda boleh menggunakan arahan GET untuk membaca data dalam cache dan menyahsiri data.

Berikut ialah contoh penggunaan arahan GET untuk mendapatkan data cache:

import json

key = 'mykey'

serialized_data = r.get(key)

data = json.loads(serialized_data)

Kod ini menggunakan arahan Redis GET untuk membaca data cache dengan kekunci 'mykey' . Kemudian, deserialisasi data ke dalam kamus Python atau jenis data lain.

  1. Tetapkan masa tamat tempoh cache

Apabila menetapkan data cache, anda juga boleh menetapkan kitaran hayat data. Anda boleh menggunakan arahan Redis EXPIRE untuk menetapkan masa tamat tempoh cache. Setelah data cache tamat tempoh, Redis akan memadamkannya secara automatik.

Berikut ialah kod sampel yang menetapkan jangka hayat data kepada 60 saat:

import json

data = {'name': 'Tom', 'age': 30}
key = 'user_001'
serialized_data = json.dumps(data)

r.set(key, serialized_data)
r.expire(key, 60)

Kod ini menetapkan data cache bernama 'user_001' dan akan Lifetime ditetapkan kepada 60 saat. Selepas itu, Redis akan memadam data cache ini secara automatik.

  1. Gunakan cache untuk meningkatkan prestasi aplikasi

Caching data boleh meningkatkan prestasi aplikasi web, terutamanya apabila aplikasi perlu mengakses data yang sama masa data kerap. Dengan menulis data ke cache, aplikasi boleh mengelakkan pertanyaan pangkalan data beberapa kali, dengan itu mengurangkan kependaman rangkaian dan beban sistem.

Berikut ialah contoh penggunaan caching untuk meningkatkan prestasi:

import time
import json

def get_user_data(user_id):
    key = 'user_' + str(user_id)
    serialized_data = r.get(key)

    if serialized_data is not None:
        # 缓存中有数据,直接读取并返回
        data = json.loads(serialized_data)
        return data
    else:
        # 缓存中无数据,从数据库中读取并写入缓存
        data = read_from_db(user_id)
        serialize_data = json.dumps(data)
        r.set(key, serialized_data)
        r.expire(key, 60)

        return data

def read_from_db(user_id):
    # 从数据库读取用户数据
    time.sleep(2)  # 模拟真实数据库查询时间
    data = {'name': 'Tom', 'age': 30}
    return data

Kod ini menyerupai fungsi yang membaca data pengguna. Jika terdapat data pengguna dalam cache, fungsi akan membaca terus dari cache dan mengembalikan data jika tidak, fungsi akan membaca data pengguna dari pangkalan data dan menulisnya ke cache Redis.

  1. Ringkasan

Di atas memperkenalkan cara Redis melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi web. Ia menyediakan ciri yang sangat baik seperti storan data, ketekunan, sokongan kelompok dan pelbagai struktur data, yang boleh membantu pembangun membina aplikasi yang cekap dengan mudah.

Apabila menggunakan Redis untuk caching, anda perlu memberi perhatian kepada isu seperti pensirilan data, masa tamat tempoh cache, pecahan cache dan avalanche cache. Tetapi masalah ini boleh diselesaikan dengan mudah dengan beberapa cara teknikal dan amalan terbaik.

Kami percaya petua dan amalan terbaik ini akan membantu anda apabila menggunakan cache Redis untuk meningkatkan prestasi aplikasi web.

Atas ialah kandungan terperinci Bagaimana Redis melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi. 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