Skip to content

Riak-Cpp v0.2: More Professional

Latest
Compare
Choose a tag to compare
@ajtack ajtack released this 29 Jul 21:17

Riak-Cpp now has Logging (#16)

The previous release required deep understanding of the library in order to address any problems. A good server-side tool has good logging – now Riak-Cpp has it as well. Logging statements were added throughout the code using boost::log, verified by hand to provide a useful understanding of request progress.

The boost::log library is a little bit new to the scene, so it's probably even unlikely that you're using it. Fortunately, by implementing your own sink (admittedly a bit of work) you can pipe the output of Riak-Cpp's logging wherever you need it. Furthermore, every log line produced is tagged with the request to which it applies, the timestamp, and a severity. The output of the unit tests (see test/units/main.cxx) is a good example of what kind of formatting is possible.

(test) [get_with_siblings]: Beginning test multiple_sibling_resolutions_are_correctly_handled ...
(test) [get_with_siblings]: ==========================================================
---- (riak/core) 2014-06-23 12:37:17.067280     INFO [r:19558c67-be15-4efd-be7f-9cd815c140fd]: GET 'a' / 'document'
---- (riak/core) 2014-06-23 12:37:17.067473    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Parsing server response ...
---- (riak/core) 2014-06-23 12:37:17.067536    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Found 2 siblings; attempting resolution.
---- (riak/core) 2014-06-23 12:37:17.067598    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Resolved value has vector clock 'blah blah blah'. Transmitting ...
---- (riak/core) 2014-06-23 12:37:17.067817    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Processing result of sibling resolution ...
---- (riak/core) 2014-06-23 12:37:17.067874    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Value collided again upon resolution. Fetching new siblings ...
---- (riak/core) 2014-06-23 12:37:17.068032    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Parsing server response ...
---- (riak/core) 2014-06-23 12:37:17.068094    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Found 2 siblings; attempting resolution.
---- (riak/core) 2014-06-23 12:37:17.068156    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Resolved value has vector clock 'blah blah blah'. Transmitting ...
---- (riak/core) 2014-06-23 12:37:17.068400    TRACE [r:19558c67-be15-4efd-be7f-9cd815c140fd]: Processing result of sibling resolution ...
---- (riak/core) 2014-06-23 12:37:17.068459     INFO [r:19558c67-be15-4efd-be7f-9cd815c140fd]: GET successful after applying sibling resolution.
(test) [get_with_siblings]: ----------------------------------------------------------
(test) [get_with_siblings]: Test Complete!

If you're on a legacy compiler or using an older version of boost, this feature is unavailable for the time-being. You can exclude it from your build of Riak-cpp by applying the --with-logging=no option to scons.

Minor Changes

These things were fixed along the way by the author and by the community.

  1. Less Paranoid Networking The Single Serial Socket that Riak-Cpp provides by default is still not a tremendously effective socket pool, but it will now nevertheless function faster. Unless a request terminates in exception, the connection will be re-used instead of recycled.
  2. Fixes for Deadlocks and Crashes thanks to the contributions of @DeanoC and @mcobzarenco.

Compatibility

This release is compatible with:

  • gcc 4.4, 4.6, 4.8
  • clang 3.3, 3.4
  • Boost v1.54+ (Boost v1.46+ when compiled without logging)