Write and view logsStay organized with collectionsSave and categorize content based on your preferences.
Logging is an important tool for debugging and monitoring code.Cloud Functionsgives you the option of using the logger SDK forNode.jsorPython,
or theconsoleobject standard for developing for the web.
Cloud Logging is a chargeable service; you may be billed if you
exceed the no-cost quota. For more information, seeCloud Logging pricing.
Writing logs
Using theCloud Functionslogger SDK
TheCloud Functionslogger SDK provides a standard interface
to report status from functions to Cloud Logging.
You can use this SDK to log events withstructured data,
enabling easier analysis and monitoring.
Import from theloggersubpackage:
Node.js
// All available logging functionsconst{log,info,debug,warn,error,write,}=require("firebase-functions/logger");
@https_fn.on_request()defhello_world(req:https_fn.Request)->https_fn.Response:# sends a log to Cloud Logginglogger.log("Hello logs!")returnhttps_fn.Response("Hello from Firebase!")
Use different log levels for different types of log in your function code.
Structured data can be attached to a log as the last argument. Here is an
example of how a function can use each log type:
Node.js
exports.getInspirationalQuote=onRequest(async(request,response)=>{constdb=getFirestore();consttoday=newDate();constquoteOfTheMonthRef=db.collection("quotes").doc(`${today.getFullYear()}`).collection("months").doc(`${today.getMonth()}`);constDEFAULT_QUOTE="You miss 100% of the shots you don't take. -Wayne Gretzky";letquote;try{constquoteOfTheMonthDocSnap=awaitquoteOfTheMonthRef.get();// Attach relevant debugging information with debug()debug("Monthly quote fetch result",{docRef:quoteOfTheMonthRef.path,exists:quoteOfTheMonthDocSnap.exists,createTime:quoteOfTheMonthDocSnap.createTime,});if(quoteOfTheMonthDocSnap.exists){quote=quoteOfTheMonthDocSnap.data().text;}else{// Use warn() for lower-severity issues than error()warn("Quote not found for month, sending default instead",{docRef:quoteOfTheMonthRef.path,dateRequested:today.toLocaleDateString("en-US"),});quote=DEFAULT_QUOTE;}}catch(err){// Attach an error object as the second argumenterror("Unable to read quote from Firestore, sending default instead",err);quote=DEFAULT_QUOTE;}// Attach relevant structured data to any loginfo("Sending a quote!",{quote:quote});response.json({inspirationalQuote:quote});});
@https_fn.on_request()defget_inspirational_quote(req:https_fn.Request)->https_fn.Response:firestore_client=firestore.client()today=datetime.date.today()quote_of_the_month_ref=(firestore_client.collection("quotes").doc(str(today.year)).collection("months").doc(str(today.month)))default_quote="Python has been an important part of Google since the beginning, and remains so as the system grows and evolves."quote=Nonetry:quote_of_the_month=quote_of_the_month_ref.get()# Attach relevant debugging information with debug()logger.debug("Monthly quote fetch result",docRef=quote_of_the_month.path,exists=quote_of_the_month.exists,createTime=quote_of_the_month.createTime,)ifquote_of_the_month.exists:quote=quote_of_the_month.to_dict()["text"]else:# Use warn() for lower-severity issues than error()logger.warn("Quote not found for month, sending default instead",doc_reference=quote_of_the_month.path,date_requested=today.strftime("%Y-%m-%d"),)quote=default_quoteexcept:e=sys.exc_info()[0]# Attach an error object as the second argumentlogger.error("Unable to read quote from Firestore, sending default instead",error=e)quote=default_quote# Attach relevant structured data to any loglogger.info("Sending a quote!",quote=quote)returnhttps_fn.Response("Hello from Firebase!")
Withlogger.write(), you can write log entries with additional
log severity levels
ofCRITICAL,ALERT, andEMERGENCY. SeeLogSeverity.
Node.js
exports.appHasARegression=onRegressionAlertPublished((event)=>{write({// write() lets you set additional severity levels// beyond the built-in logger functionsseverity:"EMERGENCY",message:"Regression in production app",issue:event.data.payload.issue,lastOccurred:event.data.payload.resolveTime,});});
@crashlytics_fn.on_regression_alert_published()defapp_has_regression(alert:crashlytics_fn.CrashlyticsRegressionAlertEvent)->None:logger.write(severity="EMERGENCY",message="Regression in production app",issue=alert.data.payload.issue,last_occurred=alert.data.payload.resolve_time,)print(alert)
The recommended solution for logging from a function is to use the logger SDK
for your platform. With Node.js, you can instead use standard JavaScript logging
calls such asconsole.logandconsole.error, but you first need to require a
special module to patch the standard methods to work correctly:
require("firebase-functions/logger/compat");
Once you have required the logger compatibility module, you can useconsole.log()methods as normal in your code:
exports.helloError=functions.https.onRequest((request,response)=>{console.log('I am a log entry!');response.send('Hello World...');});
Cloud Loggingoffers a powerful suite of logs analysis tools that you can
use to monitor yourCloud Functions.
Charts and alerts
Once you have created logs-based metrics to monitor your functions, you can
create charts and alerts based on these metrics. For example, you could create
a chart to visualize latency over time, or create an alert to let you know
if a certain error occurs too often.
SeeCreating Charts and Alertsfor detailed information on how
to use logs-based metrics in charts and alerting policies.
Understand and use execution IDs
By default, Cloud Run functions (2nd gen) supports concurrent execution of
multiple requests within a single function instance. This means logs from
different requests can be interleaved, making it harder to follow the flow of a
single execution.
To help with this, functions deployed using Firebase CLI version 13.33.0 and
later automatically deploy with an option to associate an execution ID with each
log entry emitted during handling of that execution.
The execution ID uniquely identifies all logs associated with a single request
handled by your function. No code changes are required; the execution ID will
be automatically added to your logs.
To disable logging execution ID in your log entries, set theenvironment variableLOG_EXECUTION_IDto false in your dotenv file.
Find and correlate logs by execution ID
You can inspect and correlate logs by execution ID in Cloud Logs Explorer.
Expand the log entry from your function. The execution ID is located within
the structured log data, nested under labels aslabels.execution_id.
Click the value of theexecution_idand select "Show matching entries" from
the drop-down menu to see all other logs associated with that same function
execution.
By using the execution ID, you can group together all log messages related to
a single request, even if your function is handling multiple requests
concurrently.
Enhance log visibility with custom summary fields
To make the execution ID more readily visible in the Logs Explorer, you can add
it as a [custom summary field][cloud-logging-preference]. After you add
execution ID as a summary field, every log entry will show execution ID as a
chip at the beginning of the log line. similar to the
way 1st Gen functions surfaced execution ID for all log entries.
To add execution ID to summary field:
Click the value of the execution ID in the structured log entry underlabels.execution_id.
Select "Add field to summary line" from the drop-down menu.
Each log entry now displays theexecutionIdprominently in the summary field,
making it easier to identify and group logs associated with a specific execution
ID.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-10-30 UTC."],[],[]]