Blog Pages

go-codec: Primer and How To Guide
By Ugorji Nwoke   Sun, 21 Dec 2014 15:00:00 -0700   /blog   technology go-codec
Below, we will walk you through using the go-codec library for your serialization needs. go-codec is a high performance and feature rich library that provides idiomatic encoding and decoding support for the following formats:
Code Generation using go-codec - for 2-20X performance improvement
By Ugorji Nwoke   Thu, 18 Dec 2014 08:00:00 -0700   /blog   technology go-codec
go-codec supports compile-time generation of encoders and decoders for named types, which does not incur the overhead of reflection in the typical case, giving 2X-20X performance improvement over the idiomatic runtime introspection mode. Idiomatic encoding and decoding types within go typically relies on the reflection capabilities of the go runtime. This affords flexible performance without the need for a pre-compilation step; the go types contain all the information needed and the runtime exposes the full types via reflection. However, introspecting the runtime to get this information has a noticeable overhead, which can be eliminated by a pre-compilation/code-generation step.
How go-codec achieves its stellar performance
By Ugorji Nwoke   Wed, 17 Dec 2014 12:00:00 -0700   /blog   technology go-codec
They say premature optimization is the root of all evil. I say some layers of the stack MUST be optimal. The layer that does marshalling of data MUST be optimal. go-codec library supports code generation OR runtime reflection for its encoding and decoding. We will mostly discuss the runtime reflection in this article. It is easiest to compare this to other libraries.
Benchmarks!!! Serialization in Go!!!
By Ugorji Nwoke   Tue, 16 Dec 2014 18:00:00 -0700   /blog   technology go-codec
Let’s have some fun with some numbers. In the serialization in go article , we discussed a number of types of encoding formats and their libraries in go.
Yet Another JSON Library? But Why?
By Ugorji Nwoke   Tue, 16 Dec 2014 12:00:00 -0700   /blog   technology go-codec
And let me answer … The encoding/json library bundled with the standard library is a GREAT piece of software.
go-codec supports cbor? What is a CBOR?
By Ugorji Nwoke   Mon, 15 Dec 2014 18:00:00 -0700   /blog   technology go-codec
Glad you asked. cbor stands for: Concise Binary Object Representation . cbor is a relatively new binary format which builds upon the simplicity of messagepack and json. It is currently being targeted agressively in the internet-of-things space. It is a kick-ass format.
Re-Introducing Go Codec Library: msgpack, binc, cbor, json and more formats
By Ugorji Nwoke   Mon, 15 Dec 2014 16:00:00 -0700   /blog   technology go-codec
The go-codec library is a High Performance , Feature-Rich and Idiomatic Go encoding/decoding library for binc , msgpack , cbor , json , with runtime reflection or compile-time code generation support. View Source at . About a year ago, we announced go-codec as a library for msgpack. The go-codec library has come a long way since then.
Serialization In Go
By Ugorji Nwoke   Sun, 14 Dec 2014 15:00:00 -0700   /blog   technology go-codec
For data transfer between systems to occur, the sending side must encode the data structures into a stream of bytes, and the receiving side must efficiently decode the stream of bytes into a representative data structure. There is efficient and extensive support for this when using go as your language runtime. The standard library provides support for the following general-purpose encodings:
Update on Binc data interchange format
By Ugorji Nwoke   Wed, 05 Jun 2013 08:30:00 -0700   /blog   geek technology
We describe enhancements to the Binc data interchange format since its public release. Also, the Binc spec is now stored on github ( ). This allows us track revisions and affords better collaboration.
Announcing Go codec library for msgpack and binc
By Ugorji Nwoke   Thu, 30 May 2013 10:54:00 -0700   /blog   golang technology
Go codec is a High Performance and Feature-Rich Idiomatic Go Library providing encode/decode support for different serialization formats, including msgpack and binc . Get it while it’s hot at This follows on the public release of Binc , a lightweight, compact, limitless, schema-free, precise, binary, high-performance, feature-rich, language-independent, multi-domain, extensible, data interchange format for structured data.
Announcing Binc data interchange format
By Ugorji Nwoke   Thu, 30 May 2013 10:49:00 -0700   /blog   technology
Binc is a lightweight, compact, limitless, schema-free, precise, binary, high-performance, feature-rich, language-independent, multi-domain, extensible, data interchange format for structured data. See the format documented at
Announcing go-msgpack
By Ugorji Nwoke   Wed, 11 Apr 2012 10:46:00 -0700   /blog   golang technology
Announcing go-msgpack, a rich msgpack codec for Go. Supports encoding/decoding to msgpack binary format, and use for net/rpc communication.
Streamlining Go App Engine Runtime
By Ugorji Nwoke   Fri, 16 Mar 2012 13:44:00 -0700   /blog   appengine geek golang technology
With App Engine, the Go Runtime is a mashup of Python Runtime, Go SDK and glue code (Go and Python). This poses some challenges during development, which this proposal addresses with solutions. Current setup of Go Runtime
Trayvon Martin: Unarmed black kid shot for walking in wrong neighbourhood
By Ugorji Nwoke   Wed, 14 Mar 2012 07:55:00 -0700   /blog   social
Trayvon Martin: Unarmed black kid shot for walking in wrong neighbourhood. His killer must be prosecuted. UPDATE: Mar 19, 2011
Dev Tool for GO AppEngine
By Ugorji Nwoke   Sat, 03 Dec 2011 16:54:00 -0800   /blog   appengine geek golang technology
Development Tool for go app engine development, that presents an easier to use wrapper for App Engine development with GO Runtime, bypassing some pitfalls caused by integration with the Python SDK. The source is available online, and the motivation for building this is described below. What irks one person may not irk the other, so your utility of this tool may differ from mine. For me, the utility is really high:
GO App Engine datastore operations design
By Ugorji Nwoke   Wed, 16 Nov 2011 10:06:00 -0800   /blog   appengine
GO App Engine datastore.Load/Save uses goroutines and channels to iterate over datastore entity properties, causing overhead. Background With GAE 1.6.0, Support for Indexed Properties, Hooks, etc was introduced with a nice, elegant design using a PropertyLoadSaver interface that uses channels (as an iterator).
Testing Go App Engine Applications natively
By Ugorji Nwoke   Mon, 14 Nov 2011 06:05:00 -0800   /blog   appengine geek golang technology
With changes to allow concurrent requests in Go App Engine, Testing support follows naturally and natively. Following support for concurrent requests described previously, Testing support is as easy as ensuring the following is called one time before your test is run. I have tested it and it works flawlessly.
Enable Concurrent Requests in Go App Engine SDK
By Ugorji Nwoke   Mon, 14 Nov 2011 03:53:00 -0800   /blog   appengine geek golang technology
This details how to enable concurrent requests in the Go App Engine SDK. UPDATES: Nov 15: Added that python sdk is currently not threadsafe. This shows how to make GO side threadsafe, and still test concurrency in your application (even though only 1 API request is processed at a time).
Datastore Enhancement for GO Language Runtime in Google App Engine
By Ugorji Nwoke   Tue, 27 Sep 2011 17:15:00 -0700   /blog   appengine geek golang technology
This attempts to make a case for datastore enhancements in the GO Language Runtime of App Engine. Quoting from
Objective Gripes with New Google App Engine Pricing
By Ugorji Nwoke   Thu, 08 Sep 2011 06:29:00 -0700   /blog   appengine geek technology
This attempts to objectively address areas where the new App Engine pricing may not not fair, and what Google may do to alleviate these concerns. Disclaimer I am an unabashed fan of Google App Engine, and have been for over three years. I don’t think there’s anything else on the market that comes close. I think it is a fine platform for any applications, from simpler small ones to large complex ones.
Google App Engine New Pricing Sucks
By Ugorji Nwoke   Thu, 01 Sep 2011 04:25:00 -0700   /blog   appengine geek technology
Google has done a major disservice to its cult of developers by changing the pricing terms of App Engine ridiculously while giving developers short notice to react. In doing so, Google may have done severe damage to their brand and the trust that developers put in them. Google released app engine in 2008 on a set of premises:
Android Conversation Backup
By Ugorji Nwoke   Wed, 23 Mar 2011 19:29:00 -0700   /blog   android geek
This is a post for all my android users out there. With Android, Google guarantees us that if we ever lose our android phones, we can just grab a new one. Once we sign in with our google account, it automatically syncs our emails, contacts, and applications (including the settings we have for those applications which support this).
The meaning of my name
By Ugorji Nwoke   Thu, 03 Mar 2011 08:27:00 -0800   /blog   musings
A while back, I was having an email discussing with one of the men I respect most in this world. All my emails are signed as: He saw this and responded as below. His description aptly describes what my name means and signifies, better than I have ever done myself. More importantly though, it helped me realize that I need to do more, and really achieve my potential. My prayer is that I live up to my name.
Trying to describe my job at Oracle
By Ugorji Nwoke   Thu, 03 Mar 2011 08:17:00 -0800   /blog   rant
I’ve always had a hard time describing what I did at a software company to folks outside software (lawyers, doctors, basketball players, club hoppers, etc). Part of the reason is that I am pretty private and ridiculously modest and overly calculated. However, I was having one of my frustrating days with technology, and someone asked me again to explain, and I just let … said it. Reading the thread later, I am pretty impressed with the description. So I figured I would share. Enjoy.

Subscribe: Technology
© Ugorji Nwoke