Облачные функции Firebase - медленный ответ при запросе Firestore
У меня есть простая облачная функция в Firebase, которая берет JSON в http POST и сохраняет его в коллекции Firestore. Он выделил 512 МБ памяти.
Производительность этой облачной функции очень низкая. Если выполняется непрерывно, кругосветное путешествие колеблется от 200-600 мс, а если выполняется нечасто (каждые 5-10 минут), это может занять 4-10 секунд. Я понимаю проблему холодного старта, но на AWS я никогда не видел холодного начала этого медленного, и это не часто.
Мой код ниже - я был бы признателен за понимание того, как ускорить работу.
'use strict';
const functions = require('firebase-functions');
const admin = require('firebase-admin');
admin.initializeApp(functions.config().firebase);
const db = admin.firestore();
const express = require('express');
const bodyParser = require("body-parser");
const app = express();
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
// CORS Express middleware to enable CORS Requests.
const cors = require('cors');
app.use(cors({ origin: true }))
app.post('/submitResponse', (req, res) => {
console.log('/submitResponse');
if (!req.body.info)
res.status(422).send()
const payload = req.body.info;
console.log(payload);
const responses = db.collection("responses")
responses.add({
payload: payload,
timestamp: admin.firestore.FieldValue.serverTimestamp()
}).then(function(docRef) {
console.log("Response written with ID: ", docRef.id);
res.status(200).send(JSON.stringify(docRef.id))
})
.catch(function(error) {
console.error("Error adding document: ", error);
});
});
exports.app = functions.https.onRequest(app);