APM Log Sender Function
Find out how to use the APM Log Sender pre-built function in OCI Functions to move service logs to an APM domain.
Common Usage Scenarios
Use the APM Log Sender PBF to move service logs to an APM domain by using the function as a target of a service connector. The main use of this function is to monitor Oracle Integration Cloud (OIC) integrations with Application Performance Monitoring (APM) by connecting an OIC activity stream log to the function.
Services related to the APM Log Sender function include:
Scope
Scope considerations for this function include:
- The function can be used with any log resource that contains OIC activity stream logging. For more information, see Capture the Activity Stream of Integrations in the Oracle Cloud Infrastructure Console.
- The function is to be used as the target of a service connector. For more information, see Overview of Connector Hub.
- The function can act as the data source of any APM domain. For more information, see Configure Application Performance Monitoring Data Sources.
Prerequisites and Recommendations
The following are best practices when using this pre-built function:
- Set the pre-built function timeout to 300 seconds.
- If the subnet specified for the application is a private subnet, the VCN must include a service gateway. If the subnet specified for the application is a public subnet, the VCN must include an internet gateway. In both cases, the necessary routing rules must exist. See the instructions in the Invoking a function returns a FunctionInvokeImageNotAvailable message and a 502 error troubleshooting topic.
- The function, APM domain, and log resource must all be in the same region.
Configuring the APM Log Sender Function
To create an APM Log Sender function, perform the following steps:
The deploy dialog displays the tasks to deploy the function (see Finishing Pre-Built Function Deployment).
Configuration Options
Configuration Parameters
| Name | Description | Required | 
|---|---|---|
| APM_DOMAIN_ID | The id of the domain that is to monitor the service log. | Yes | 
| PBF_LOG_LEVEL | Logging level, options are DEBUG,INFO,WARN, andERROR. Defaults toINFO. | No | 
Permissions
Running a function requires certain IAM policies. If you selected the Do not create a dynamic group and IAM policy option when creating the function, you must define the dynamic group and the IAM policy yourself.
To set the proper policies, perform the following steps:
- Create a dynamic group with the rule: ALL {resource.id = '<function_ocid>', resource.compartment.id = '<compartment_ocid>'
- Configure an IAM policy using the dynamic group: Allow dynamic-group <dynamic-group-name> to read apm-domains in compartment <compartment-name> Allow dynamic-group <dynamic-group-name> to {APM_DOMAIN_DATA_UPLOAD} in compartment <compartment-name>
Replace
<function-ocid> with the OCID of the function that you created in preceding steps. Replace
<dynamic-group-name> with the name of the dynamic group that you created using the function's OCID.Replace
<compartment_ocid> with the OCID of the compartment that contains the function.Replace
<compartment_name> with the name of the compartment that contains the APM domain.Invoking This Function
- Create a function using this PBF.
- Create a connector in the Connector Hub to forward the activity stream logs to the function:- Open the navigation menu and select Analytics & AI. Under Messaging, select Connector Hub.
- Select the Create connector button.
- Enter a name and optional description.
- Select a compartment.
- Under Configure connector, set the Source to Logging, and the Target to Functions.
- Under Configure source, point the Log Group and Logs to a service log.
- Under Configure target, set the Function application and Function to the function that you created in the earlier step.Note: Do not configure a task. 
- Select the Create button.
 
Troubleshooting
OCI Functions common status codes
The following table summarizes common OCI Functions errors that you might encounter when working with pre-built functions:
| Error Code | Error Message | Action | 
|---|---|---|
| 200 | Success | None | 
| 404 | NotAuthorizedOrNotFound | Verify that the required policies are configured (see Running Fn Project CLI commands returns a 404 error). | 
| 444 | Timeout | The connection between the client and OCI Functions was interrupted during function execution (see Invoking a function causes the client to report a timeout, and a 444 error is shown in the function's logs). A retry might solve the issue. Note that most clients have an inner timeout of 60 seconds. Even when the pre-built function timeout is set to 300 seconds, the following might be required: 
 For more information, see Invoking Functions. | 
| 502, 504 | (various) | Most issues return a 502 status code (see Invoking a function returns a Function failed message and a 502 error). A 502 error with the message "error receiving function response" might be resolved by increasing the memory allocation. A 502 might occur occasionally when the function is in some transient state. A retry might solve the issue. | 
To further identify the cause, enable logging features for the pre-built function (see Storing and Viewing Function Logs). For detailed information on troubleshooting a function, see Troubleshooting OCI Functions.
APM Log Sender pre-built function error messages
The following table summarizes the errors that you might encounter when working with this pre-built function:
| Error Code | Error Message | Action | 
|---|---|---|
| n/a | Unable to retrieve data upload endpoint | Verify that the following required policy statement has been created:  | 
| n/a | Post to APM collector failed | Verify that the following required policy statement has been created: Verify that the application's VCN has the appropriate gateway configured. See Prerequisites and Recommendations. | 
To further identify the cause, enable logging features for the pre-built function (see Storing and Viewing Function Logs).
Log Analysis Tips
All the pre-built functions provide an option to specify the logging level as a configuration parameter. You can set the logging level to DEBUG to get more information.
Since an application has multiple functions, the pre-built function log entries are identified by the prefix "PBF | <PBF NAME> ".
For example, a log entry for the APM Log Sender pre-built function looks similar to the following:
"PBF | APM Log Sender | ERROR | 2024-08-13T12:44:49.579050219Z | Unable to retrieve data upload endpoint"