


Quelle est la méthode de sérialisation par défaut pour modifier Springsession Redis ?
一、配置Spring-session-redis 的关键配置如下:
<!-- 设置Cookie domain 和 名称 --> <bean id="defaultCookieSerializer" class="org.springframework.session.web.http.DefaultCookieSerializer"> <property name="domainName" value="${sso.cookie.domain}"/> <property name="cookieName" value="${sso.cookie.name}"/> <property name="cookieMaxAge" value="${sso.cookie.maxage}" /> <property name="cookiePath" value="${sso.cookie.path}" /> <!--<property name="domainNamePattern" value="^.+?\\.(\\w+\\.[a-z]+)$"/>--> </bean> <!-- 配置spring session --> <bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> <!-- session超时设置 --> <property name="maxInactiveIntervalInSeconds" value="${spring.session.expiration}" /> <property name="cookieSerializer" ref="defaultCookieSerializer" /> </bean>
二、查看 RedisHttpSessionConfiguration 源代码如下:
@Bean public RedisTemplate<Object, Object> sessionRedisTemplate( RedisConnectionFactory connectionFactory) { RedisTemplate<Object, Object> template = new RedisTemplate<Object, Object>(); template.setKeySerializer(new StringRedisSerializer()); template.setHashKeySerializer(new StringRedisSerializer()); if (this.defaultRedisSerializer != null) { template.setDefaultSerializer(this.defaultRedisSerializer); } template.setConnectionFactory(connectionFactory); return template; } @Bean public RedisOperationsSessionRepository sessionRepository( @Qualifier("sessionRedisTemplate") RedisOperations<Object, Object> sessionRedisTemplate, ApplicationEventPublisher applicationEventPublisher) { RedisOperationsSessionRepository sessionRepository = new RedisOperationsSessionRepository( sessionRedisTemplate); sessionRepository.setApplicationEventPublisher(applicationEventPublisher); sessionRepository .setDefaultMaxInactiveInterval(this.maxInactiveIntervalInSeconds); if (this.defaultRedisSerializer != null) { sessionRepository.setDefaultSerializer(this.defaultRedisSerializer); } String redisNamespace = getRedisNamespace(); if (StringUtils.hasText(redisNamespace)) { sessionRepository.setRedisKeyNamespace(redisNamespace); } sessionRepository.setRedisFlushMode(this.redisFlushMode); return sessionRepository; }
创建RedisTemplate时,指定的默认序列化是:StringRedisSerializer,当 defaultRedisSerializer != null 时,重新指定了序列化方法。以下是 defaultRedisSerializer 的初始化代码:
@Autowired(required = false) @Qualifier("springSessionDefaultRedisSerializer") public void setDefaultRedisSerializer( RedisSerializer<Object> defaultRedisSerializer) { this.defaultRedisSerializer = defaultRedisSerializer; }
因此,我们只需要创建名为 springSessionDefaultRedisSerializer 的Bean,及可修改默认序列化方法。
<bean id="springSessionDefaultRedisSerializer" class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer" />
注:使用JSON序列化,在特定的场景,会报错,谨慎使用。
三、RedisTemplate 初始化代码如下:
public void afterPropertiesSet() { super.afterPropertiesSet(); boolean defaultUsed = false; if (defaultSerializer == null) { defaultSerializer = new JdkSerializationRedisSerializer( classLoader != null ? classLoader : this.getClass().getClassLoader()); } if (enableDefaultSerializer) { if (keySerializer == null) { keySerializer = defaultSerializer; defaultUsed = true; } if (valueSerializer == null) { valueSerializer = defaultSerializer; defaultUsed = true; } if (hashKeySerializer == null) { hashKeySerializer = defaultSerializer; defaultUsed = true; } if (hashValueSerializer == null) { hashValueSerializer = defaultSerializer; defaultUsed = true; } } if (enableDefaultSerializer && defaultUsed) { Assert.notNull(defaultSerializer, "default serializer null and not all serializers initialized"); } if (scriptExecutor == null) { this.scriptExecutor = new DefaultScriptExecutor<K>(this); } initialized = true; }
从句式和语序上调整,可将原话重写为:"如果未指定默认值,使用JdkSerializationRedisSerializer。"。
特别提醒:如果已有session中存在旧有的序列化值,更换序列化方法后,要删除旧值,使用新的序列化进行调试,否则会报序列化错误。
特别提醒:如果已有session中存在旧有的序列化值,更换序列化方法后,要删除旧值,使用新的序列化进行调试,否则会报序列化错误。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Linux System restreint les ressources utilisateur via la commande UliMIT pour éviter une utilisation excessive des ressources. 1.Ulimit est une commande shell intégrée qui peut limiter le nombre de descripteurs de fichiers (-n), la taille de la mémoire (-v), le nombre de threads (-u), etc., qui sont divisés en limite douce (valeur effective actuelle) et limite dure (limite supérieure maximale). 2. Utilisez directement la commande ulimit pour une modification temporaire, telle que Ulimit-N2048, mais elle n'est valable que pour la session en cours. 3. Pour un effet permanent, vous devez modifier /etc/security/limits.conf et les fichiers de configuration PAM, et ajouter SessionRequiredPam_limits.so. 4. Le service SystemD doit définir Lim dans le fichier unitaire

