开发者社区 > 云原生 > Serverless > 正文

Serverless 应用引擎怎么在启动命令中让他自动生成一个logs的文件夹放日志?

Serverless 应用引擎怎么在启动命令中让他自动生成一个logs的文件夹放日志?

展开
收起
真的很搞笑 2023-07-16 18:44:33 77 0
2 条回答
写回答
取消 提交回答
  • 在 Serverless 应用引擎(SAE)中,您可以通过在启动命令中指定相关配置来自动生成一个名为 "logs" 的文件夹,并将日志文件写入该文件夹。具体的步骤如下:

    1. 首先,在您的应用代码中,确保使用适当的日志库或框架来记录日志。常见的选择包括 Log4j、Slf4j、Winston 等。这些库通常支持指定日志输出位置。

    2. 在配置文件中,添加一个环境变量或配置项,用于指定生成日志的路径。您可以在 template.yamlserverless.yml 文件中根据您正在使用的映射文件格式进行配置。

      • 如果您使用 template.yaml,可以在其中添加一个 Resources 节点,定义一个 SAE 函数资源,并通过 Properties.EnvironmentVariables 来设置环境变量,示例如下:

        Resources:
          MyFunction:
            Type: 'Aliyun::Serverless::Function'
            Properties:
              ...
              EnvironmentVariables:
                LOGS_DIR: '/mnt/auto/logs'
        
      • 如果您使用 serverless.yml,则可以在 functions 节点中的相应函数配置中,添加一个 environment 变量,示例如下:

        functions:
          myFunction:
            handler: index.handler
            environment:
              LOGS_DIR: '/mnt/auto/logs'
        
    3. 在您的应用代码中,获取环境变量 LOGS_DIR 的值,并将日志文件写入该目录。具体的实现方式取决于您使用的日志库和编程语言。

      • 例如,在 Node.js 中,可以使用 process.env.LOGS_DIR 来获取环境变量的值,并将日志文件写入指定的目录。

      • 在 Java 中,可以使用 System.getenv("LOGS_DIR") 来获取环境变量的值,并将日志文件写入指定的目录。

    这样配置后,在 SAE 运行应用时,它会自动创建名为 "logs" 的文件夹,并将日志文件写入指定的目录。

    请注意,生成日志的路径应与实际的运行环境和部署方式相匹配。确保对应的权限设置正确,以允许应用程序在指定的目录中写入日志文件。

    2023-07-23 09:24:18
    赞同 展开评论 打赏
  • 北京阿里云ACE会长

    函数计算(如Serverless应用引擎)并不支持您在启动命令中自动生成日志文件夹。

    函数计算有如下特点:

    每次函数运行时会生成一个全新的执行环境。函数结束后,该执行环境就被销毁。

    函数计算不提供全局文件系统,不支持在执行环境中生成持久的文件夹结构。

    函数计算会自动保存函数的标准输出(stdout)作为执行日志,您无需手动生成日志文件夹。

    正确的做法是将日志输出到标准输出(stdout),例如:

    js
    Copy
    console.log("This is a log");
    函数计算会自动将标准输出作为执行日志保存下来。

    如果需要更多的日志级别与功能,可以考虑将日志输出到第三方日志服务,例如:

    阿里云日志服务SLS
    ElasticSearch
    CloudWatch Logs

    2023-07-22 16:07:10
    赞同 展开评论 打赏

快速交付实现商业价值。

相关产品

  • 函数计算
  • Serverless 应用引擎
  • 相关电子书

    更多
    Hologres Serverless之路:揭秘弹性计算组 立即下载
    Serverless开发平台: 让研发效能再提升 立即下载
    Serverless 引领云上研发新范式 立即下载