我正在编写一个应用程序脚本(用于处理电子邮件、任务和日历事件)并希望将其部署为网络应用程序。
该应用程序将在运行它的用户的上下文中运行。该应用程序将被超过 10,000 多个用户使用,甚至可能更多。
在我将其分发给用户之前,我想知道 Web 应用程序可以拥有的并发点击数是否有限制?
在这种情况下,如果运行 Web 应用程序脚本的用户会考虑限制,或者我的(脚本所有者)限制是否适用?如果未达到此处描述的限制,我是否可以假设它可以扩展足以满足 10k+ 用户的需求?任何与之相关的想法或经验?
我正在编写一个应用程序脚本(用于处理电子邮件、任务和日历事件)并希望将其部署为网络应用程序。
该应用程序将在运行它的用户的上下文中运行。该应用程序将被超过 10,000 多个用户使用,甚至可能更多。
在我将其分发给用户之前,我想知道 Web 应用程序可以拥有的并发点击数是否有限制?
在这种情况下,如果运行 Web 应用程序脚本的用户会考虑限制,或者我的(脚本所有者)限制是否适用?如果未达到此处描述的限制,我是否可以假设它可以扩展足以满足 10k+ 用户的需求?任何与之相关的想法或经验?
如果您正在寻找这个问题的解决方案,那么这个怎么样?我使用可以进行异步处理的 fetchAll 方法测量了 Web 应用程序的并发连接数。流程如下。
var workers = 10; // Number of workers
var object = [];
for (var i = 0; i < workers; i++) {
object.push({
"url": "https://script.google.com/macros/s/#####/exec?key=ok",
"method": "get",
"muteHttpExceptions": true,
});
}
var startTime = Date.now();
var res = UrlFetchApp.fetchAll(object);
var endTime = Date.now();
var elapsedTime = (endTime - startTime) / 1000;
var error = res.filter(function(e){return ~e.getContentText().indexOf("Error")});
var result = [[workers, elapsedTime, (error.length > 0 ? error.length : 0)]]; // This is imported to Spreadsheet
function doGet(e) {
if (e.parameter.key == "ok") {
var val = JSON.stringify({
date: new Date().getTime().toString(),
});
Utilities.sleep(1000);
return ContentService.createTextOutput(val).setMimeType(ContentService.MimeType.JSON);
} else {
return;
}
}
该图显示了随着工作人员数量的增加而返回的错误数量。从这个图中可以看出,30个worker以下没有错误,而且当worker超过30个时,错误也包含在返回的结果中。错误消息是Service invoked too many times in a short time: exec qps. Try Utilities.sleep(1000) between calls.
。这意味着对于 Web 应用程序,与并发访问连接的最大有效工作人员数为 29。如果worker的访问时间间隔超过1秒,则不会发生错误。
"Execute the app as:" : Me
,则 Web Apps 的脚本以所有者身份运行。所以使用了所有者的配额。"Execute the app as:" : User accessing the web app
,则 Web Apps 的脚本以每个用户的身份运行。所以使用每个用户的配额。如果这不是你想要的,我很抱歉。