Spring menyediakan penyelesaian untuk mengendalikan sesi yang diedarkan: Spring-Session. Spring-Session menyediakan sokongan untuk storan biasa seperti Redis, MongoDB, MySQL, dll. Spring-Session menyediakan integrasi telus dengan HttpSession, yang bermaksud pembangun boleh menggunakan pelaksanaan yang disokong oleh Spring-Session untuk menukar HttpSession kepada Spring-Session.
Langkah 1. Tambah kebergantungan
Tambah kebergantungan untuk Redis dan Spring-Session dalam Beg fail pom.xml projek .
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency>
Langkah 2. Konfigurasikan kaedah kegigihan Redis dan Spring-Session
Pengarang sudah biasa menggunakan application.properties sebagai fail konfigurasi SpringBoot, atau anda boleh menggunakan aplikasi .yml kepada konfigurasi. Tambahkan konfigurasi berikut dalam fail konfigurasi application.properties.
# 配置 Redis 服务器地址(此处是一个虚假地址) spring.redis.host=10.211.12.6 # 配置 Redis 端口 spring.redis.port=6379 # 配置 Redis 密码 spring.redis.password=123456 # 其他 Redis 的配置还有很多,例如 Redis 连接池的配置,此处暂时只配置上述几项关键点 # spring session 配置 spring.session.store-type=redis
Langkah 3. Gunakan mekanisme siri JSON
Sesi Musim Bunga menggunakan mekanisme siri JDK secara lalai, yang memerlukan kelas untuk melaksanakan antara muka Boleh Bersiri dan Array bait binari bersiri adalah sukar untuk difahami. Menggunakan mekanisme bersiri JSON, rentetan bersiri mudah difahami.
package com.test.conf; import com.alibaba.fastjson.support.spring.GenericFastJsonRedisSerializer; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.serializer.RedisSerializer; // spring session 使用 json 序列化机制 @Configuration public class SessionConfig { @Bean public RedisSerializer<Object> springSessionDefaultRedisSerializer() { return new GenericFastJsonRedisSerializer(); } }
Langkah 4. Tambahkan anotasi @EnableRedisHttpSession ke kelas permulaan SpringBoot untuk membuka Spring-Session
package com.test; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession; @SpringBootApplication // 开启 Spring-Session @EnableRedisHttpSession // @EnableRedisHttpSession(maxInactiveIntervalInSeconds = 1800, redisNamespace = "test:session") public class TestSessionAppApplication { public static void main(String[] args) { SpringApplication.run(TestSessionAppApplication.class, args); } }
Tambahkan @EnableRedisHttpSession-Session untuk membuka Spring-Session Anotasi mempunyai beberapa parameter yang boleh ditetapkan secara individu, antaranya maxInactiveIntervalInSeconds mewakili masa tamat Sesi, nilai lalai ialah 30 minit redisNamespace mewakili ruang nama apabila Sesi disimpan dalam Redis, iaitu, awalan nama utama Sesi yang disimpan; dalam Redis, nilai lalai ialah "spring :session", dalam projek sebenar, sistem yang berbeza mungkin menggunakan Redis yang sama untuk menjimatkan sumber Untuk membezakan Sesi sistem yang berbeza, ruang nama yang berasingan boleh ditetapkan untuk setiap sistem.
2.1 Demo ujian penulisan lapisan pengawal
@RequestMapping(value = "testSession") public String testSession(HttpServletRequest request) { HttpSession session = request.getSession(); log.info("sessionId:[{}]", session.getId()); session.setAttribute("name", "Lucy"); session.setAttribute("age", "20"); return session.getAttribute("name").toString(); }
2.2 Proses ujian
Pada masa yang sama, mulakan projek SpringBoot dengan port yang berbeza 9001 /9002 Simulasikan nod yang berbeza dalam kelompok teragih pada komputer tempatan anda. Gunakan Google Chrome untuk membuka pautan http://localhost:9001/testSession Pelayan mencetak log seperti yang ditunjukkan di bawah.
sessionId:[5c417104-4f6d-430d-b569-cbc1e19cdf02]
Pelanggan log masuk ke pelayan Redis dan melihat kandungan Sesi dalam Redis.
[testuser@vm ~]$ redis-cli -h 10.211.12.6 -p 6379 10.211.12.6:6379> auth 123456 OK 10.211.12.6:6379> keys * 1) "spring:session:expirations:1658127780000" 2) "spring:session:sessions:5c417104-4f6d-430d-b569-cbc1e19cdf02" 3) "spring:session:sessions:expires:5c417104-4f6d-430d-b569-cbc1e19cdf02"
Redis akan menyimpan tiga pasangan nilai kunci (selepas ini dirujuk sebagai nilai kunci) untuk setiap Sesi Semula:
Nilai kunci pertama menyimpan Id ini Session , ialah struktur data Redis jenis Set. Nilai 1658127780000 terakhir dalam kunci ini ialah cap masa yang dikira berdasarkan detik tamat tempoh Sesi yang digulung ke minit seterusnya.
Nilai kunci kedua digunakan untuk menyimpan maklumat terperinci Sesi Ia ialah struktur data Redis jenis Hash, termasuk masa akses terkini Sesi (lastAccessedTime) dan selang tamat tempoh (maxInactiveInterval , lalai ialah 30 minit, nilai saat disimpan di sini), masa penciptaan (creationTime), sessionAttr, dsb.
Nilai kunci ketiga digunakan untuk mewakili masa tamat tempoh Sesi dalam Redis dan merupakan struktur data Redis jenis String. Nilai kunci ini tidak menyimpan sebarang data berguna, ia hanya ditetapkan untuk menunjukkan tamat tempoh Sesi. Masa tamat tempoh kunci ini dalam Redis ialah selang tamat tempoh Sesi Anda boleh menggunakan perintah ttl untuk melihat masa tamat tempoh kunci, iaitu masa tamat tempoh Sesi.
Semasa ujian ini, butiran data dalam Redis adalah seperti berikut.
10.211.12.6:6379> type spring:session:expirations:1658127780000 set 10.211.12.6:6379> smembers spring:session:expirations:1658127780000 1) "\"expires:5c417104-4f6d-430d-b569-cbc1e19cdf02\"" 10.211.12.6:6379> 10.211.12.6:6379> type spring:session:sessions:5c417104-4f6d-430d-b569-cbc1e19cdf02 hash 10.211.12.6:6379> hgetall spring:session:sessions:5c417104-4f6d-430d-b569-cbc1e19cdf02 1) "lastAccessedTime" 2) "1658125969794" 3) "maxInactiveInterval" 4) "1800" 5) "creationTime" 6) "1658125925139" 7) "sessionAttr:age" 8) "\"20\"" 9) "sessionAttr:name" 10) "\"Lucy\"" 10.211.12.6:6379> 10.211.12.6:6379> type spring:session:sessions:expires:5c417104-4f6d-430d-b569-cbc1e19cdf02 string 10.211.12.6:6379> get spring:session:sessions:expires:5c417104-4f6d-430d-b569-cbc1e19cdf02 "" 10.201.42.26:6379>
Semak kuki penyemak imbas Pada masa ini, pelayar sudah mempunyai kuki yang sedang digunakan, seperti yang ditunjukkan dalam gambar di bawah.
Muat semula penyemak imbas, SessionId yang dicetak pada bahagian belakang kekal tidak berubah, kandungan Sesi dalam Redis tidak ditambahkan dan penyemak imbas mengembalikan kandungan seperti biasa. Ini bermakna operasi sesi nod ini adalah normal.
Dengan penyemak imbas yang sama, buka pautan port ujian yang lain http://localhost:9002/testSession Penyemak imbas secara automatik membawa kandungan cetakan bahagian belakang adalah sama dan kandungan Redis adalah sama (masa tamat tempoh telah dikemas kini), menunjukkan Sesi kelompok dikongsi antara nod.
Walaupun Sesi Musim Bunga menyediakan kaedah penyepaduan hampir telus yang mudah digunakan yang menjadikan sesi kluster sokongan tidak penting, sebenarnya Sesi Musim Bunga mempunyai beberapa kelemahan .
Adalah mustahil untuk menerbitkan peristiwa tamat tempoh dan pemusnahan Sesi dalam masa nyata
Kaedah bersiri mungkin tidak disokong untuk beberapa jenis tertentu; sesi. Tidak begitu baik; senario konkurensi tinggi, Kerana Sesi bukan operasi CAS (Banding Dan Tetapkan), mungkin terdapat beberapa isu konkurensi (isu kecil).
Walaupun Sesi Musim Bunga mempunyai beberapa kekurangan, secara keseluruhannya ia masih sangat boleh digunakan. Selain itu, anda boleh menulis sendiri set penapis untuk mengoptimumkan kelemahan Spring-Session dan melaksanakan sesi teragih.
Atas ialah kandungan terperinci Cara SpringBoot menyepadukan Sesi Musim Bunga untuk melaksanakan sesi teragih. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!