10

我正在编写一个应用程序脚本(用于处理电子邮件、任务和日历事件)并希望将其部署为网络应用程序。

该应用程序将在运行它的用户的上下文中运行。该应用程序将被超过 10,000 多个用户使用,甚至可能更多。

在我将其分发给用户之前,我想知道 Web 应用程序可以拥有的并发点击数是否有限制?

在这种情况下,如果运行 Web 应用程序脚本的用户会考虑限制,或者我的(脚本所有者)限制是否适用?如果未达到此处描述的限制,我是否可以假设它可以扩展足以满足 10k+ 用户的需求?任何与之相关的想法或经验?

4

1 回答 1

16

如果您正在寻找这个问题的解决方案,那么这个怎么样?我使用可以进行异步处理的 fetchAll 方法测量了 Web 应用程序的并发连接数。流程如下。

  1. 部署 Web 应用程序。
  2. 通过异步处理连接到 Web Apps。此时,作为连接数的工作人员的数量发生了变化。
  3. 从 Web 应用程序返回结果时检索错误数。

本实验的示例脚本:

客户端脚本: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;
  }
}

结果 :

在此处输入图像描述

该图显示了随着工作人员数量的增加而返回的错误数量。从这个图中可以看出,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 Apps 部署为"Execute the app as:" : Me,则 Web Apps 的脚本以所有者身份运行。所以使用了所有者的配额。
  • 如果 Web Apps 部署为"Execute the app as:" : User accessing the web app,则 Web Apps 的脚本以每个用户的身份运行。所以使用每个用户的配额。

参考 :

如果这不是你想要的,我很抱歉。

于 2018-04-26T02:31:59.297 回答