La configuration décrite ci-dessous ne permet pas de faire du JNDI pur. Elle est toutefois plus adaptée car permet de connecter le portail prioritairement à la ressource JNDI et, en cas de non présence de la ressource, permet de se brancher directement sur la ressource JDBC. |
Le passage de JDBC vers JNDI se fait en modifiant plusieurs fichiers.
Modifier le rdbm.properties :
##### Maven Filtering ##### Use these settings to define DB connection settings in filters file: hibernate.connection.jndiname=${environment.build.hibernate.connection.jndiname} ##### /filters/{env}.properties |
Déclarer la ressource JNDI "jdbc/uPortalDB" au niveau du serveur Tomcat :
<Context path="/portail" docBase="/opt/webapps/uPortal" reloadable="false" crossContext="true" > <Resource name="jdbc/uPortalDB" auth="Container" type="javax.sql.DataSource" username="USER" password="PASSWORD" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://database.ip:3306/uPortal4" maxActive="100" maxIdle="30" maxWait="10000" poolPreparedStatements="true" removeAbandoned="true" removeAbandonedTimeout="300" validationQuery="SELECT 1" logAbandoned="true" /> |
crossContext est indispensable au bon fonctionnement du contexte uPortal, par exemple pour le partage de session ou pour Pluto. |
Utiliser la ressource dans l'application. Modifier :
<bean id="PortalDb" parent="basePooledDataSource"> <qualifier value="PortalDb"/> <property name="driverClassName" value="${hibernate.connection.driver_class}" /> <property name="url" value="${hibernate.connection.url}" /> <property name="username" value="${hibernate.connection.username}" /> <property name="password" value="${hibernate.connection.password}" /> </bean> |
En :
<bean id="PortalDb" class="org.jasig.portal.spring.beans.factory.MediatingFactoryBean"> <property name="type" value="javax.sql.DataSource" /> <property name="delegateBeanNames"> <list> <value>PortalDb.JNDI</value> <value>PortalDb.direct</value> </list> </property> </bean> <bean id="PortalDb.JNDI" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName" value="java:comp/env/${hibernate.connection.jndiname}" /> </bean> <bean id="PortalDb.direct" class="org.apache.commons.dbcp.BasicDataSource" lazy-init="true"> <property name="driverClassName" value="${hibernate.connection.driver_class}" /> <property name="url" value="${hibernate.connection.url}" /> <property name="username" value="${hibernate.connection.username}" /> <property name="password" value="${hibernate.connection.password}" /> <property name="maxActive" value="50" /> <property name="maxIdle" value="10" /> <property name="maxWait" value="1000" /> <property name="removeAbandoned" value="true" /> <property name="removeAbandonedTimeout" value="300" /> <property name="logAbandoned" value="true" /> </bean> |
Configurer le fichier esup.properties :
environment.build.hibernate.connection.jndiname=jdbc/uPortalDB |
https://wiki.jasig.org/display/UPM40/Using+JNDI+managed+DataSources |