Google App Engine数据存储区不在本地运行

时间:2015-02-06 20:48:00

标签: java google-app-engine

我已将一个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>

日志文件 Log File

3 个答案:

答案 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>