我正在使用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中将它们连接在一起