我正在编写一个应用程序脚本(用于处理电子邮件、任务和日历事件)并希望将其部署为网络应用程序。
该应用程序将在运行它的用户的上下文中运行。
该应用程序将被超过 10k+ 的用户使用,甚至可能更多。
在将其分发给用户之前,我想知道网络应用程序可以拥有的并发点击数是否有限制?
在这种情况下,如果用户运行网络应用程序脚本会受到限制,或者我的(脚本所有者)限制会适用吗?我是否可以假设它可以扩展至足以满足超过 10k 个用户的需求,前提是未达到此处所述的限制?有什么相关的想法或经验吗?
如果您正在寻找这个问题的解决方案,那么这个怎么样?我使用 fetchAll 方法测量了 Web 应用程序的并发连接数,该方法可以进行异步处理。流程如下。
- 部署网络应用程序。
- 通过异步处理连接到Web Apps。此时,作为连接数的工作线程数发生变化。
- 检索从 Web Apps 返回结果时的错误数。
本实验的示例脚本:
客户端脚本:Google Apps 脚本
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
Web 应用程序端的脚本:
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;
}
}
Result :
该图显示了随着worker数量的增加,返回的错误数量。从图中可以发现,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秒,则不会出现错误。
- 如果 Web 应用程序部署为
"Execute the app as:" : Me
,Web Apps 的脚本以所有者身份运行。所以使用了owner的配额。
- 如果 Web 应用程序部署为
"Execute the app as:" : User accessing the web app
,Web Apps 的脚本作为每个用户运行。这样就使用了每个用户的配额。
参考 :
- 获取全部方法 https://developers.google.com/apps-script/reference/url-fetch/url-fetch-app#fetchAll(Object)
如果这不是您想要的,我很抱歉。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)