Rumah pangkalan data Redis Bagaimana untuk mengkonfigurasi dan menggunakan redis

Bagaimana untuk mengkonfigurasi dan menggunakan redis

May 31, 2023 pm 11:31 PM
redis

Spring-data-redis ialah bahagian sokongan untuk redis dalam modul spring-data, yang dirujuk sebagai "SDR". Ia menyediakan tahap enkapsulasi tinggi berdasarkan API klien jedis dan integrasi dengan bekas spring , pelanggan jedis sudah cukup Mudah dan ringan, spring-data-redis disyaki "terlalu reka bentuk".
Pelanggan jedis mempunyai kelemahan berikut dalam pelaksanaan pengaturcaraan:
1) Pengurusan sambungan tidak mempunyai automasi, dan reka bentuk sambungan-pool tidak mempunyai sokongan kontena yang diperlukan.
2) Operasi data perlu memberi perhatian kepada "bersiri"/"deserialisasi", kerana jenis data yang diterima oleh API klien jedis ialah rentetan dan bait, dan pengendalian data berstruktur (json, xml, pojo) memerlukan sokongan tambahan .
3) Operasi transaksi adalah berkod keras semata-mata
4) Fungsi pub/sub tidak mempunyai sokongan corak reka bentuk yang diperlukan, yang memerlukan terlalu banyak perhatian untuk pembangun.
1. Senario penggunaan Redis
Redis ialah pangkalan data Nilai Kunci jenis log sumber terbuka yang ditulis dalam bahasa ANSI C, menyokong rangkaian, boleh berasaskan memori dan berterusan serta menyediakan API dalam berbilang bahasa.
Kita semua tahu bahawa dalam aplikasi harian, kesesakan pangkalan data adalah yang paling mungkin berlaku. Disebabkan oleh jumlah data yang banyak dan pertanyaan yang kerap, prestasi projek semakin rendah dan lebih rendah disebabkan oleh had prestasi IO cakera.
Pada masa ini, rangka kerja caching berasaskan memori boleh menyelesaikan banyak masalah kita. Contohnya Memcache, Redis, dll. Meletakkan beberapa data yang kerap digunakan ke dalam cache untuk membaca sangat mengurangkan beban pada pangkalan data. Prestasi sistem yang lebih baik. Malah, perkara yang sama berlaku untuk cache tahap kedua hibernate dan Mybatis. Gunakan kelajuan memori membaca dan menulis berkelajuan tinggi untuk menyelesaikan kesesakan cakera keras.

2. Konfigurasikan dan gunakan redis

Konfigurasi dalam applicationContext-dao.xml adalah seperti berikut:

  1. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

  2. xmlns:context="http://www.springframework.org/schema/context"

  3. xmlns:mongo="http://www.springframework.org/schema/data/mongo"

  4. xmlns:aop="http://www.springframework.org/schema/aop"

  5. xsi:schemaLocation="http://www.springframework.org/schema/beans

  6. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

  7. http://www.springframework.org/schema/data/mongo

  8. http://www.springframework.org/schema/data/mongo/spring-mongo.xsd

  9. http://www.springframework.org/schema/context

  10. http://www.springframework.org/schema/context/spring-context-3.0.xsd

  11. http://www.springframework.org/schema/aop

  12. http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">

  13.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            <

  14.               

  15.           

  16.           

  17.       

  18.            

  19.            

  20.            

  21.            

  22.       

  23.            

  24.           

  25.           

  26.           

  27.       

  28.       

  29.               

  30.               

  31.               

  32.               

  33.               

  34.       

  35.   

  36.   

database.properties配置文件如下:

  1. redis.maxIdle=10  

  2. redis.maxActive=20  

  3. redis.maxWait=10000  

  4. redis.testOnBorrow=true  

  5. redis.host=192.168.1.76  

  6. redis.port=6379  

  7. redis.pass=password1  

