我的afterSave云代码应在每次保存后运行,但是我看不到它执行了任务。也没有将调试信息写入本地的“ temp.txt”文件
我的解析服务器正在docker容器上运行(可能是相关的) 在 / parse-server / cloud 中创建main.js之后,我做了一个干净的 docker run (以启动解析服务器) >子文件夹,但仍然看不到任何内容
我如何调试此云代码问题?
我的main.js内容:
Parse.Cloud.afterSave("Post", (request) => {
var fs = require("fs");
const image = request.object.get("image").url();
const detail = request.object.get("detail");
const geo = request.object.get("geo");
const itemId = request.object.get("objectId");
fs.writeFileSync('./temp.txt', request, function(err, data) {
if (err) console.log(err);
});
console.log(detail);
console.log(image);
console.log(geo);
console.log('========');
var data =detail+" "+image+" "+geo+" "+request;
fs.appendFileSync("./temp.txt", data, function(err, data) {
if (err) console.log(err);
console.log("Successfully Written to File.");
});
var postRequest = require('request');
postRequest({
method: 'POST',
preambleCRLF: true,
postambleCRLF: true,
json: true,
uri: 'https://graph.facebook.com/1111/feed?access_token=sometoken',
body:
{
message: detail,
link: image
}
},
function (error, response, body) {
if (error) {
return console.error('upload failed:', error);
console.log('statusCode:', response && response.statusCode);
fs.appendFileSync("temp.txt", response+" "+ response.statusCode
,function(err, data) {
if (err) console.log(err);
});
}
console.log('Upload successful! Server responded with:', body);
})
}
);
答案 0 :(得分:1)
在启动 parse Docker容器时(例如,使用“ docker run”),我们还必须将“ 绝对路径传递给我们的云代码main.js文件”。 (包括main.js)
例如:
sudo docker run --name parse --network=test --appId <app-id> --masterKey <mater-key>--publicServerURL https://my-url.com/parse --databaseURI mongodb://mongo:port/mongo --cloud /parse-server/<cloudpath>/main.js
此处“ docker run ”命令中缺少的开关是:
-cloud /parse-server/cloudpath/main.js
这解决了问题