我正在尝试获取Rackspace中特定“堆栈”的“服务器”列表。我必须对Stack资源进行一些处理以获取服务器列表,因为某些服务器位于资源组(嵌套)中。我通过异步调用逐个获取每个服务器。如何将它们捆绑在一起并一次发送给客户端? 以下是代码:
app.js
function setClient(credentials)
{
var client = pkgcloud.orchestration.createClient({
provider: 'rackspace',
username: credentials.uname,
apiKey: credentials.key,
region: 'HKG'
});
return client;
}
app.io.route('ready', function(req) {
var client = setClient(req.session.credentials);
client.getStacks(function (err, stacks) {
if (err) {
req.io.emit("error", { error: err.result.error.message });
return;
}
if (stacks.length > 0) {
var stack = stacks[0].name;
getSer(stack, client, req, 'init');
}
req.io.emit("showStacks", { stacks: stacks });
});
});
app.io.route('create_stack', function(req) {
var stack = req.data.stack_name;
var tmpl = req.data.content;
var client = setClient(req.session.credentials);
client.createStack({
name: stack,
timeout: 60,
template: tmpl // Heat template
}, handle(req));
});
function handle(req) {
return function handle(err, stack)
{
var client = setClient(req.session.credentials);
if (err) {
req.io.emit("error", { error: err.result.error.message });
console.dir(err.result.error.message);
return;
}
client.getStacks(function (err, stacks) {
req.io.emit("showStacks", { stacks: stacks });
});
req.io.emit("status", {status: 'Stack created'});
// Wait for status: CREATE_COMPLETE on our stack, and then callback
stack.setWait({ status: 'CREATE_COMPLETE' }, 5000, function (err) {
if (err) {
req.io.emit("error", { error: err.result.error.message });
console.dir(err);
return;
}
client.getStacks(function (err, stacks) {
req.io.emit("showStacks", { stacks: stacks });
});
client.getStack(stack, function (err, stack) {
if (err) {
req.io.emit("error", { error: err.result.error.message });
console.dir(err.result.error.message);
return;
}
req.io.emit("showStack", { stack: stack });
});
getSer(stack, client, req, 'create');
});
}
}
function getSer(stack, client, req, mode)
{
client.getResources(stack, function(err, resources) {
if (err) {
console.dir(err);
req.io.emit("error", { error: err.result.error.message });
return;
}
resources.forEach(function (resource) {
var nestedlink = '';
var nested = false;
if (resource.links != undefined) {
resource.links.forEach(function (link) {
if (link.rel == "nested") {
nestedlink = link.href;
nested = true;
}
});
}
if (nested) {
var stack_name = nestedlink.substr(nestedlink.indexOf('stacks/')+7, nestedlink.lastIndexOf('/'));
getSer(stack_name, client, req, mode);
} else {
var serId = resource.physicalResourceId;
var ser = serClient(req.session.credentials);
ser.getServer(serId, function (err, server) {
if (mode == 'init')
req.io.emit("showServer", { server: server});
else if (mode == 'create')
req.io.emit("stackCreate", { server: server});
});
}
});
});
}
实际上,问题是pkgcloud有一个方法'getResources',它给出了堆栈名称返回的资源。从中我获得服务器的'physical_resource_id'(server_id),该服务器不在一个组中,但是通过'OS :: Heat :: ResourceGroup'创建的服务器可以做一些额外的工作,因为资源列表只有一个'嵌套的'链接。所以我从嵌套的“链接”中获取stack_name并获取其服务器标识var stack_name = nestedlink.substr(nestedlink.indexOf('stacks/')+7, nestedlink.lastIndexOf('/'));
。如果pkgcloud有一个类似于堆栈名称的东西它将返回其中的服务器列表,那么生活将变得容易。
答案 0 :(得分:2)
我在评论中提到的问题(https://github.com/pkgcloud/pkgcloud/issues/410)现已修复。使用该修复程序,您应该能够请求堆栈的所有资源列表,包括嵌套资源。只需在您的代码中执行此操作:
client.getResources(stack, { nestedDepth: XXX }, function(err, resources) {
其中XXX
是足够的嵌套深度,具体取决于您的堆栈。
而不是:
client.getResources(stack, function(err, resources) {
pkgcloud的修复程序将包含在下一个正式版本中。这可能在几周或几个月内无法使用,因此如果您需要立即下载此修补程序,可以使用以下命令执行此操作:
npm install https://github.com/pkgcloud/pkgcloud/tarball/master
或者,您可以修改项目pkgcloud
中的package.json
依赖项,如下所示:
"pkgcloud": "git://github.com/pkgcloud/pkgcloud.git"