我已将一个Java项目部署到Google App Engine,并且数据存储无法像在本地那样工作。该项目将产生一个包含各种新闻摘要的网页。这些文章摘自数据存储区。数据存储区通过cron作业和Java Servlet每30分钟更新一次新文章。至少这是本地发生的情况。实时部署后,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>
日志文件
最佳答案
我没有看到Successfully updated database
日志条目,这可能意味着该servlet从未执行-否则您会看到一些错误消息。确保将其在web.xml中正确映射到此URL。