AWS Elastic Beanstalk 上の ATOP デプロイメント用の設定ファイル

AWS Elastic Beanstalk 上の ATOP デプロイメント用の設定ファイル

解決済み マシンが Beanstalk からデプロイされるときに、EC2 インスタンスに ATOP をインストールする必要があります。AWS サポートには、以下のリンクしかありませんでしたが、ebextensions 構成ファイルでデプロイする方法は示されていません。すでにこれを実行していて、構成ファイルを作成している人はいますか? ありがとうございます! -->https://www.tecmint.com/how-to-install-atop-to-monitor-logging-activity-of-linux-system-processes/

{{編集 3/23/18}}

これまで自分で作業した結果、これができました。完全には機能していませんが、まだ作業中です。

packages:
  rpm:
    epel: https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm

container_commands:
  1_rpm_atop:
    command: "sudo /bin/rpm -i --replacepkgs 
https://www.atoptool.nl/download/atop-2.3.0-1.el6.x86_64.rpm"
  2_add_atop:
    command: "/sbin/chkconfig --add atop"
    leader_only: true
  3_add_atop:
    command: "/sbin/chkconfig atop on --level 235"
    leader_only: true
  4_config_atop:
    command: "/bin/sed 's/600/60/' /usr/share/atop/atop.daily -i"
    leader_only: true
  5_link:
    command: "/bin/ln -sfn /var/log/atop /var/app/current/wp-content/uploads/atop"
    leader_only: true
  6_start:
    command: "/etc/init.d/atop start"
    leader_only: true

答え1

AWS Beanstalk テクニカル サポートの素晴らしい Yao の助けにより、すべてのインスタンスに ATOP をインストールするファイルを作成することができました。また、個々のインスタンス ログを既存のシンボリック リンクされた EFS ファイル ディレクトリに書き込むことで、スケーリングやマシンのデプロイメントを通じてログが保持されるようにします。これは現在、私の開発デプロイメントで機能しています。他に何も聞こえない場合は、約 1 週間以内に本番環境でも機能することになります。Wordpress デプロイメント用に調整した内容は次のとおりです。お楽しみください。

container_commands:
  1_install_config_atop:
    command: /tmp/installatop.sh

files:
  "/tmp/installatop.sh":
      mode: "000755"
      content : |
        #!/bin/bash

    #############################################


    ATOPLOGDEST=/var/app/current/wp-content/uploads/atop/   #where to persist the atop log
    LOGFILE=/tmp/atopinstall.log #installaton log

    ##############################################
    INSTANCEID=$(curl http://169.254.169.254/latest/meta-data/instance-id/)

    exec 1>&- # close stdout
    exec 2>&- # close stderr

    echo "========" >> $LOGFILE
    date >> $LOGFILE
    echo "starting" >> $LOGFILE

    echo "---- Step 1, install atop" >> $LOGFILE
    echo "check if atop is installed" >> $LOGFILE
    rpm -q atop >> $LOGFILE
    if [ $? -ne 0 ]
    then
      echo "atop not installed yet" >> $LOGFILE
      rpm -i https://www.atoptool.nl/download/atop-2.3.0-1.el6.x86_64.rpm
      rpm -q atop >> $LOGFILE
      echo "now installed" >> $LOGFILE
    fi

    echo "---- step 2, config atop in chkconfig" >> $LOGFILE
    /sbin/chkconfig --add atop
    /sbin/chkconfig atop on --level 235
    echo "this is the output of chkconfig"  >> $LOGFILE
    /sbin/chkconfig | grep atop >> $LOGFILE

    echo "---- setp 3, config atop's schedule to 60 seconds" >> $LOGFILE
    /bin/sed 's/600/60/' /usr/share/atop/atop.daily -i
    cat /usr/share/atop/atop.daily | grep "INTERVAL=" >> $LOGFILE

    echo "---- step 4, presistent it in EFS" >> $LOGFILE
    mkdir -p $ATOPLOGDEST$INSTANCEID
    /bin/sed "s|/var/log/atop|$ATOPLOGDEST$INSTANCEID|" /usr/share/atop/atop.daily -i
    cat /usr/share/atop/atop.daily | grep "LOGPATH=" >> $LOGFILE
    stat $ATOPLOGDEST$INSTANCEID >> $LOGFILE

    echo "---- step 5, restart atop" >> $LOGFILE
    /etc/init.d/atop restart
    sleep 5
    ps aux | grep atop >> $LOGFILE

    echo "---- finished!" >> $LOGFILE
    date >> $LOGFILE
    echo "========" >> $LOGFILE

答え2

確信はありませんが、AWS インスタンス CLI からその curl URL を実行すると、呼び出し元のインスタンス ID が返されると思います。これを使用する方法の 1 つは、インスタンス ID をフォルダー名としてログ ディレクトリを作成し、ATOP を実行するインスタンスごとにログに記録して取得できるようにすることです。

関連情報