解析云代码未执行指定任务,并且未创建日志

时间:2019-03-22 12:02:58

标签: docker parse-platform parse-javascript-sdk parse-cloud

我的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);
    })

  }
);

1 个答案:

答案 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

这解决了问题