BW 3.7 Setting up URL builder & Webcache
Introduction
Bedework ships with a production-ready page caching application for caching public event data feeds. Webcache is used only for data feeds and is fronted by the URL builder, a feed URL and widget generator. Webcache itself fronts Bedework, storing results pages in a file hierarchy. Result pages may appear in a variety of formats (xml, json, ics, rss, html) and may contain a single event or a list of events.
Setting up Webcache is recommend for two reasons. Like any caching system, it should improve responsiveness. Also, Webcache should protect your Bedework server from having to work so hard, which may lead to greater reliability. Webcache can be placed on another host to further protect your Bedework server
To illustrate how Webcache works in the quickstart (where it is installed next to the rest of Bedework). Let's say you'd like a json feed of the next 21 days of all public events.
You'd send this URL: http://calendar.myschool.edu/webcachev/1.0/genFeedList/21/list-json/all/all. (Don't worry about having to actually construct such a URL. That's what the URL Builder is for).
First Page Cache looks at the file location <topOfPageCache>/v1.0/genFeedList/21/list-json/all/all.json. If it finds a page there, it serves it up. Otherwise, it “translates” the URL into http://calendar.myschool.edu/feeder/listEvents.do?skinName=list-json&days=21, calls it, and then both caches the results and returns them to the user.
Note: there is currently no code to handle cache invalidation. You must expire events using a script (or other mechanism) that you create. For more details, see the Bedework wiki: http://www.bedework.org/trac/bedework/wiki/CachedFeeder/ExpiringEvents
Point Webcache at Bedework
Easier way: Edit the deployed application
- cd <qs>jboss-5.1.0.GA/server/default/bwdeploy/webcache.war
- Explode the archive, if necessary, using the jar command. If you replace the archive with the exploded war you can leave it that way. Make sure the directory is called webcache.war
- cd WEB-INF/config/environments/development.rb
- Edit the TARGET server
- (optionally) Jar up the directory and overwrite the old webcache.war archive.
Hard way: Rebuild webcache
This way is more work because you need to install the jruby environment. You'll need to install jruby, warbler, and jruby-openssl. These commands should do the trick on those flavors of linux that have apt-get. sudo jruby -s gem install warbler sudo jruby -s gem install jruby-openssl
sudo apt-get install jruby export PATH=$PATH:$JRUBY_HOME/bin sudo jruby -s gem install warbler sudo jruby -s gem install jruby-openssl
Then you can rebuild and redeploy with
./bw -buildwebcache ./bw -deploywebcache
More on the URLBuilder
The url builder includes a web form that generates Page Cache URL's and simple widgets (essentially wrapped URL's). Users specify whether they'd like a feed or a widget (paste-able code), what kind of output they're interested in, etc. Users may filter by categories and/or by a group.
The feed URL's may be XML, RSS, HTML, JSON, or ICS.
The widgets are javascript functions that process a JSON feed.
Point URL Builder at Webcache
- cd <qs>/cachedfeeder/URLandWidgetBuilder/
- edit index.html and replace the localhost references
- cd javascript/bedework
- edit listEvents.js and update calendarServer.
- edit builder.js and update urlPrefix.
Reploy the urlbuilder:
./bw -deployurlbuilder
Bedework Enterprise Calendar, version 3.7