La stratégie de mise en cache de la page de Laravel peut améliorer considérablement les performances du site Web. 1) Utilisez des fonctions de cache d'assistance pour implémenter la mise en cache de page, telles que la méthode Cache :: Rappelez-vous. 2) Sélectionnez le backend de cache approprié, tel que redis. 3) Faites attention aux problèmes de cohérence des données et vous pouvez utiliser des caches à grain fin ou des auditeurs d'événements pour effacer le cache. 4) Une optimisation supplémentaire est combinée avec le cache de routage, les étiquettes de cache et de cache d'afficher. En appliquant rationnellement ces stratégies, les performances du site Web peuvent être effectivement améliorées.

Les étapes de dépannage et de réparation des défaillances de réplication des esclaves de Redis incluent: 1. Vérifiez la connexion réseau et utilisez Ping ou Telnet pour tester la connectivité; 2. Vérifiez le fichier de configuration Redis pour vous assurer que la réplique et le temps de remplacement sont définis correctement; 3. Vérifiez le fichier journal Redis et recherchez des informations d'erreur; 4. S'il s'agit d'un problème de réseau, essayez de redémarrer le périphérique réseau ou de changer le chemin alternatif; 5. S'il s'agit d'un problème de configuration, modifiez le fichier de configuration; 6. S'il s'agit d'un problème de synchronisation des données, utilisez la commande SlaveOf pour réintégrer les données.

RedisisuniqueComperedTotraditionalsqldatabasesInSeverAlways: 1) itoperatesprimy inmemory, permettant à la base de laadandwriteoperations.2)

Les étapes d'emplacement et de traitement rapides de la défaillance du nœud de cluster redis sont les suivantes: 1. Confirmez le défaut: utilisez la commande CluSterodes pour afficher l'état du nœud. Si l'échec est affiché, le nœud échouera. 2. Déterminez la cause: vérifiez le réseau, le matériel et la configuration. Les problèmes courants incluent les limites de mémoire dépassant. 3. Réparation et restauration: prenez des mesures basées sur les raisons, telles que le redémarrage du service, le remplacement du matériel ou la modification de la configuration. 4. Remarques: Assurer la cohérence des données, sélectionner les politiques de basculement appropriées et établir des systèmes de surveillance et d'alarme.

Des solutions efficaces au problème du cerveau divisé dans le cluster redis comprennent: 1) l'optimisation de la configuration du réseau pour assurer la stabilité de la connexion; 2) Surveillance du nœud et détection des défauts, surveillance en temps réel avec outils; 3) Mécanisme de basculement, fixant des seuils élevés pour éviter plusieurs nœuds maître; 4) Garantie de cohérence des données, en utilisant la fonction de réplication pour synchroniser les données; 5) Intervention et récupération manuelle et traitement manuel si nécessaire.

Redis et RabbitMQ ont chacun leurs propres avantages dans les scénarios de performance et d'application conjointe. 1.Redis fonctionne parfaitement dans la lecture et l'écriture des données, avec une latence de hausses pour les microsecondes, adapté à des scénarios de concurrence élevés. 2.Rabbitmq se concentre sur la messagerie, la latence en millisecondes et prend en charge les modèles multi-quelles et consommateurs. 3. Dans les applications conjointes, Redis peut être utilisé pour le stockage des données, RabbitMQ gère les tâches asynchrones et améliore la vitesse et la fiabilité de la réponse du système.

Les méthodes pour améliorer les performances de persistance redis via la configuration incluent: 1. Ajustez les paramètres de sauvegarde de RDB pour réduire la fréquence de génération d'instantané; 2. Définissez le paramètre APPENDFSYNC d'AOF sur EverySEC; 3. Utilisez AOF et RDB en combinaison; 4. Utilisez des paramètres sans apprendfsync-on-liwrite pour optimiser les performances de réécriture AOF; 5. Activer le mode de persistance hybride. Ces configurations peuvent améliorer les performances tout en garantissant la sécurité des données.
