9

我尝试从 redis db 获取信息并将其作为响应的主体返回给用户。首先,这是一个失败的代码:

var redis = require("redis"),
    koa = require("koa");

var app = koa(),
    port = process.argv[2] || 3000,
    client = redis.createClient();

app.use(function* (next) {

    client.get("test", function (err, res) {
        this.body = res;
    });

    yield next;
});

app.listen(port);
console.log("listen on port " + port)

肯定是因为 yield 调用在调用回调之前结束。

然后这是一个成功的代码:

function askRedit (callback) {
    client.get("test", callback);
}

app.use(function* (next) {
    this.body = yield askRedit;
    yield next;
});

但我显然误解了为什么第二个有效。in的行为与yieldin的行为相同吗?yield askRedityield next

编辑:我刚刚看到一个似乎可以回答的页面:https ://github.com/visionmedia/co/blob/master/examples/redis.js

所以现在我将尝试理解这些神秘的产量..这是用异步调用做同步事情的一种方式吗?

4

2 回答 2

8

这是正确的解决方案:

"Use strict";

var redis = require("redis"),
    coRedis = require("co-redis"),
    koa = require("koa");

var app = koa(),
    port = process.argv[2] || 3000,
    db  = redis.createClient(),
    dbCo = coRedis(db);

app.use(function* () {
    yield dbCo.set("test", 42);
    this.body = yield dbCo.get("test");
});


app.listen(port);
console.log("listen on port " + port)

这些链接有帮助:

https://github.com/koajs/workshop/tree/master/01-co

http://www.jongleberry.com/koa.html

当然还有“co-redis”

感谢我自己!

于 2014-08-26T08:51:27.800 回答
0

您还可以使用:

var koa = require('koa');
var app = koa();
var redis = require('then-redis');

var db = redis.createClient('tcp://redis:6379');

db.set('my-key', 0);

app.use(function *(){
    db.incrby('my-key', 5);
    this.body = yield db.get('my-key');
});

app.listen(9000);
于 2015-10-27T15:29:29.403 回答