Как использовать переменную среды без сервера в параметре stepfunction

#aws-serverless #aws-step-functions

Вопрос:

У меня есть запрос с жестко заданными датами, используемыми в разделе параметров.Вместо этого я хочу передать их в качестве переменных среды.Есть какие-либо предложения о том, как параметризовать QueryString параметр?

 service: service-name

frameworkVersion: '2'

provider:
  name: aws
  runtime: go1.x
  lambdaHashingVersion: 20201221
  stage: ${opt:stage, self:custom.defaultStage}
region: us-east-1
  tags: ${self:custom.tagsObject}
  logRetentionInDays: 1
  timeout: 10
  deploymentBucket: lambda-repository
  memorySize: 128
  tracing:
    lambda: true

plugins:
  - serverless-step-functions

configValidationMode: error

stepFunctions:
  stateMachines:
    callAthena:
      name: datasorting-dev
      type: STANDARD
      role: ${self:custom.datasorting.${self:provider.stage}.iam}
      definition:
        Comment: "Data Refersh"
        StartAt: Refresh Data
        States:
          Refresh Data:
            Type: Task
            Resource: arn:aws:states:::athena:startQueryExecution.sync
            Parameters:
              QueryString: >-
                ALTER TABLE table.raw_data ADD IF NOT EXISTS
                PARTITION  (YEAR=2021, MONTH=02, DAY=15, hour=00)
              WorkGroup: primary
              ResultConfiguration:
                OutputLocation: s3://output/location
            End: true  
    

 

Ответ №1:

вы можете заменить любое значение serverless.yml , заключенное в скобки ${} ,

Бессерверный фреймворк Руководство по переменным: https://www.serverless.com/framework/docs/providers/aws/guide/variables/

например, вы можете создать custom: раздел для поиска переменных среды, и если они отсутствуют, у вас могут быть значения по умолчанию:

 service: service-name

frameworkVersion: '2'

custom:
  year: ${env:YEAR, 'default-year'}
  month: ${env:MONTH, 'default-month'}
  day: ${env:DAY, 'default-day'}
  hour: ${env:HOUR, 'default-hour'}

stepFunctions:
  stateMachines:
    callAthena:
      ...
      Parameters:
        QueryString: >-
          ALTER TABLE table.raw_data ADD IF NOT EXISTS
          PARTITION  (YEAR=${self:custom.year}, MONTH=${self:custom.month}, DAY=${self:custom.day}, hour=${self:custom.hour})
      ...