函数计算内置的Java8运行时支持接入ARMS(Application Real-Time Monitoring Service)应用监控。自定义运行时中的Java 8、Java 11和Java 17也支持接入ARMS应用监控。本文介绍如何使用自定义运行时接入ARMS应用监控。
背景信息
函数计算无缝对接ARMS应用监控平台后,您可以通过ARMS应用监控平台对目标函数进行监控追踪,获取相关信息,例如实例级别的可观测性、链路追踪信息、Java虚拟机指标、代码级别的剖析(Profiling)信息和应用安全信息等。
前提条件
获取License Key
登录ARMS控制台,在左侧导航栏选择 。
在应用列表页面顶部选择目标地域,然后单击接入应用。
在接入中心面板单击Java,然后在STEP2区域获取License Key。
自定义运行时接入ARMS
ARMS应用监控是一种内部扩展。自定义运行时接入ARMS应用监控时,主要包括以下三部分。
使用公共层获取ARMS Agent程序
函数计算平台以公共层的形式,提供了支持Java 8、Java 11和Java 17三种Java版本的ARMS Agent。
Java版本 | 兼容运行时 | 公共层ARN |
Java 11/Java 8 | 自定义运行时 | acs:fc:{region}:official:layers/ArmsAgent273x/versions/2 |
Java 17 | 自定义运行时 | acs:fc:{region}:official:layers/ArmsAgent273x_JDK17/versions/1 |
使用Bootstrap脚本作为启动命令
使用ARMS需要添加3个启动参数,考虑到启动命令比较复杂,建议通过脚本来启动。可以在函数代码页面使用WebIDE创建文件bootstrap,并设置文件权限为可执行权限(终端窗口执行命令chmod +x bootstrap
)。示例代码如下所示。
#!/bin/bash
set -eo pipefail
# 1. 设置ARMS应用名称
appName="FC:Custom_Java_Arms_Demo"
if [ -n "${FC_SERVICE_NAME}" ] || [ -n "${FC_FUNCTION_NAME}" ]; then
appName="FC:${FC_SERVICE_NAME}.${FC_FUNCTION_NAME}"
fi
echo "appName: ${appName}"
params=" "
# 2. 添加ARMS参数
if [[ -n "${FC_EXTENSIONS_ARMS_LICENSE_KEY}" ]]; then
echo "FC_EXTENSIONS_ARMS_LICENSE_KEY: ${FC_EXTENSIONS_ARMS_LICENSE_KEY}"
params+="-Dfc.instanceId=$HOSTNAME@`hostname -i` "
# 使用公共层的ARMS程序路径
params+="-javaagent:/opt/ArmsAgent/arms-bootstrap-1.7.0-SNAPSHOT.jar "
params+="-Darms.licenseKey=${FC_EXTENSIONS_ARMS_LICENSE_KEY} "
params+="-Darms.appName=${appName} "
else
echo "The environment FC_EXTENSIONS_ARMS_LICENSE_KEY does not exist, please set the FC_EXTENSIONS_ARMS_LICENSE_KEY environment!"
exit 1
fi
# 3. 启动应用程序
echo "params: ${params}"
exec java $params \
-Dserver.port=9000 \
-jar /code/target/demo-0.0.1-SNAPSHOT.jar
示例代码解析如下。
设置ARMS应用名称。默认为
FC:{ServiceName}.{FunctionName}
。添加ARMS参数。
javaagent
:ARMS程序路径。如果使用ARMS Agent的公共层,该路径为/opt/ArmsAgent/arms-bootstrap-1.7.0-SNAPSHOT.jar
。Darms.licenseKey
:License key信息。本文示例展示从环境变量中获取License key。更多关于获取License Key的信息,请参见获取License Key。Darms.appName
:ARMS应用程序名称。按照实际情况填写。
设置环境变量
设置环境变量
FC_EXTENSIONS_ARMS_LICENSE_KEY=xxxx
,值为License Key。获取License Key信息的具体步骤,请参见获取License Key。设置环境变量
FC_EXTENSION_ARMS=true
。添加该环境变量后,在一次函数调用结束时,不会立刻冻结函数实例,会等待10s再冻结函数实例,以确保ARMS Agent扩展成功上报日志。
重要该方式会有额外的收费,收费策略与实例的Prefreeze回调相同。具体信息,请参见计费说明。
操作步骤
- 登录函数计算控制台,在左侧导航栏,单击服务及函数。
- 在顶部菜单栏,选择地域,然后在服务列表页面,单击目标服务。
- 在函数管理页面,单击目标函数操作列的配置。
在函数配置页面的层区域,通过添加官方公共层添加与所选Java语言兼容的ArmsAgent层。
在函数配置页面的环境变量区域,添加环境变量
FC_EXTENSION_ARMS=true
和FC_EXTENSIONS_ARMS_LICENSE_KEY=xxxx
。具体操作,请参见设置环境变量。
在函数代码页面的WebIDE中,创建Bootstrap文件,然后单击部署代码。
具体操作,请参见使用Bootstrap脚本作为启动命令。
成功更新配置并部署代码后,您的函数将被添加到ARMS应用监控进行高性能管理。同时,ARMS监控将对您的服务进行计费。更多信息,请参见计费概述。
当您的函数成功接入ARMS监控平台后,如果您需要查看对应监控信息,请确保ARMS监控平台和函数所属地域相同。
为了函数能够正常执行,请确保您的函数配置中,内存规格大于512 MB(ARMS大概占用300 MB内存)。
结果验证
当您成功将函数接入ARMS应用监控平台后,您可以在ARMS控制台查看接入的函数。