我已将一个Java项目部署到Google App Engine,并且数据存储区不像本地一样工作。该项目生成一个网页,其中包含各种新闻文章的摘要。这些文章来自数据存储区。数据存储区每30分钟通过一个cron作业和Java Servlet更新新文章。至少这是本地发生的事情。实时部署时,cron作业会根据日志成功运行,但数据存储区中没有条目。有没有人遇到类似的问题并有解决方案?
代码
@SuppressWarnings("serial")
public class CronServlet extends HttpServlet {
private static final Logger log = Logger.getLogger(CronServlet.class.getName());
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
try {
ArrayList<String> feeds = new ArrayList<String>();
feeds.add("http://feeds.reuters.com/reuters/technologyNews");
feeds.add("http://feeds.reuters.com/reuters/companyNews");
RunTagger tagger = new RunTagger();
tagger.loadRssStreams(feeds.toArray(new String[feeds.size()]));
ArrayList<Story> articles = tagger.tagArticles();
uploadArticles(articles);
log.info("Succesfully updated database");
} catch (Exception e) {
log.error("Failed to update database.");
e.printStackTrace();
}
}
private void uploadArticles(ArrayList<Story> articles) {
DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
for(Story article : articles){
String url = article.getUrl();
String headline = article.getHeadline();
String summary = article.getSummary();
String tags = article.getTags().toString();
String feed = article.getFeed();
String image = article.getImage();
DateFormat format = new SimpleDateFormat("EEE, dd MMM yyyy HH:mm:ss z", Locale.ENGLISH);
Date date;
try {
date = format.parse(article.getDate());
} catch (ParseException e) {
date = new Date();
e.printStackTrace();
}
Key k = KeyFactory.createKey("Articles", url+feed);
Entity entity = new Entity("Article", k);
entity.setProperty("url", url);
entity.setProperty("headline", headline);
entity.setProperty("summary", summary);
entity.setProperty("tags", tags);
entity.setProperty("feed", feed);
entity.setProperty("image", image);
entity.setProperty("date", date);
datastore.put(entity);
}
}
}
Cron Job
<?xml version="1.0" encoding="UTF-8"?>
<cronentries>
<cron>
<url>/cron/mycronjob</url>
<description>Update DB</description>
<schedule>every 1 hours</schedule>
</cron>
</cronentries>
日志文件
答案 0 :(得分:1)
我没有看到Successfully updated database
日志条目,这可能意味着这个servlet从未执行过 - 否则你会看到一些错误消息。确保它在web.xml中正确映射到此URL。
答案 1 :(得分:0)
猜测一下:如果您在上传之前清理了项目,则可能会破坏DataStore索引配置信息,如here所述。
如果是这种情况,在本地运行您的devserver并执行所有相关的DataStore操作,然后再次上传应用程序(不先清除)应该可以解决您的问题。
答案 2 :(得分:0)
1)计划任务可以访问仅限管理员的URL。
<security-constraint>
<web-resource-collection>
<web-resource-name>cron</web-resource-name>
<url-pattern>/cron</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>admin</role-name>
</auth-constraint>
</security-constraint>