Javascript 如何将数据从df~提取到我的网站上?
我正在创建一个饼图,显示我的linux设备上有多少可用/使用的磁盘空间。但是,我不确定如何将数据解析到microservice url上。非常感谢您的帮助 以下是我目前的情况: 路由器:Javascript 如何将数据从df~提取到我的网站上?,javascript,node.js,ajax,linux,Javascript,Node.js,Ajax,Linux,我正在创建一个饼图,显示我的linux设备上有多少可用/使用的磁盘空间。但是,我不确定如何将数据解析到microservice url上。非常感谢您的帮助 以下是我目前的情况: 路由器: router.route('/linux_disk').get(disk.get_linux_disk) 控制器: function get_linux_disk(req, res, next) { try { var cmd = `df ~`; exec(cmd) rows
router.route('/linux_disk').get(disk.get_linux_disk)
控制器:
function get_linux_disk(req, res, next) {
try {
var cmd = `df ~`;
exec(cmd)
rows = [];
rows.push({"Command": cmd});
if (rows.length >= 1) {
res.status(200).json(rows);
} else {
res.status(404).end();
}
} catch (err) {
next(err);
}
}
您可以尝试下面的方法,我们为df创建的每个条目创建一个row对象 命令创建。完成此操作后,您应该能够从以下内容创建饼图:
const { exec } = require('child_process');
const { promisify } = require('util');
const execPromise = promisify(exec);
async function get_linux_disk(req, res, next) {
try {
const result = await execPromise(`df ~`)
const lines = result.stdout.split("\n");
const keys = lines[0].split(/\s+/ig);
// Skip the header row when assigning objects..
const rows = lines.slice(1).map(line => {
// Parse each line..
const values = line.split(/\s+/ig);
return keys.reduce((o, k, index) => {
o[k] = values[index];
return o;
}, {})
});
res.status(200).json(rows);
} catch (err) {
res.status(500).send(err.message);
}
}
生成的JSON看起来有点像这样:
[
{
"Filesystem": "/dev/sda1",
"1K-blocks": "10253588",
"Used": "7971516",
"Available": "1741504",
"Use%": "83%",
"Mounted": "/"
}
]
谢谢你的回复,特里。不幸的是,我收到了一条“execPromise未定义错误消息”哦,我很抱歉,我在代码中忽略了这一点。。我马上更新!