Я следую официальному весеннему руководству, чтобы добавить поддержку сеанса Redis в весеннюю загрузку.
http://docs.spring.io/spring-session/docs/current/reference/html5/guides/boot.html
pom.xml
...
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.1.RELEASE</version>
...
<groupId>org.springframework.session</groupId>
<artifactId>spring-session</artifactId>
...
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-redis</artifactId>
...
Я не добавлял версию в весенние сессии, начиная с 1.3.0.RELEASE
весенней загрузки, в нее включен jar. Даже добавление версии 1.0.2.RELEASE
в соответствии с руководством не решило мою проблему
Обратите внимание, что для spring-boot 1.3.1.RELEASE
используется версия spring 4.2.4.RELEASE
.
Конфигурация
@EnableRedisHttpSession
public class HttpSessionConfig {
}
Файл свойств
#redis
spring.redis.host=127.0.0.1
spring.redis.port=6379
Я не добавлял секрет, так как пароль моего сервера Redis пуст. Даже добавление пароля не решило мою проблему.
Когда я запускаю приложение, оно выдает следующую ошибку
Вызвано: ..NoSuchBeanDefinitionException: не найден квалифицирующий bean-компонент типа [...SessionRepository] для зависимости: expect...endency. Аннотации зависимостей: {}
Я также добавил полный стек ошибок для справки ниже
016-01-05 01:49:50.775 ERROR 7616 --- [ main] o.s.boot.SpringApplication : Application startup failed
org.springframework.context.ApplicationContextException: Unable to start embedded container; nested exception is org.springframework.boot.context.embedded.EmbeddedServletContainerException: Unable to start embedded Tomcat
at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.onRefresh(EmbeddedWebApplicationContext.java:133) ~[spring-boot-1.3.1.RELEASE.jar:1.3.1.RELEASE]
...
at com.enbiso.proj.estudo.Application.main(Application.java:25) [classes/:na]
Caused by: org.springframework.boot.context.embedded.EmbeddedServletContainerException: Unable to start embedded Tomcat
at org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainer.initialize(TomcatEmbeddedServletContainer.java:99) ~[spring-boot-1.3.1.RELEASE.jar:1.3.1.RELEASE]
...
at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.onRefresh(EmbeddedWebApplicationContext.java:130) ~[spring-boot-1.3.1.RELEASE.jar:1.3.1.RELEASE]
... 8 common frames omitted
Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'springSessionRepositoryFilter' defined in class path resource [org/springframework/session/data/redis/config/annotation/web/http/RedisHttpSessionConfiguration.class]: Unsatisfied dependency expressed through constructor argument with index 0 of type [org.springframework.session.SessionRepository]: : No qualifying bean of type [org.springframework.session.SessionRepository] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {}; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [org.springframework.session.SessionRepository] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {}
at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:749) ~[spring-beans-4.2.4.RELEASE.jar:4.2.4.RELEASE]
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:464) ~[spring-beans-4.2.4.RELEASE.jar:4.2.4.RELEASE]
...
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) ~[na:1.8.0_20]
at java.lang.Thread.run(Thread.java:745) ~[na:1.8.0_20]
Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [org.springframework.session.SessionRepository] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {}
at org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoSuchBeanDefinitionException(DefaultListableBeanFactory.java:1373) ~[spring-beans-4.2.4.RELEASE.jar:4.2.4.RELEASE]
...
at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:741) ~[spring-beans-4.2.4.RELEASE.jar:4.2.4.RELEASE]
... 27 common frames omitted