Cara menggunakan django redis
1. Penerangan
Sebagai pangkalan data cache, redis memainkan peranan yang hebat dalam semua aspek. Jika anda menggunakan Django, terdapat perpustakaan redis yang direka khas untuk Django, iaitu django-redis
2. Pasang
pip install django-redis
3. Konfigurasikan
3.1 Konfigurasi redis
Buka fail konfigurasi Django, seperti setting.py, dan tetapkan CACHES dalam ia Item
CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379/1", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", } } }
Maklumat sambungan redis berbilang boleh dikonfigurasikan dalam satu CACHES Setiap satu mempunyai alias sendiri (alias" di atas ialah alias Kemudian anda boleh menyambung ke pangkalan data redis yang berbeza
LOKASI ialah maklumat sambungan, termasuk kata laluan pengguna port IP, dsb. Jika kata laluan pengguna tidak diperlukan, anda boleh meninggalkannya django-redis menyokong tiga protokol sambungan, seperti berikut
协议 | 说明 | 举例 |
---|---|---|
redis:// | 普通的TCP套接字连接 | redis://[[username]:[password]]@localhost:6379/0 |
rediss | SSL方式的TCP套接字连接 | rediss://[[username]:[password]]@localhost:6379/0 |
rediss:// | Unix域套接字连接 | unix://[[username]:[password]]@/path/to/socket.sock?db=0 |
3.2 Menggunakan sesi Penyimpanan redis
Sesi lalai Django disimpan dalam pangkalan data sql, tetapi kita semua tahu bahawa data biasa akan disimpan pada cakera keras, yang tidak begitu pantas untuk disimpan dalam redis, cuma Anda hanya perlu mengkonfigurasinya dalam fail konfigurasi
SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "default"
3.3 Tetapan tamat masa sambungan Redis
Bilangan saat tamat masa sambungan boleh ditentukan dalam item konfigurasi . SOCKET_CONNECT_TIMEOUT menunjukkan masa tamat untuk menyambung ke redis, dan SOCKET_TIMEOUT menunjukkan penggunaan Masa tamat untuk operasi baca dan tulis semula
CACHES = { "default": { # ... "OPTIONS": { "SOCKET_CONNECT_TIMEOUT": 5, # 连接redis超时时间,单位为秒 "SOCKET_TIMEOUT": 5, # redis读写操作超时时间,单位为秒 } } }
4.1 Gunakan redis
Jika anda ingin menggunakan redis lalai, tetapkannya dalam fail konfigurasi Redis dengan alias "lalai" boleh merujuk kepada cache dalam django.core.cache
from django.core.cache import cache cache.set("name", "冰冷的希望", timeout=None) print(cache.get("name"))
4.2 Gunakan redis yang ditentukan (redis asli)
Apabila anda menulis berbilang sambungan redis, anda boleh menentukan redis yang hendak digunakan melalui alias
from django_redis import get_redis_connection redis_conn = get_redis_connection("chain_info") redis_conn.set("name", "icy_hope") print(redis_conn.get("name"))
Sila ambil perhatian bahawa klien yang diperoleh melalui get_redis_connection() ialah klien Redis asli semua arahan redis asli, ia mengembalikan Data adalah jenis bait, anda perlu menyahkodnya sendiri
5 Kolam sambungan
Kelebihan menggunakan kolam sambungan ialah anda tidak mempunyai untuk mengurus objek sambungan. Ia akan membuat beberapa objek sambungan secara automatik dan menggunakannya semula sebanyak mungkin, jadi secara relatifnya, prestasi akan menjadi lebih baik
5.1 Mengkonfigurasi kumpulan sambungan
Untuk menggunakan sambungan pool, anda mesti terlebih dahulu menulis bilangan maksimum sambungan dalam kolam sambungan dalam fail konfigurasi Django
CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", ... "OPTIONS": { "CONNECTION_POOL_KWARGS": {"max_connections": 100} } } }
5.2 Menggunakan kolam sambungan
Kami boleh menentukan redis yang hendak digunakan melalui alias sambungan, dan kemudian laksanakan arahan seperti biasa. Kami tidak perlu mengambil berat tentang kejadian sambungan yang dibuatnya, tetapi anda boleh melihat ciptaan semasa melalui atribut _created_connections bagi connection_pool Berapa banyak tika sambungan terdapat
from django_redis import get_redis_connection redis_conn = get_redis_connection("default") redis_conn.set("name", "冰冷的希望") print(redis_conn.get("name")) # 查看目前已创建的连接数量 connection_pool = redis_conn.connection_pool print(connection_pool._created_connections)
5.3 Kumpulan sambungan tersuai
Kelas sambungan lalai Django-redis ialah DefaultClient Jika anda mempunyai keperluan penyesuaian yang lebih tinggi, anda boleh membuat kelas baharu anda sendiri
from redis.connection import ConnectionPool class MyPool(ConnectionPool): pass
Selepas mempunyai kelas ini, anda perlu. untuk menentukannya dalam fail konfigurasi Django
"OPTIONS": { "CONNECTION_POOL_CLASS": "XXX.XXX.MyPool", }
Atas ialah kandungan terperinci Cara menggunakan django redis. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Mod Redis cluster menyebarkan contoh Redis ke pelbagai pelayan melalui sharding, meningkatkan skalabilitas dan ketersediaan. Langkah -langkah pembinaan adalah seperti berikut: Buat contoh Redis ganjil dengan pelabuhan yang berbeza; Buat 3 contoh sentinel, memantau contoh redis dan failover; Konfigurasi fail konfigurasi sentinel, tambahkan pemantauan maklumat contoh dan tetapan failover; Konfigurasi fail konfigurasi contoh Redis, aktifkan mod kluster dan tentukan laluan fail maklumat kluster; Buat fail nodes.conf, yang mengandungi maklumat setiap contoh Redis; Mulakan kluster, laksanakan perintah Buat untuk membuat kluster dan tentukan bilangan replika; Log masuk ke kluster untuk melaksanakan perintah maklumat kluster untuk mengesahkan status kluster; buat

Cara Mengosongkan Data Redis: Gunakan perintah Flushall untuk membersihkan semua nilai utama. Gunakan perintah flushdb untuk membersihkan nilai utama pangkalan data yang dipilih sekarang. Gunakan Pilih untuk menukar pangkalan data, dan kemudian gunakan FlushDB untuk membersihkan pelbagai pangkalan data. Gunakan perintah DEL untuk memadam kunci tertentu. Gunakan alat REDIS-CLI untuk membersihkan data.

Menggunakan Arahan Redis memerlukan langkah -langkah berikut: Buka klien Redis. Masukkan arahan (nilai kunci kata kerja). Menyediakan parameter yang diperlukan (berbeza dari arahan ke arahan). Tekan Enter untuk melaksanakan arahan. Redis mengembalikan tindak balas yang menunjukkan hasil operasi (biasanya OK atau -r).

Untuk membaca giliran dari Redis, anda perlu mendapatkan nama giliran, membaca unsur -unsur menggunakan arahan LPOP, dan memproses barisan kosong. Langkah-langkah khusus adalah seperti berikut: Dapatkan nama giliran: Namakannya dengan awalan "giliran:" seperti "giliran: my-queue". Gunakan arahan LPOP: Keluarkan elemen dari kepala barisan dan kembalikan nilainya, seperti LPOP Queue: My-Queue. Memproses Baris kosong: Jika barisan kosong, LPOP mengembalikan nihil, dan anda boleh menyemak sama ada barisan wujud sebelum membaca elemen.

Menggunakan REDIS untuk mengunci operasi memerlukan mendapatkan kunci melalui arahan SETNX, dan kemudian menggunakan perintah luput untuk menetapkan masa tamat tempoh. Langkah-langkah khusus adalah: (1) Gunakan arahan SETNX untuk cuba menetapkan pasangan nilai utama; (2) Gunakan perintah luput untuk menetapkan masa tamat tempoh untuk kunci; (3) Gunakan perintah DEL untuk memadam kunci apabila kunci tidak lagi diperlukan.

Redis menggunakan jadual hash untuk menyimpan data dan menyokong struktur data seperti rentetan, senarai, jadual hash, koleksi dan koleksi yang diperintahkan. Redis berterusan data melalui snapshots (RDB) dan menambah mekanisme tulis sahaja (AOF). Redis menggunakan replikasi master-hamba untuk meningkatkan ketersediaan data. Redis menggunakan gelung acara tunggal untuk mengendalikan sambungan dan arahan untuk memastikan atom dan konsistensi data. Redis menetapkan masa tamat tempoh untuk kunci dan menggunakan mekanisme memadam malas untuk memadamkan kunci tamat tempoh.

Cara terbaik untuk memahami kod sumber REDIS adalah dengan langkah demi langkah: Dapatkan akrab dengan asas -asas Redis. Pilih modul atau fungsi tertentu sebagai titik permulaan. Mulakan dengan titik masuk modul atau fungsi dan lihat baris kod mengikut baris. Lihat kod melalui rantaian panggilan fungsi. Berhati -hati dengan struktur data asas yang digunakan oleh REDIS. Kenal pasti algoritma yang digunakan oleh Redis.

Redis, sebagai middleware mesej, menyokong model penggunaan pengeluaran, dapat meneruskan mesej dan memastikan penghantaran yang boleh dipercayai. Menggunakan Redis sebagai middleware mesej membolehkan pematuhan latensi rendah, boleh dipercayai dan berskala.
