با مجموعهها، منظم بمانید
ذخیره و طبقهبندی محتوا براساس اولویتهای شما.
اگر میخواهید توابع را برای اجرا در زمانهای مشخص زمانبندی کنید، از کنترلکننده onSchedule ارائهشده توسط firebase-functions/v2/scheduler استفاده کنید. این توابع از Cloud Scheduler برای فراخوانی منطق تابع در زمان ها یا فواصل زمانی که شما تعریف می کنید استفاده می کنند.
قبل از شروع
اگرچه صورتحساب مورد نیاز است، میتوانید انتظار داشته باشید که هزینه کلی قابل مدیریت باشد، زیرا هر کار Cloud Scheduler 0.10 دلار (دلار آمریکا) در ماه هزینه دارد، و سه شغل برای هر حساب Google بدون هیچ هزینهای وجود دارد. از ماشین حساب قیمت گذاری Blaze برای ایجاد برآورد هزینه بر اساس استفاده پیش بینی شده خود استفاده کنید.
Cloud Scheduler API باید برای پروژه شما فعال باشد. از قبل باید برای اکثر پروژه های Firebase فعال باشد. می توانید در کنسول Google Cloud تأیید کنید.
یک تابع زمان بندی شده بنویسید
در Cloud Functions for Firebase ، منطق زمانبندی در کد توابع شما قرار دارد، بدون نیاز به زمان استقرار خاص. به عنوان مثال، برای پاکسازی حسابهای کاربری غیرفعال یک بار در روز، میتوانید تابعی بنویسید که با دستورهای import زیر شروع میشود:
Node.js
// The Cloud Functions for Firebase SDK to set up triggers and logging.const{onSchedule}=require("firebase-functions/v2/scheduler");const{logger}=require("firebase-functions");// The Firebase Admin SDK to delete inactive users.constadmin=require("firebase-admin");admin.initializeApp();// The es6-promise-pool to limit the concurrency of promises.constPromisePool=require("es6-promise-pool").default;// Maximum concurrent account deletions.constMAX_CONCURRENT=3;
# The Cloud Functions for Firebase SDK to set up triggers and logging.fromfirebase_functionsimportscheduler_fn# The Firebase Admin SDK to delete users.importfirebase_adminfromfirebase_adminimportauthfirebase_admin.initialize_app()
سپس، می توانید از onSchedule برای شروع یک کار Cloud Scheduler استفاده کنید:
Node.js
// Run once a day at midnight, to clean up the users// Manually run the task here https://console.cloud.google.com/cloudschedulerexports.accountcleanup=onSchedule("every day 00:00",async(event)=>{// Fetch all user details.constinactiveUsers=awaitgetInactiveUsers();// Use a pool so that we delete maximum `MAX_CONCURRENT` users in parallel.constpromisePool=newPromisePool(()=>deleteInactiveUser(inactiveUsers),MAX_CONCURRENT,);awaitpromisePool.start();logger.log("User cleanup finished");});
# Run once a day at midnight, to clean up inactive users.# Manually run the task here https://console.cloud.google.com/cloudscheduler@scheduler_fn.on_schedule(schedule="every day 00:00")defaccountcleanup(event:scheduler_fn.ScheduledEvent)-> None:"""Delete users who've been inactive for 30 days or more."""user_page:auth.ListUsersPage|None=auth.list_users()whileuser_pageisnotNone:inactive_uids=[user.uidforuserinuser_page.usersifis_inactive(user,timedelta(days=30))]auth.delete_users(inactive_uids)user_page=user_page.get_next_page()
هنگامی که یک تابع زمان بندی شده را اجرا می کنید، یک کار زمانبندی و یک تابع HTTP به طور خودکار ایجاد می شود. Firebase CLI نام تابع را بازتاب می دهد و می توانید کار و عملکرد را در کنسول Google Cloud مشاهده کنید. موضوع بر اساس قرارداد زیر نامگذاری شده است:
firebase-schedule- function_name - region
به عنوان مثال:
firebase-schedule-accountcleanup-us-east1.
در زمان برنامه ریزی شده، حساب سرویس محاسباتی پیش فرض تابع HTTP مرتبط را فراخوانی می کند. این بدان معناست که فقط کار مربوط به Cloud Scheduler اجازه اجرای عملکرد را دارد.
تاریخ آخرین بهروزرسانی 2025-09-04 بهوقت ساعت هماهنگ جهانی.
[[["درک آسان","easyToUnderstand","thumb-up"],["مشکلم را برطرف کرد","solvedMyProblem","thumb-up"],["غیره","otherUp","thumb-up"]],[["اطلاعاتی که نیاز دارم وجود ندارد","missingTheInformationINeed","thumb-down"],["بیشازحد پیچیده/ مراحل بسیار زیاد","tooComplicatedTooManySteps","thumb-down"],["قدیمی","outOfDate","thumb-down"],["مشکل ترجمه","translationIssue","thumb-down"],["مشکل کد / نمونهها","samplesCodeIssue","thumb-down"],["غیره","otherDown","thumb-down"]],["تاریخ آخرین بهروزرسانی 2025-09-04 بهوقت ساعت هماهنگ جهانی."],[],[],null,["\u003cbr /\u003e\n\nIf you want to schedule functions to run at specified times, use\nthe `onSchedule` handler provided by `firebase-functions/v2/scheduler`.\nThese functions use [Cloud Scheduler](https://cloud.google.com/scheduler/)\nto invoke function logic at the times or intervals that you define.\n\nBefore you begin\n\nThough scheduled functions are billed, you can expect the overall\ncost to be manageable, as\neach Cloud Scheduler job costs $0.10 (USD) per month, and there is an\nallowance of three jobs per Google account, at no charge. Use the Blaze\n[pricing calculator](/pricing#blaze-calculator) to generate a cost estimate\nbased on your projected usage.\n\nThe Cloud Scheduler API must be enabled for your\nproject. It should already be enabled for most Firebase projects; you can\nverify in the [Google Cloud console](https://console.cloud.google.com/).\n\nWrite a scheduled function\n\nIn Cloud Functions for Firebase, scheduling logic resides in your functions code,\nwith no special deploy-time requirements.\nFor example, to clean up inactive user accounts once daily, you could write\na function starting with the following import statements: \n\nNode.js \n\n // The Cloud Functions for Firebase SDK to set up triggers and logging.\n const {onSchedule} = require(\"firebase-functions/v2/scheduler\");\n const {logger} = require(\"firebase-functions\");\n\n // The Firebase Admin SDK to delete inactive users.\n const admin = require(\"firebase-admin\");\n admin.initializeApp();\n\n // The es6-promise-pool to limit the concurrency of promises.\n const PromisePool = require(\"es6-promise-pool\").default;\n // Maximum concurrent account deletions.\n const MAX_CONCURRENT = 3; \n https://github.com/firebase/functions-samples/blob/c4fde45b65fab584715e786ce3264a6932d996ec/Node/delete-unused-accounts-cron/functions/index.js#L20-L31\n\nPython \n\n # The Cloud Functions for Firebase SDK to set up triggers and logging.\n from firebase_functions import scheduler_fn\n\n # The Firebase Admin SDK to delete users.\n import firebase_admin\n from firebase_admin import auth\n\n firebase_admin.initialize_app() \n https://github.com/firebase/functions-samples/blob/c4fde45b65fab584715e786ce3264a6932d996ec/Python/delete-unused-accounts-cron/functions/main.py#L19-L26\n\nThen, you could use `onSchedule` to start a Cloud Scheduler task: \n\nNode.js \n\n // Run once a day at midnight, to clean up the users\n // Manually run the task here https://console.cloud.google.com/cloudscheduler\n exports.accountcleanup = onSchedule(\"every day 00:00\", async (event) =\u003e {\n // Fetch all user details.\n const inactiveUsers = await getInactiveUsers();\n\n // Use a pool so that we delete maximum `MAX_CONCURRENT` users in parallel.\n const promisePool = new PromisePool(\n () =\u003e deleteInactiveUser(inactiveUsers),\n MAX_CONCURRENT,\n );\n await promisePool.start();\n\n logger.log(\"User cleanup finished\");\n }); \n https://github.com/firebase/functions-samples/blob/c4fde45b65fab584715e786ce3264a6932d996ec/Node/delete-unused-accounts-cron/functions/index.js#L35-L49\n\nPython \n\n # Run once a day at midnight, to clean up inactive users.\n # Manually run the task here https://console.cloud.google.com/cloudscheduler\n @scheduler_fn.on_schedule(schedule=\"every day 00:00\")\n def accountcleanup(event: scheduler_fn.ScheduledEvent) -\u003e None:\n \"\"\"Delete users who've been inactive for 30 days or more.\"\"\"\n user_page: auth.ListUsersPage | None = auth.list_users()\n while user_page is not None:\n inactive_uids = [\n user.uid for user in user_page.users if is_inactive(user, timedelta(days=30))\n ]\n auth.delete_users(inactive_uids)\n user_page = user_page.get_next_page() \n https://github.com/firebase/functions-samples/blob/c4fde45b65fab584715e786ce3264a6932d996ec/Python/delete-unused-accounts-cron/functions/main.py#L31-L42\n\nBoth Unix Crontab and App Engine syntax\nare supported by Cloud Scheduler. For example, to use Crontab, do something like this: \n\nNode.js \n\n exports.scheduledFunctionCrontab = onSchedule(\"5 11 * * *\", async (event) =\u003e {\n // ...\n });\n\nPython \n\n @scheduler_fn.on_schedule(schedule=\"5 11 * * *\")\n\n| **Important:** Depending on how you design your scheduling logic, a function may be triggered multiple times, with the next instance running while the previous instance is still executing.\n\nDeploy a scheduled function\n\nWhen you deploy a scheduled function, a scheduler job and an HTTP function\nare created automatically. The Firebase CLI echoes the function name,\nand you can view the job and the function in the\n[Google Cloud console](https://console.cloud.google.com/project/_/cloudscheduler).\nThe topic is named according to the following convention:\n\n**firebase-schedule-\u003cvar translate=\"no\"\u003efunction_name\u003c/var\u003e-\u003cvar translate=\"no\"\u003eregion\u003c/var\u003e**\n\nFor example:\n\n**firebase-schedule-accountcleanup-us-east1.**\n\nAt the scheduled time, the default compute service account invokes the\nassociated HTTP function. This means that only the associated Cloud Scheduler\njob has permission to run the function.\n| **Important:** Make sure you do not manually delete or modify the function or scheduler job in the console. Doing this could cause errors in the execution of your scheduled function."]]