2012-06-29 3 views
1

У меня есть рабочий Apache 2.2.16 на Debian Squeeze, который обслуживает некоторые приложения PHP из/var/www/с использованием разных доменов (например, phpApp1.com, phpApp2.com).Подключение Apache и Tomcat с помощью mod_proxy_ajp работает, но JDBC затем завершается

У меня также есть работающий Tomcat 7.x, который живет в/opt/tomcat/и обслуживает приложение JSF + JPA, которое живет в/opt/tomcat/webapps/MyApp /.

Таким образом, MyApp можно получить через, например, myapp.com:8080/MyApp/home.html или phpApp1.com:8080/MyApp/home.html (из-за порта). Так как я хотел, чтобы это было myapp.com/home.html вместо этого, я подключил Apache и Tomcat с помощью mod_proxy_ajp, используя следующие конфигурационные файлы:

Апачи виртуального хоста в/и т.д./apache2/сайты-доступные/MyApp

<Virtualhost *:80> 
    ServerName myapp.com 
    ServerAlias *.myapp.com 
    ProxyPass/ajp://localhost:8009/ 
    ProxyPassReverse/ajp://localhost:8009/ 
</Virtualhost> 

и виртуальный хост Tomcat в /opt/tomcat/conf/server.xml

<Host name="myapp.com" appBase="webapps" unpackWARs="true" autoDeploy="true"> 
    <Context path="" reloadable="true" debug="0" docBase="MyApp" /> 
    <Alias>www.myapp.com</Alias> 
</Host> 

Это работает к тому, что я CANN доступ http://myapp.com/home.html и получить правильную страницу HTML, включая CSS, изображения и JS. Таким образом, AJP-разъем в tomcat должен работать.

НО приложение не может установить соединение JDBC, которое в противном случае работает нормально. Неважно, пользуюсь ли я myapp.com или myapp.com:8080, он терпит неудачу в любом случае. Тем не менее, он работает, если я получаю доступ к моему приложению http://phpapp1.com:8080/MyApp/home.html. Это происходит только при использовании прокси-домена «myapp.com».

У кого-нибудь возникли подобные проблемы при использовании AJP и JDBC? Как я могу это решить? У меня была такая же проблема при использовании mod_jk, которая также использует AJP. Заранее спасибо.

Update 1

@Mark Rotteveel: Что вы имеете в виду под "прямого подключения"? Я имею в виду, что соединение JDBC работает, если я использую один из доменов, которые не указаны в качестве виртуальных хостов в tomcats server.xml.

Здесь ошибка соединения:

ERROR: HHH000231: Schema export unsuccessful 
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null' 
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1452) 
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1371) 
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044) 
at org.hibernate.service.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:141) 
at org.hibernate.tool.hbm2ddl.SuppliedConnectionProviderConnectionHelper.prepare(SuppliedConnectionProviderConnectionHelper.java:51) 
at org.hibernate.tool.hbm2ddl.DatabaseExporter.<init>(DatabaseExporter.java:52) 
at org.hibernate.tool.hbm2ddl.SchemaExport.execute(SchemaExport.java:367) 
at org.hibernate.tool.hbm2ddl.SchemaExport.create(SchemaExport.java:304) 
at org.hibernate.tool.hbm2ddl.SchemaExport.create(SchemaExport.java:293) 
at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:492) 
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1744) 
at org.hibernate.ejb.EntityManagerFactoryImpl.<init>(EntityManagerFactoryImpl.java:94) 
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:905) 
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:890) 
at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:57) 
at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:63) 
at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:47) 
at com.myapp.util.database.Database.<init>(Database.java:70) 
at com.myapp.util.database.Database.<clinit>(Database.java:38) 
at com.myapp.controller.file.UploadBacking.ajaxUpload(UploadBacking.java:89) 
at com.myapp.controller.file.UploadBacking$Proxy$_$$_WeldClientProxy.ajaxUpload(UploadBacking$Proxy$_$$_WeldClientProxy.java) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
at java.lang.reflect.Method.invoke(Method.java:597) 
at org.apache.el.parser.AstValue.invoke(AstValue.java:264) 
at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:278) 
at org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpression.java:39) 
at org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50) 
at org.apache.myfaces.view.facelets.el.ContextAwareTagMethodExpression.invoke(ContextAwareTagMethodExpression.java:96) 
at org.apache.myfaces.view.facelets.tag.jsf.core.AjaxHandler$AjaxBehaviorListenerImpl.processAjaxBehavior(AjaxHandler.java:495) 
at javax.faces.event.AjaxBehaviorEvent.processListener(AjaxBehaviorEvent.java:57) 
at javax.faces.component.behavior.BehaviorBase.broadcast(BehaviorBase.java:74) 
at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:405) 
at javax.faces.component.UICommand.broadcast(UICommand.java:103) 
at javax.faces.component.UIViewRoot._broadcastAll(UIViewRoot.java:1028) 
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:286) 
at javax.faces.component.UIViewRoot._process(UIViewRoot.java:1375) 
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:752) 
at org.apache.myfaces.lifecycle.InvokeApplicationExecutor.execute(InvokeApplicationExecutor.java:38) 
at org.apache.myfaces.lifecycle.LifecycleImpl.executePhase(LifecycleImpl.java:170) 
at org.apache.myfaces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:117) 
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:197) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.ocpsoft.rewrite.servlet.RewriteFilter.doFilter(RewriteFilter.java:183) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
at org.apache.coyote.ajp.AjpProcessor.process(AjpProcessor.java:200) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310) 
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 
at java.lang.Thread.run(Thread.java:662) 
Caused by: java.lang.NullPointerException 
at sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:507) 
at sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:476) 
at sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307) 
at java.sql.DriverManager.getDriver(DriverManager.java:253) 
at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1437) 
... 60 more 

