| * Vendor: update gitea.com/macaron/session to a177a270 * make vendor * Vendor: update gitea.com/macaron/macaron to 0db5d458 * make vendor * Vendor: update gitea.com/macaron/cache to 905232fb * make vendor * Vendor: update gitea.com/macaron/i18n to 4ca3dd0c * make vendor * Vendor: update gitea.com/macaron/gzip to efa5e847 * make vendor * Vendor: update gitea.com/macaron/captcha to e8597820 * make vendor | ||
|---|---|---|
| .. | ||
| client | ||
| .gitignore | ||
| LICENSE | ||
| README.markdown | ||
| flexibleFraming.go | ||
| mc_constants.go | ||
| mc_req.go | ||
| mc_res.go | ||
| tap.go | ||
		
			
				
				README.markdown
			
		
		
			
			
		
	
	gomemcached
This is a memcached binary protocol toolkit in go.
It provides client and server functionality as well as a little sample server showing how I might make a server if I valued purity over performance.
Server Design
 
The basic design can be seen in gocache.  A storage
server is run as a goroutine that receives a MCRequest on
a channel, and then issues an MCResponse to a channel contained
within the request.
Each connection is a separate goroutine, of course, and is responsible
for all IO for that connection until the connection drops or the
dataServer decides it's stupid and sends a fatal response back over
the channel.
There is currently no work at all in making the thing perform (there are specific areas I know need work). This is just my attempt to learn the language somewhat.