Google App Engine上的Jersey 2.2.0。错误404. jersey init。虽然在本地工作

时间:2014-04-17 04:24:57

标签: google-app-engine jersey

我正在使用jersey 2.2.0 jar将我的应用部署到Google应用引擎上。我一直在本地开发和运行,它在本地运行/测试期间运行良好。

我部署到谷歌应用引擎,我开始得到所有资源的错误:404错误。检查谷歌日志,在第一次请求时它会吐出以下内容

  

org.glassfish.jersey.server.ApplicationHandler初始化:启动Jersey应用程序,版本泽西:2.7 2014-03-12 18:11:31 ...

jersey servlet吐出以下内容

  

I 09:27:38.889 org.glassfish.jersey.filter.LoggingFilter log:1 *服务器已收到线程上的请求请求EE25C261   获取http://xxxx.appspot.com/service/users/test   接受:text / html,application / xhtml + xml,application / xml; q = 0.9,image / webp, / ; q = 0.8   Accept-Language:en-US,en; q = 0.8   主持人:xxxxx.appspot.com   用户代理:Mozilla / 5.0(Macintosh; Intel Mac OS X 10_9_2)AppleWebKit / 537.36(KHTML,与Gecko一样)Chrome / 33.0.1750.152 Safari / 537.36   X-AppEngine-City:班加罗尔   X-AppEngine-CityLatLong:12.971599,77.594563   X-AppEngine-Country:IN   X-AppEngine-Region:ka

然后吐出未找到的资源

  

I 09:41:15.094 org.glassfish.jersey.filter.LoggingFilter log:3 *服务器响应线程上的响应请求9826AB68    < 404

它还增加了一行暗示

  

I 09:27:39.180此请求导致为您的应用程序启动了一个新进程,从而导致您的应用程序代码首次加载。因此,此请求可能需要更长的时间,并且使用的CPU比典型的应用程序请求更多。

现在,所有这些都适用于我的本地测试,但在部署到Google App Engine时只是一个问题。

这是我的web.xml

<?xml version="1.0" encoding="utf-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
  <servlet>
      <servlet-name>Jersey Web Application</servlet-name>
      <servlet-class>
        org.glassfish.jersey.servlet.ServletContainer
      </servlet-class>
      <init-param>
          <param-name>jersey.config.server.provider.packages</param-name>
<!--           Enter your Jersey resources to speed up initial Jersey loading
          You can separate the java packages using , -->
          <param-value>com.poolE.web.rest</param-value>
        </init-param>
        <init-param>
            <param-name>jersey.config.server.provider.classnames</param-name>
            <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
      <servlet-name>Jersey Web Application</servlet-name>
      <url-pattern>/service/*</url-pattern>
    </servlet-mapping>
    <system-properties>
        <property name="java.util.logging.config.file" value="WEB-INF/logging.properties" />
    </system-properties>
</web-app>

我的球衣类是

import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

import com.poole.web.jpa.EMFService;
import com.poole.web.jpa.Users;
import com.poole.web.jpa.model.User;

@Path("/users/")
public class UsersResource {

    private static final Logger log = Logger.getLogger(UsersResource.class.getName());

    @GET
    @Produces("application/json")
    @Path("test")
    public String info() {
        log.info("comes into test");
        return "Hello Jersey on Google App Engine";
    }

}

任何帮助将不胜感激。我陷入了这个令人沮丧的问题,只是在GAE中将它们连接在一起

0 个答案:

没有答案