От Database.java:

private Database() { 
    entityManagerFactory = Persistence.createEntityManagerFactory("myapp_persistence_unit"); 
} 

MyApp/META-INF/context.xml

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE Context> 

<Context> 

<Resource 
    name="jdbc/db_myapp" 
    auth="Container" 
    type="javax.sql.DataSource" 
    username="user_myapp" 
    password="##########" 
    driverClassName="com.mysql.jdbc.Driver" 
    url="jdbc:mysql://localhost:3306/db_myapp?autoReconnect=true" 
    validationQuery="select 1" 
    maxActive="15" 
    maxIdle="3" /> 

<Valve 
    className="org.apache.catalina.valves.AccessLogValve" 
    directory="logs/myapp" 
    prefix="myapp_access_" 
    suffix=".log" 
    pattern="%h %l %u %t &quot;%r&quot; %s %b" 
    resolveHosts="false" /> 

</Context> 

С WEB-INF/web.xml

<resource-ref> 
    <description>MySQL database</description> 
    <res-ref-name>jdbc/db_myapp</res-ref-name> 
    <res-type>javax.sql.DataSource</res-type> 
    <res-auth>Container</res-auth> 
</resource-ref> 

И, наконец, WEB-INF/классы/META-INF/persistence.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.0" 
    xmlns="http://java.sun.com/xml/ns/persistence" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
    http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"> 

    <persistence-unit name="myapp_persistence_unit"> 
     <properties> 
      <property name="hibernate.connection.datasource" value="java:comp/env/jdbc/db_myapp" /> 
      <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" /> 
      <property name="hibernate.current_session_context_class" value="thread" /> 
      <property name="hibernate.show_sql" value="true" /> 
      <property name="hibernate.format_sql" value="true" /> 
      <property name="hibernate.hbm2ddl.auto" value="create-drop" /> 
     </properties> 
    </persistence-unit> 

</persistence> 
+0

Использование AJP, вероятно, вообще не связано с проблемой JDBC. Я бы ожидал, что вы получите ту же самую ошибку, если вы будете напрямую подключаться к tomcat. Было бы более полезно, если бы вы опубликовали фактическую ошибку, которую вы получили, и соответствующие ошибки в журналах tomcat. –

ответ

3

Я, наконец, получил его на работу. Если вы создаете виртуальный хост в tomcat, вы должны поставить точную копию своих приложений /META-INF/context.xml в /tomcat/conf/Catalina/domain.com/ и назовите ее context.xml.default. Ну, я не знаю, всегда ли это так, но для моей настройки это было так. Так что это мои текущие конфигурационные файлы, которые делают работу:

/etc/apache2/sites-enabled/domain.com

<Virtualhost *:80> 
    ServerName domain.com 
    ServerAlias *.domain.com 

    ProxyRequests Off 
    <Proxy *> 
     Order deny,allow 
     Allow from all 
    </Proxy> 
    ProxyPass/ajp://my.server.ip:8009/ 
</Virtualhost> 

/tomcat/conf/server.xml

<Host name="domain.com"> 
    <Context path="" docBase="MyApp" /> 
    <Alias>www.domain.com</Alias> 
</Host> 

Я попробовал это после прочтения this thread на coderanch.com с 2006 года (решение авторов в последний пост). Я не изменил web.xml или context.xml, так как это не было неправильной конфигурацией элемента <Resource>. В любом случае, спасибо за ваши попытки помочь :)

0

Убедитесь, что вы имеете файл mysql-connector-j.x.y.z.jar точно в одном месте: lib каталог Tomcat. Убедитесь, что у вас нет бродячей копии в любом из ваших webapps 'WEB-INF/lib directories.

Два несвязанных советы:

  1. Не используйте autoReconnect
  2. Используйте /* ping */ SELECT 1 в качестве запроса проверки: последние версии Connector/J будет использовать легкий «пинг» вместо того, чтобы на самом деле выдающий запрос в порядке для проверки достоверности подключения
+0

Я уже дважды проверял, что у меня есть /opt/tomcat/lib/mysql-connector-java-5.1.20-bin.jar и никакого другого драйвера в WEB-INF/lib. Спасибо за другие советы, хотя :) – Jack

+0

Сообщение об ошибке «Невозможно создать драйвер JDBC класса» для URL-адреса подключения «null» всегда было результатом неправильной конфигурации элемента '' или отсутствующего/дублированного JAR-файла JDBC-библиотеки. –