我试图使用节点库调用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的对话流的表现吗?