spring-data-redis提供了多种serializer策略,这对使用jedis的开发者言叐供了多种serializer策略,这对使用jedis的,开发者耶便捷。 sdr提供了4种内置的serializer:

  • JdkSerializationRedisSerializer:使用JDK的序列化手段(boleh bersiri接口,ObjectInputStrean,ObjectOutputStream),数据以字节流存储,POJO对是用家身序列化机制,将pojo类通过ObjectInputStream/ObjectOutputStream进行序列化操作,最终redis-server中将存储字节序列,是目前最常用的序列化策略。

  • Stringredisserializer: 字符串 字符串 编码, 数据 以 string 存储, kekunci 或者 nilai 为 字 符串 的 场景, 根据 根据 的 的 charset 对 数据 数据 字节 字节 序列 编码 成 成 成 成 是charset)”的直接封装。是最轻量级和高效的策略。

  • JacksonJsonRedisSerializer: storan format json, alat jackson-json menyediakan keupayaan penukaran antara javabean dan json Ia boleh mensirikan kejadian pojo ke dalam format json dan menyimpannya dalam redis, atau menukar data format json kepada kejadian pojo. Oleh kerana alat Jackson perlu menyatakan secara eksplisit jenis Kelas semasa mensiri dan menyahsiri, strategi ini lebih rumit sedikit untuk dirangkumkan. [Memerlukan sokongan alat jackson-mapper-asl]

  • OxmSerializer: storan format xml, menyediakan keupayaan untuk menukar javabeans kepada xml yang tersedia pada masa ini sokongan tiga pihak termasuk jaxb, apache-xmlbeans data yang disimpan dalam redis akan menjadi alat xml. Walau bagaimanapun, menggunakan strategi ini akan menjadikan pengaturcaraan lebih sukar dan paling berkesan ia tidak disyorkan. [Memerlukan sokongan modul spring-oxm]

Antaranya, JdkSerializationRedisSerializer dan StringRedisSerializer ialah strategi bersiri yang paling asas Antaranya, "JacksonJsonRedisSerializer" dan "OxmSerializer" adalah berdasarkan storan rentetan, jadi ia lebih bersiri "maju" (akhirnya menggunakan penghuraian rentetan dan membina objek java). JdkSerializationRedisSerializer dan StringRedisSerializer ialah strategi paling asas untuk "serialisasi dan serialisasi". JacksonJsonRedisSerializer" dan "OxmSerializer" secara langsung pada masa reka bentuk, kerana sama ada ia json atau xml, mereka sendiri masih String. Jika data anda perlu dihuraikan oleh alat pihak ketiga, data harus menggunakan StringRedisSerializer dan bukannya JdkSerializationRedisSerializer.

​ 4 jenis serializers perlu diisytiharkan dalam RedisTemplate, lalai ialah "JdkSerializationRedisSerializer":

1) keySerializer: Untuk operasi K-V biasa, strategi bersiri yang diguna pakai oleh kunci
2) valueSerializer: Strategi bersiri yang diguna pakai mengikut nilai
3) hashKeySerializer: Dalam struktur data cincang, strategi bersiri bagi kunci cincang
4) hashValueSerializer: strategi siri nilai hash

Dalam apa jua keadaan, adalah disyorkan untuk menggunakan StringRedisSerializer untuk kunci/hashKey.

spring-data-redis menyediakan fungsi berikut untuk jedis:

1 Pengurusan, menyediakan kelas "RedisTemplate" yang sangat lengkap

2. Mengelaskan dan merangkum sejumlah besar API dalam klien jedis, dan merangkum jenis operasi yang sama ke dalam antara muka operasi

  • ValueOperations: Operasi K-V yang ringkas

  • SetOperations: set jenis operasi data

  • ZSetOperations: operasi data jenis zset

  • HashOperations: Operasi data untuk jenis peta

  • ListOperations: Operasi data untuk jenis senarai

3. Menyediakan API operasi mudah "terikat" (mengikat) untuk kekunci Anda boleh merangkum kunci yang ditentukan melalui terikat, dan kemudian melakukan satu siri operasi tanpa "jelas" menyatakan kunci itu sekali lagi, iaitu, BoundKeyOperations:

<.>
  • BoundValueOperations

  • BoundSetOperations

  • BoundListOperations

  • BoundSetOperations

  • BoundHashOperations

3. Penggunaan RedisTemplate

