У меня проблемы с работой JndiDataSourceLookup
с tomcat...
Я клонировал tomcat со всей его конфигурацией и приложениями с виртуальной машины на другую. Первоначальная установка работает нормально, но когда я попытался запустить новую, она не говорит:
Caused by: javax.naming.NameNotFoundException: Name [jdbc/sipreDs] is not bound in this Context. Unable to find [jdbc].
Итак, я попытался сделать некоторую отладку и написать свой заводской метод как:
@Bean
@SneakyThrows
public DataSource dataSource(){
Context context = new InitialContext();
NamingEnumeration<NameClassPair> names = context.list("java:comp/env/jdbc");
System.out.println("========================================");
System.out.println(" CONTEXT JNDI");
System.out.println("========================================");
while (names.hasMore()){
NameClassPair name = names.next();
System.out.println(name.getName());
}
System.out.println("=========================================");
final JndiDataSourceLookup dsLookup = new JndiDataSourceLookup();
dsLookup.setResourceRef(true);
return dsLookup.getDataSource("jdbc/sipreDs");
}
Результат:
========================================
CONTEXT JNDI
========================================
sipreDs
=========================================
Источник данных определяется в файле conf/context.xml
:
<Resource name="jdbc/sipreDs" auth="Container" type="javax.sql.DataSource"
maxActvive="100" maxIdle="30" maxWait="10000"
username="sipre" password="sipre" driverClassName="org.gjt.mm.mysql.Driver"
url="jdbc:mysql://localhost:3306/sipre"/>
Почему он печатает источник данных с обычным jndi, но использование spring вызывает исключение?