使用节点库

时间:2018-05-16 12:48:32

标签: javascript node.js dialogflow

我试图使用节点库调用dialogflow的v2 api的detectIntent()。但是,我的响应时间延迟平均为1.5秒,与v1 api相比太快了。这会影响聊天机器人的用户体验。 图书馆: - https://github.com/dialogflow/dialogflow-nodejs-client-v2

用于测试从库的入门示例采用的节点库的 detectIntent() api的代码片段,它记录了api响应时间。

// You can find your project ID in your Dialogflow agent settings
const projectId = '<project-id-here>';
const sessionId = 'fa2d5904-a751-40e0-a878-d622fa8d65d9';
const query = 'hi';
const languageCode = 'en-US';
const credentials = {
  client_email: '<client-email-here>',
  private_key:
    '<private-key-here>',
};
// Instantiate a DialogFlow client.
const dialogflow = require('dialogflow');

const sessionClient = new dialogflow.SessionsClient({
  projectId,
  credentials,
});

// Define session path
const sessionPath = sessionClient.sessionPath(projectId, sessionId);

// The text query request.
const request = {
  session: sessionPath,
  queryInput: {
    text: {
      text: query,
      languageCode,
    },
  },
};
const st = new Date();
console.log('Start Time : ', st.toISOString());
// Send request and log result
sessionClient
  .detectIntent(request)
  .then(responses => {
    const et = new Date();
    console.log('End Time : ', et.toISOString());
    console.log('Duration : ', (et - st) / 1000);

    console.log('Detected intent');
    const result = responses[0].queryResult;
    console.log(`  Query: ${result.queryText}`);
    console.log(`  Response: ${result.fulfillmentText}`);
    if (result.intent) {
      console.log(`  Intent: ${result.intent.displayName}`);
    } else {
      console.log(`  No intent matched.`);
    }
  })
  .catch(err => {
    console.error('ERROR:', err);
  });

示例输出为: -

Start Time :  2018-05-16T12:30:15.012Z
End Time :  2018-05-16T12:30:17.221Z
Duration :  2.209
Detected intent
  Query: hi
  Response: 
  Intent: intent_general_greetings

在输出中,持续时间以秒为单位。因此,我们在 1-2秒内获得api响应。

有人可以帮助理解这个问题,为什么我们会有太多的高延迟。我有很好的互联网。我还在aws ec2上测试了上面的代码片段。仍然,在通话中获得那么多的延迟。

这是v2 api的对话流的表现吗?

0 个答案:

没有答案