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

Bagaimana Redis melaksanakan fungsi caching untuk meningkatkan prestasi aplikasi

Nov 07, 2023 pm 12:59 PM
redis cache Prestasi aplikasi

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)
Salin selepas log masuk

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)
Salin selepas log masuk

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)
Salin selepas log masuk

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)
Salin selepas log masuk

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
Salin selepas log masuk

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 Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penyelesaian kepada ralat 0x80242008 semasa memasang Windows 11 10.0.22000.100 Penyelesaian kepada ralat 0x80242008 semasa memasang Windows 11 10.0.22000.100 May 08, 2024 pm 03:50 PM

1. Mulakan menu [Start], masukkan [cmd], klik kanan [Command Prompt], dan pilih Run as [Administrator]. 2. Masukkan arahan berikut mengikut turutan (salin dan tampal dengan teliti): SCconfigwuauservstart=auto, tekan Enter SCconfigbitsstart=auto, tekan Enter SCconfigcryptsvcstart=auto, tekan Enter SCconfigtrustedinstallerstart=auto, tekan Enter SCconfigwuauservtype=share, tekan Enter netstopwuauserv , tekan enter netstopcryptS

Strategi dan pengoptimuman caching API Golang Strategi dan pengoptimuman caching API Golang May 07, 2024 pm 02:12 PM

Strategi caching dalam GolangAPI boleh meningkatkan prestasi dan mengurangkan beban pelayan Strategi yang biasa digunakan ialah: LRU, LFU, FIFO dan TTL. Teknik pengoptimuman termasuk memilih storan cache yang sesuai, caching hierarki, pengurusan ketidaksahihan dan pemantauan dan penalaan. Dalam kes praktikal, cache LRU digunakan untuk mengoptimumkan API untuk mendapatkan maklumat pengguna daripada pangkalan data Data boleh diambil dengan cepat daripada cache Jika tidak, cache boleh dikemas kini selepas mendapatkannya daripada pangkalan data.

Mekanisme caching dan amalan aplikasi dalam pembangunan PHP Mekanisme caching dan amalan aplikasi dalam pembangunan PHP May 09, 2024 pm 01:30 PM

Dalam pembangunan PHP, mekanisme caching meningkatkan prestasi dengan menyimpan sementara data yang kerap diakses dalam memori atau cakera, dengan itu mengurangkan bilangan akses pangkalan data. Jenis cache terutamanya termasuk memori, fail dan cache pangkalan data. Caching boleh dilaksanakan dalam PHP menggunakan fungsi terbina dalam atau perpustakaan pihak ketiga, seperti cache_get() dan Memcache. Aplikasi praktikal biasa termasuk caching hasil pertanyaan pangkalan data untuk mengoptimumkan prestasi pertanyaan dan caching halaman output untuk mempercepatkan pemaparan. Mekanisme caching berkesan meningkatkan kelajuan tindak balas laman web, meningkatkan pengalaman pengguna dan mengurangkan beban pelayan.

Bagaimana untuk menaik taraf Win11 English 21996 kepada Simplified Chinese 22000_Cara untuk menaik taraf Win11 English 21996 kepada Simplified Chinese 22000 Bagaimana untuk menaik taraf Win11 English 21996 kepada Simplified Chinese 22000_Cara untuk menaik taraf Win11 English 21996 kepada Simplified Chinese 22000 May 08, 2024 pm 05:10 PM

Mula-mula anda perlu menetapkan bahasa sistem kepada paparan Bahasa Cina Mudah dan mulakan semula. Sudah tentu, jika anda telah menukar bahasa paparan kepada Bahasa Cina Ringkas sebelum ini, anda boleh melangkau langkah ini sahaja. Seterusnya, mula mengendalikan pendaftaran, regedit.exe, navigasi terus ke HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage dalam bar navigasi kiri atau bar alamat atas, dan kemudian ubah suai nilai kunci InstallLanguage dan nilai kunci Lalai kepada 0804 (jika anda ingin menukarnya ke Bahasa Inggeris en- kami, anda perlu Mula-mula tetapkan bahasa paparan sistem kepada en-us, mulakan semula sistem dan kemudian tukar semuanya kepada 0409) Anda mesti memulakan semula sistem pada ketika ini.

Bagaimana untuk menggunakan caching dalam sistem edaran Golang? Bagaimana untuk menggunakan caching dalam sistem edaran Golang? Jun 01, 2024 pm 09:27 PM

Dalam sistem pengedaran Go, caching boleh dilaksanakan menggunakan pakej groupcache Pakej ini menyediakan antara muka caching umum dan menyokong pelbagai strategi caching, seperti LRU, LFU, ARC dan FIFO. Memanfaatkan groupcache boleh meningkatkan prestasi aplikasi dengan ketara, mengurangkan beban bahagian belakang dan meningkatkan kebolehpercayaan sistem. Kaedah pelaksanaan khusus adalah seperti berikut: Import pakej yang diperlukan, tetapkan saiz kolam cache, tentukan kolam cache, tetapkan masa tamat cache, tetapkan bilangan permintaan nilai serentak dan proses keputusan permintaan nilai.

Bagaimana untuk mencari fail kemas kini yang dimuat turun oleh Win11_Share lokasi fail kemas kini yang dimuat turun oleh Win11 Bagaimana untuk mencari fail kemas kini yang dimuat turun oleh Win11_Share lokasi fail kemas kini yang dimuat turun oleh Win11 May 08, 2024 am 10:34 AM

1. Mula-mula, klik dua kali ikon [PC ini] pada desktop untuk membukanya. 2. Kemudian klik dua kali butang tetikus kiri untuk memasuki [pemacu C]. 3. Kemudian cari folder [windows] dalam pemacu C dan klik dua kali untuk masuk. 4. Selepas memasukkan folder [windows], cari folder [SoftwareDistribution]. 5. Selepas masuk, cari folder [muat turun], yang mengandungi semua fail muat turun dan kemas kini win11. 6. Jika kita ingin memadam fail-fail ini, hanya padamkannya terus dalam folder ini.

Aplikasi caching PHP Redis dan amalan terbaik Aplikasi caching PHP Redis dan amalan terbaik May 04, 2024 am 08:33 AM

Redis ialah cache nilai kunci berprestasi tinggi. Sambungan PHPRedis menyediakan API untuk berinteraksi dengan pelayan Redis. Gunakan langkah berikut untuk menyambung ke Redis, menyimpan dan mendapatkan semula data: Sambung: Gunakan kelas Redis untuk menyambung ke pelayan. Penyimpanan: Gunakan kaedah yang ditetapkan untuk menetapkan pasangan nilai kunci. Retrieval: Gunakan kaedah get untuk mendapatkan nilai kunci.

Mengapa ralat berlaku semasa memasang pelanjutan menggunakan PECL dalam persekitaran Docker? Bagaimana menyelesaikannya? Mengapa ralat berlaku semasa memasang pelanjutan menggunakan PECL dalam persekitaran Docker? Bagaimana menyelesaikannya? Apr 01, 2025 pm 03:06 PM

Punca dan penyelesaian untuk kesilapan Apabila menggunakan PECL untuk memasang sambungan dalam persekitaran Docker Apabila menggunakan persekitaran Docker, kami sering menemui beberapa sakit kepala ...

See all articles