Sebagai kelas templat, kelas ini menyediakan banyak API untuk menggunakan redis dengan cepat tanpa perlu mengekalkan sambungan dan transaksi sendiri. Pada mulanya, BaseRedisDao yang saya cipta diwarisi daripada kelas ini. Kelebihan warisan ialah dalam setiap Dao saya, saya boleh mengawal penyeri bersiri secara bebas dan sama ada saya memerlukan urus niaga saya tidak perlu memahami perkara ini terlebih dahulu, cuma ikut kaedah konfigurasi semasa saya. Templat menyediakan satu siri operasi, seperti valueOperation, HashOperation, ListOperation, SetOperation, dsb., yang digunakan untuk mengendalikan Redis daripada jenis data yang berbeza. Selain itu, RedisTemplate juga menyediakan *OperationsEditor yang sepadan, yang digunakan untuk menyuntik terus Operasi yang sepadan melalui RedisTemplate.
Kod teras:

  1. pakej com.npf.dao.impl;

  2. import java.util.ArrayList;

  3. import java.util.List;

  4. import java.util.Map;

  5. import java.util.Map.Entry;

  6. import javax.annotation.Resource;

  7. import org.springframework.beans.factory.anotation.Autowired; import org.springframework.data.redis.core.HashOperations; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Repository;
  8.   

  9. import com.npf.dao.StudentDao;  

  10. import com.npf.model.Pelajar;  

  11.   

  12. @Repositori  

  13. kelas awam StudentDaoImpl melaksanakan StudentDao{  

  14.   

  15.     @Autowired  

  16.     peribadi RedisTemplate redisTemplate;  

  17.       

  18.     @Resource(name="redisTemplate")  

  19.     HashOperations opsForHash;  

  20.       

  21.     String akhir statik awam PELAJAR = "pelajar";  

  22.       

  23.     @Override  

  24.     public void save(Pelajar pelajar) {  

  25.         opsForHash.put(STUDENT, student.getId(), student);  

  26.     }  

  27.   

  28.     @Override  

  29.     awam Pencarian Pelajar(id String) {  

  30.         Pelajar pelajar = opsForHash.get(STUDENT, id);  

  31.         pelajar kembali;  

  32.     }  

  33.   

  34.     @Override  

  35.     public void delete(String id) {  

  36.         opsForHash.delete(STUDENT, id);  

  37.     }  

  38.   

  39.     @Override  

  40.     kemas kini public void (Pelajar pelajar) {  

  41.         opsForHash.put(STUDENT, student.getId(), student);  

  42.     }  

  43.   

  44.     @Override  

  45.     awam Senarai findAll() {  

  46.         Peta entri = opsForHash.entry(STUDENT);  

  47.         Senaraikan stuList = new ArrayList();  

  48.         untuk(Entry entry : entry.entrySet()){  

  49.             stuList.add(entry.getValue());  

  50.         }  

  51.         kembalikan stuList;  

  52.     }  

  53. }  

控制层代码如下:

  1. pakej com.npf.controller;  

  2.   

  3. import java.util.List;  

  4. import java.util.UUID;  

  5.   

  6. import org.springframework.beans.factory.anotation.Autowired;  

  7. import org.springframework.stereotype.Controller;  

  8. import org.springframework.ui.Model;  

  9. import org.springframework.web.bind.annotation.RequestMapping;  

  10. import org.springframework.web.bind.annotation.RequestParam;  

  11.   

  12. import com.npf.model.Pelajar;  

  13. import com.npf.service.StudentService;  

  14.   

  15. @Pengawal  

  16. Pengawal Pelajar kelas awam {  

  17.   

  18.     @Autowired  

  19.     private StudentService studentService;  

  20.       

  21.     @RequestMapping("/pelajar/simpan")  

  22.     awam String simpanPelajar(Pelajar Pelajar){  

  23.         String id = UUID.randomUUID().toString();  

  24.         System.out.println(id);  

  25.         student.setId(id);  

  26.         studentService.save(pelajar);  

  27.         return "redirect:/student/find/all";  

  28.     }  

  29.       

  30.     @RequestMapping("/pelajar/kemas kini")  

  31.     public String updatePelajar(Pelajar pelajar){  

  32.         studentService.update(pelajar);  

  33.         return "redirect:/student/find/all";  

  34.     }  

  35.       

  36.     @RequestMapping("/pelajar/ke/simpan/borang")  

  37.     awam String toSaveStudentForm(){  

  38.         pulangkan "simpan";  

  39.     }  

  40.       

  41.     @RequestMapping("/pelajar/padam")  

  42.     awam String deleteStudent(@RequestParam("id") String id){  

  43.         studentService.delete(id);  

  44.         return "redirect:/student/find/all";  

  45.     }  

  46.       

  47.     @RequestMapping("/pelajar/ke/kemas kini/borang")  

  48.     awam String toUpdateStudentForm(@RequestParam("id") String id,Model model){  

  49.         Student stu = studentService.find(id);  

  50.         model.addAttribute("stu", stu);  

  51.         kembalikan "kemas kini";  

  52.     }  

  53.       

  54.     @RequestMapping("/pelajar/cari/semua")  

  55.     awam String findPelajar(Model model){  

  56.         Senaraikan stuList = studentService.findAll();  

  57.         model.addAttribute("stuList", stuList);  

  58.         kembalikan "senarai";  

  59.     }  

  60. }  

Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi dan menggunakan redis. 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)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 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)

