7月 152012
<< 担々麺 || HerokuのSinatraにバックグラウンドワーカーを詰め込んで節約 >>
memjsというmemcached clientにpull requestが取り込まれた。
HerokuではアドオンのMemcacheかMemcachierを使う事になるが、両方共SASLによる認証が入っている。
SASL認証を使うにはバイナリプロトコルが使えるmemcache clientが必要なのだが、node.jsにはバイナリ使えるのmemjsしか無かったのでとりあえず試したけど認証なしでしか動かなかった。
この時にmemcacheとmemcachierのアドオンを入れたり消したりしてたらmemcachierの中の人からメールが来て、相談してたらOpCode 0x21の時にKeyが必要なところが入ってなかったのを見つけて、修正したらうまく動いたのでpull requestして取り込まれた。
これでNodeでHerokuのMemcacheが使えるようになりました。
memjsの使い方はこんなの。
まだREADMEがしっかり書かれていないのでflagとかが何だかわからないけど、テストコード見たらだいたい使い方もわかってbugfixもできた。
// npm install memjs
var memjs = require('memjs');
var cache = new memjs.Client.create(null, {expires: 10}); // 10sec expire
// set value
cache.set('name', 'shokai', function(err, val){
if(err) console.error('set error');
else{
// get value
cache.get('name', function(err, val, flag){
if(err) console.error('get error');
else console.log('get : '+ (val ? val.toString() : null));
});
// wait 11 sec, then get value
setTimeout(function(){
console.log('wait 3 sec');
cache.get('name', function(err, val, flag){
if(err) console.error('get error');
else console.log('get : '+ (val ? val.toString() : null));
});
}, 11000);
}
});
2バイト以上の文字はencodeURI/decodeURIを通して使う。