簡體   English   中英

firebase Cloud Functions 錯誤:RangeError:超出最大調用堆棧大小

[英]firebase Cloud Functions Error: RangeError: Maximum call stack size exceeded

我正在嘗試從 api 獲取股票數據。

我希望它在每 12:00 PM 更新一次。

但是當我試圖部署這個功能時,使用

$firebase deploy --only 函數

錯誤出來了。

錯誤:無法從源加載函數定義:無法從​​函數源生成清單:RangeError:超出最大調用堆棧大小

這是函數/src 中的“index.ts”。

import * as functions from "firebase-functions";
import axios from "axios"
import { doc, getFirestore, setDoc, Timestamp } from 'firebase/firestore'
import { format } from 'date-fns'
import { initializeApp } from "firebase/app";

const firebaseConfig = {
    apiKey: "***********",
    authDomain: "****",
    projectId: "",
    storageBucket: "",
    messagingSenderId: "",
    appId: "",
    measurementId: ""
};

// Initialize Firebase
export const app = initializeApp(firebaseConfig);
export const db = getFirestore(app);

const API_KEY = "****************"

interface Wow {
    clpr: string
    srtnCd: string
}

const today = new Date();
const yesterday = today.setDate(today.getDate() - 1);
const basDt = format(yesterday, 'yyyyMMdd')

export const getStocks = functions
    .region('asia-northeast3')
    .pubsub.schedule('12 00 * * *')
    .timeZone('Asia/Seoul').onRun(async (context) => {
        await axios.get(`https://api.odcloud.kr/api/GetStockSecuritiesInfoService/v1/getStockPriceInfo?numOfRows=3000&resultType=json&basDt=${basDt}&serviceKey=${API_KEY}`)
            .then(response => {
                const wow: Wow[] = response.data.response.body.items.item
                wow.map((v, index) => {
                    setDoc(doc(db, 'KRX', v.srtnCd), { day: Timestamp.fromDate(today), price: v.clpr })
                })
                return null;
            })
    })

另一個功能確實運作良好。 但如果我包括這個,它不起作用。

我應該怎么辦?

因為這是您的functions\src\index.ts文件,所以您應該只從中導出 Cloud Functions,而不是其他任何內容。

所以改變:

// Initialize Firebase
export const app = initializeApp(firebaseConfig);
export const db = getFirestore(app);

至:

// Initialize Firebase
const app = initializeApp(firebaseConfig);
const db = getFirestore(app);

如果您想導出已初始化的 Firebase SDK 以在其他地方使用,請將其移動到名為functions\src\firebase.ts (或類似文件)的自己的文件中:

// firebase.ts
import { initializeApp } from "firebase-admin/app";
import { getFirestore } from "firebase-admin/firestore";

export const app = initializeApp(); // no arguments uses the default service account
export const db = getFirestore(app);

然后像這樣使用它:

import { app, db } from "./firebase.ts"

// NOTE: at time of writing, @google-cloud/firestore still uses the legacy namespaced syntax
db.doc("path/to/some/document") 
  .set({ /* data */ })
  .then(() => console.log('success'))
  .catch((err) => console.error('error', err));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM