Just to be clear, the timeout exception hits on App Engine. All is well as a java app.
On Nov 9, 8:06 am, Eyal <[email protected]> wrote: > Hi Didier, > > It takes about 8-9 seconds to return with a reply "as a java > application" for one query. I'm going to need a lot more than one > query, though, so some of my fetch requests will take much longer. But > in any case the timeout exception hits even before the 8-9 seconds, > and even when I increase the connect and read timeouts to 10 secs as > above. > > Thanks, > Eyal > > On Nov 9, 7:38 am, Didier Durand <[email protected]> wrote: > > > > > > > > > Hi Eyal, > > > Independently of App Engine, how many seconds does it take to get an > > answer to your request to Google Analytics (as given above) when you > > run is "as a Java application" ? A servlet cannot last more than 30s > > in App Engine, so knwoing your timing is important. > > But, from my experience, you should get the answer in a matter of a > > few seconds at most. > > > Let us know > > didier > > > On Nov 8, 6:32 pm, Eyal <[email protected]> wrote: > > > > Just to complete the picture here's the initialization of the > > > AnalyticsService: > > > > AnalyticsService as = new > > > AnalyticsService("gaExportAPI_acctSample_v1.0"); > > > as.setUserCredentials(CLIENT_USERNAME, CLIENT_PASS); > > > > Thanks again, > > > Eyal > > > > On Nov 8, 7:27 pm, Eyal <[email protected]> wrote: > > > > > Hi Didier, > > > > > Sure, here is an example method: > > > > > public SiteBasicData getSiteBasicData(AnalyticsService as, Site > > > > site, > > > > DateTime date) { > > > > SiteBasicData sd = new SiteBasicData(); > > > > as.setConnectTimeout(10000); > > > > as.setReadTimeout(10000); > > > > DataFeed dataFeed = null; > > > > try { > > > > DataQuery query = new DataQuery(new > > > > URL("https://www.google.com/ > > > > analytics/feeds/data")); > > > > DateTimeFormatter fmt = > > > > DateTimeFormat.forPattern("yyyy-MM- > > > > dd"); > > > > query.setStartDate(date.toString(fmt)); > > > > query.setEndDate(date.toString(fmt)); > > > > > query.setMetrics("ga:visitors,ga:visits,ga:pageviews,ga:newVisits,ga:bounce > > > > s,ga:timeOnSite"); > > > > query.setMaxResults(50); > > > > query.setIds(site.getTableID()); > > > > > dataFeed = as.getFeed(query.getUrl(), > > > > DataFeed.class); > > > > > DataEntry entry = dataFeed.getEntries().get(0); > > > > DecimalFormat dfDouble = new DecimalFormat(".##"); > > > > DecimalFormat dfZero = new DecimalFormat("#"); > > > > > int visits = > > > > Integer.parseInt(entry.stringValueOf("ga:visits")); > > > > int uniques = > > > > Integer.parseInt(entry.stringValueOf("ga:visitors")); > > > > int newVisits = > > > > Integer.parseInt(entry.stringValueOf("ga:newVisits")); > > > > int pageViews = > > > > Integer.parseInt(entry.stringValueOf("ga:pageviews")); > > > > int bounces = > > > > Integer.parseInt(entry.stringValueOf("ga:bounces")); > > > > int timeOnSite = > > > > Integer.parseInt(entry.stringValueOf("ga:timeOnSite")); > > > > > sd.setSite(site); > > > > sd.setDate(date); > > > > sd.setVisitors(visits); > > > > sd.setUniqueVisitors(uniques); > > > > sd.setNewVisits(newVisits); > > > > sd.setReturningVisits(visits-newVisits); > > > > sd.setPageViews(pageViews); > > > > sd.setUniquePageViews(getUniquePageViews(as, site, > > > > date)); > > > > sd.setBounces(bounces); > > > > sd.setTimeOnSite(timeOnSite); > > > > > } catch(Exception e) { > > > > e.printStackTrace(); > > > > } > > > > return sd; > > > > } > > > > > Then I do the simple JDO to persist the sd object. But it doesn't even > > > > get there because I get the "Timeout while fetching" exception. > > > > > Thanks! > > > > Eyal > > > > > On Nov 8, 6:33 pm, Didier Durand <[email protected]> wrote: > > > > > > Hi Eyal, > > > > > > Can you detail (i.e post code samples) on what you do with Analytics > > > > > ("I need to be able to update the application's datastore with a feed > > > > > from Analytics.") and how you want to do it. > > > > > > It's too vague as of now. > > > > > > regards > > > > > > didier > > > > > > On Nov 8, 4:41 pm, Eyal <[email protected]> wrote: > > > > > > > Hi Didier, > > > > > > > Thanks for your reply. Here's the problem, though: when I run it as > > > > > > a > > > > > > web application I'm getting a timeout error. I've already posted > > > > > > this > > > > > > issue on the Analytics dev group at (http://groups.google.com/group/ > > > > > > google-analytics-data-export-api/browse_thread/thread/ > > > > > > 3f9956a25d718b59) but so far no one responded. > > > > > > > Do you have experience integrating analytics into app engine? I'm > > > > > > sure > > > > > > it can be done but I've been trying to get it to work for 2 days now > > > > > > with absolutely no progress. If you, or anyone can help me out I'm > > > > > > sure my company will be willing to pay for this service. > > > > > > > Thanks, > > > > > > Eyal > > > > > > > On Nov 8, 5:17 pm, Didier Durand <[email protected]> wrote: > > > > > > > > Eyal, > > > > > > > > Now it's clear = you MUST run the application as a Web > > > > > > > Application to > > > > > > > be able to activate the App Engine environment with the Datastore > > > > > > > that > > > > > > > you need for JDO. > > > > > > > > Then you MUST activate the local dev env for App Engine on your > > > > > > > machine : see my previous answer with the link. > > > > > > > > If you don't do both actions above, it can not work as you wish. > > > > > > > > regards > > > > > > > didier > > > > > > > > On Nov 8, 1:39 pm, Eyal <[email protected]> wrote: > > > > > > > > > On my dev, when running "As A Java Application." If I try to > > > > > > > > run it as > > > > > > > > a Web Application I get a Timeout exception, because the > > > > > > > > Analytics > > > > > > > > feed takes too long to respond... > > > > > > > > > Thanks for looking into this, Didier! > > > > > > > > > Eyal > > > > > > > > > On Nov 8, 1:55 pm, Didier Durand <[email protected]> > > > > > > > > wrote: > > > > > > > > > > Hi Eyal, > > > > > > > > > > Where do you run your application when getting this > > > > > > > > > exception: on your > > > > > > > > > dev env or on the google infrastructure ? > > > > > > > > > regards > > > > > > > > > didier > > > > > > > > > > On Nov 8, 8:44 am, Eyal <[email protected]> wrote: > > > > > > > > > > > Thank you lp, and Didier. > > > > > > > > > > > Actually this application will need to run in production, > > > > > > > > > > and not only > > > > > > > > > > in testing. > > > > > > > > > > > I need to be able to update the application's datastore > > > > > > > > > > with a feed > > > > > > > > > > from Analytics. When I create a very simple GUI for it > > > > > > > > > > using GWT > > > > > > > > > > (basically just a submit button,) I get a timeout exception > > > > > > > > > > because > > > > > > > > > > the Analytics server takes too long to respond (it seems to > > > > > > > > > > be > > > > > > > > > > unsolvable at this point.) So I thought I'll just run it as > > > > > > > > > > a simple > > > > > > > > > > Java application -- and than I don't have the timeout > > > > > > > > > > problem and the > > > > > > > > > > Analytics feed works beautifully. > > > > > > > > > > > But then -- this problem. When I create objects from the > > > > > > > > > > Analytics > > > > > > > > > > feed, and try to insert them into the datastore, I get the > > > > > > > > > > exception > > > > > > > > > > above. > > > > > > > > > > > What am I missing? > > > > > > > > > > > You help is greatly appreciated! > > > > > > > > > > > Eyal > > > > > > > > > > > On Nov 8, 6:21 am, Didier Durand <[email protected]> > > > > > > > > > > wrote: > > > > > > > > > > > > Hi, > > > > > > > > > > > > This comes when you are trying to run code within Eclipse > > > > > > > > > > > without > > > > > > > > > > > having starting properly the local runtime of App Engine: > > > > > > > > > > > seehttp://code.google.com/appengine/docs/java/tools/localunittesting.html > > > > > > > > > > > (parag Datastore tests) > > > > > > > > > > > > I can also supply my Junit init code when needed > > > > > > > > > > > > regards > > > > > > > > > > > didier > > > > > > > > > > > > On Nov 7, 5:45 pm, Eyal <[email protected]> wrote: > > > > > > > > > > > > > Hi all, > > > > > > > > > > > > > I'm trying to use JDO in an app engine application on > > > > > > > > > > > > Eclipse. When I > > > > > > > > > > > > use a web interface I'm able to make it work just fine. > > > > > > > > > > > > But I need to > > > > > > > > > > > > be able to run it as a java application and when I try > > > > > > > > > > > > I get the > > > > > > > > > > > > following exception: > > > > > > > > > > > > > java.lang.NullPointerException: No API environment is > > > > > > > > > > > > registered for > > > > > > > > > > > > this thread. > > > > > > > > > > > > at > > > > > > > > > > > > com.google.appengine.api.datastore.DatastoreApiHelper.getCurrentAppId(Datas > > > > > > > > > > > > toreApiHelper.java: > > > > > > > > > > > > 108) > > > > > > > > > > > > at > > > > > > > > > > > > com.google.appengine.api.datastore.DatastoreApiHelper.getCurrentAppIdNamesp > > > > > > > > > > > > ace(DatastoreApiHelper.java: > > > > > > > > > > > > 118) > > > > > > > > > > > > at > > > > > > > > > > > > com.google.appengine.api.datastore.Query.<init>(Query.java:87) > > > > > > > > > > > > at > > > > > > > > > > > > org.datanucleus.store.appengine.query.DatastoreQuery.validate(DatastoreQuer > > > > > > > > > > > > y.java: > > > > > > > > > > > > 649) > > > > > > > > > > > > at > > > > > > > > > > > > org.datanucleus.store.appengine.query.DatastoreQuery.performExecute(Datasto > > > > > > > > > > > > reQuery.java: > > > > > > > > > > > > 215) > > > > > > > > > > > > at > > ... > > read more » -- You received this message because you are subscribed to the Google Groups "Google App Engine for Java" group. To post to this group, send email to [email protected]. To unsubscribe from this group, send email to [email protected]. For more options, visit this group at http://groups.google.com/group/google-appengine-java?hl=en.