Cara Membina Mod Kluster Redis Cara Membina Mod Kluster Redis Apr 10, 2025 pm 10:15 PM

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 melaksanakan redis yang mendasari Cara melaksanakan redis yang mendasari Apr 10, 2025 pm 07:21 PM

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 melihat nombor versi Redis Cara melihat nombor versi Redis Apr 10, 2025 pm 05:57 PM

Untuk melihat nombor versi REDIS, anda boleh menggunakan tiga kaedah berikut: (1) Masukkan arahan INFO, (2) Mulakan pelayan dengan pilihan --version, dan (3) Lihat fail konfigurasi.

Cara Melihat Semua Kekunci di Redis Cara Melihat Semua Kekunci di Redis Apr 10, 2025 pm 07:15 PM

Untuk melihat semua kunci di Redis, terdapat tiga cara: Gunakan perintah kunci untuk mengembalikan semua kunci yang sepadan dengan corak yang ditentukan; Gunakan perintah imbasan untuk melangkah ke atas kunci dan kembalikan satu set kunci; Gunakan arahan maklumat untuk mendapatkan jumlah kunci.

Apa yang perlu dilakukan sekiranya pelayan redis tidak dapat dijumpai Apa yang perlu dilakukan sekiranya pelayan redis tidak dapat dijumpai Apr 10, 2025 pm 06:54 PM

Langkah-langkah untuk menyelesaikan masalah yang tidak dapat dijumpai oleh Redis-Server: periksa pemasangan untuk memastikan Redis dipasang dengan betul; Tetapkan pembolehubah persekitaran redis_host dan redis_port; Mulakan Redis Server Redis-server; Semak sama ada pelayan sedang menjalankan ping redis-cli.

Cara menggunakan redis zset Cara menggunakan redis zset Apr 10, 2025 pm 07:27 PM

Redis memerintahkan set (ZSET) digunakan untuk menyimpan elemen yang diperintahkan dan disusun mengikut skor yang berkaitan. Langkah -langkah untuk menggunakan ZSET termasuk: 1. Buat zset; 2. Tambah ahli; 3. Dapatkan skor ahli; 4. Dapatkan kedudukan; 5. Dapatkan ahli dalam julat ranking; 6. Padam ahli; 7. Dapatkan bilangan elemen; 8. Dapatkan bilangan ahli dalam julat skor.

Bagaimana kunci unik untuk pertanyaan redis Bagaimana kunci unik untuk pertanyaan redis Apr 10, 2025 pm 07:03 PM

Redis menggunakan lima strategi untuk memastikan keunikan kekunci: 1. Pemisahan ruang nama; 2. Struktur data hash; 3. Tetapkan struktur data; 4. Karakter Khas Kekunci String; 5. Pengesahan skrip Lua. Pilihan strategi khusus bergantung kepada organisasi data, prestasi, dan keperluan skalabilitas.

Cara Menggunakan Kaunter Redis Cara Menggunakan Kaunter Redis Apr 10, 2025 pm 07:00 PM

Kaunter Redis menyediakan struktur data untuk menyimpan dan mengendalikan kaunter. Langkah -langkah khusus termasuk: Buat kaunter: Gunakan perintah Incr untuk menambah 1 ke kekunci yang ada. Dapatkan nilai kaunter: Gunakan arahan GET untuk mendapatkan nilai semasa. Kaunter kenaikan: Gunakan perintah Inter, diikuti dengan jumlah yang akan ditingkatkan. Kaunter pengurangan: Gunakan perintah Dec Dec atau Decrby untuk menurun sebanyak 1 atau tentukan jumlahnya. Tetapkan semula kaunter: Gunakan arahan set untuk menetapkan nilainya kepada 0. Di samping itu, kaunter boleh digunakan untuk mengehadkan kadar, pengesanan sesi, dan membuat sistem pengundian.

See all articles