AWS Glue不支持指定每月第n个工作日的定时任务。但可以通过使用AWS Lambda和CloudWatch事件来实现。
首先,编写一个Lambda函数来检查今天是否是每月的第n个工作日。以下是一个Python代码示例:
import datetime
def lambda_handler(event, context):
# 获取今天的日期
today = datetime.datetime.today()
# 获取当前月份
current_month = today.month
current_year = today.year
# 获取第n个工作日
n_th_workday = event['n_th_workday']
# 计算n_th_workday在当前月份的日期
date = datetime.date(current_year, current_month, 1)
while date.weekday() != 0:
date += datetime.timedelta(days=1)
n_th_workday_date = date + datetime.timedelta(weeks=0, days=n_th_workday - 1)
# 如果今天是n_th_workday,返回True
if today.date() == n_th_workday_date:
return True
return False
接下来,使用CloudWatch事件触发Lambda函数。在CloudWatch事件规则中定义cron表达式,以便在每天的特定时间调用Lambda函数,并将Lambda函数的返回值发送到SNS主题。以下是一个CloudWatch事件规则的代码示例,该规则将在每个月的第3个工作日的上午10点调用Lambda函数(假设Lambda函数名为“check_workday”):
{
"source": [
"aws.cloudwatch"
],
"detail-type": [
"Scheduled Event"
],
"detail": {
"requestParameters": {
"name": [
"check_workday"
]
}
},
"cron": "0 10 * * ? 1-5 3#3"
}
最后,创建一个SNS主题来接收Lambda函数的返回值,并在必要时触发后续操作。