2

我有一个关于弹性 beantalk 和 cron 作业的应用程序。

设置cron的代码是

container_commands:
  01_some_cron_job:
    command: "echo '*/5 * * * * wget -O - -q -t 1 http://site.com/cronscript/' | crontab"
  leader_only: true

此脚本调用邮件发件人。我每次收到两条消息。

http://site.com/cronscript/看起来像的代码 (php代码)

require_once('ses.php');
$ses = new SimpleEmailService(EMAIL_SHORTKEY, EMAIL_LONGKEY);
$m = new SimpleEmailServiceMessage();
$m->addTo('user@domain.com');
$m->setFrom('response_service@domain.com');
$m->setSubject('test message');
$m->setMessageFromString('', 'message content');
$send_emails=($ses->sendEmail($m));

当我http://site.com/cronscript/从浏览器的地址栏拨打电话时,我会收到一条我想要的消息。

4

2 回答 2

5

我相信发生的事情是,当您第一次部署应用程序时,AutoScaling 会选择一个实例作为领导者,并在该实例上创建新的 cron 作业。下次部署应用程序时,AutoScaling 会选择另一个实例作为领导者。因此,您最终会在两个实例上执行相同的 cron 作业。

所以基本的测试是 ssh 到所有实例并检查它们的crontab内容crontab -l

您可以通过删除实例上的旧 cron 作业来避免重复的 cron 作业,无论它是否是领导者。

container_commands:
  00_remove_old_cron_jobs:
    command: "crontab -r || exit 0"
  01_some_cron_job:
    command: "echo '*/5 * * * * wget -O - -q -t 1 http://example.com/cronscript/' | crontab"
    leader_only: true

正如在 Elastic Beanstalk Auto-Scaling 环境中运行 Cron中所述:|| exit 0是强制性的,因为如果机器中没有 crontab,该crontab -r命令将返回状态代码 > 0(错误)。如果 container_commands 之一失败,Elastic Beanstalk 将停止部署过程。

虽然我个人从未遇到过crontab在 Elastic Beanstalk Instance 上找不到的情况。

您可以运行/opt/elasticbeanstalk/bin/leader-test.sh以测试它是否是领导者实例。

希望能帮助到你。

于 2014-01-23T03:57:13.470 回答
1

我遇到了同样的问题,只需将用户从 root 更改为我使用 eb ssh 登录的用户即可。我的代码看起来像这样。

files:
"/etc/cron.d/mycron":
    mode: "000644"
    owner: ec2-user
    group: ec2-user
    content: |
        30 1 * * * echo $(date) >> /tmp/cron_start.log; /usr/local/bin/daily_script.sh >> /tmp/crons.log 2>&1;



"/usr/local/bin/daily_script.sh":
    mode: "000755"
    owner: ec2-user
    group: ec2-user
    content: |
        #!/bin/bash

        date > /tmp/date
        # Your actual script content
        /opt/python/run/venv/bin/python3 /opt/python/current/app/cronjob_files/email_data.py >> /opt/python/current/app/cron.logs 2>&1

        exit 0

...

于 2020-06-08T14:21:58.687 回答