コンテンツ配信のためにEC2 WebサーバーからS3バケットにファイルをアップロードするデフォルトの方法は何ですか?
答えは目的によってかなり異なります。たとえば、EC2インスタンスがPHPアプリケーションを実行している場合、PHP-SDKを使用するのが最善のルートです。S3バケットをローカルファイルとしてマウントすると便利なアプリケーションもあります。システム(S3-Fuseなど)。
ただし、シェルを介してEC2からS3にファイルをアップロードするだけの場合は、 Tim Kayのaws スクリプトをお勧めします。これは、インストールなしで実行できる、またはエイリアス機能をセットアップするためにインストールできる自己完結型のPerlスクリプトです。このスクリプトを使用してファイルを既存のバケットにアップロードすると、次のようになります。
s3put bucket_name/filename.ext /path/to/local/file/name.ext
AWSのほとんどの機能をサポートしており、エラーメッセージが十分に詳細であるため、問題のデバッグがかなり簡単になります。
S3への直接アップロードを説明する簡単な例を次に示します
http://sente.cc/upload_to_s3.html
コード:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body>
<h3>refresh the page after you've submitted to see your new image</h3>
<div style="width:300px">
<form action="http://s3.amazonaws.com/dev.sente" method="post" enctype="multipart/form-data">
<fieldset>
<input type="hidden" name="acl" value="public-read" /> <br />
<i>name of key:</i><input type="text" name="key" readonly="true" value="image.jpg" /> <br />
<input name="file" type="file" /> <br />
<input name="submit" value="Upload" type="submit" />
</fieldset>
</form>
</div>
<br>
<a href="http://s3.amazonaws.com/dev.sente/image.jpg">http://s3.amazonaws.com/dev.sente/image.jpg</a>
<br>
<a href="http://s3.amazonaws.com/dev.sente/image.jpg"><img src="http://s3.amazonaws.com/dev.sente/image.jpg"></a>
</a>
</body>
</html>
同様の質問への私の回答からコピーされました- ここ
S3cpツールを使用できます。 scpコマンドに似ています。ダウンロードとドキュメントについては、 http://www.beaconhill.com/opensource/s3cp.html および http://aws.Amazon.com/code/Java/3124 を参照してください。 =
インストール後、たとえばS3にコピーできます:s3cp local-file s3:// bucket/object [/]
一般に、そのアプリケーションで使用するCDNをセットアップする目的でアプリケーションからS3にファイルをアップロードする場合は、最初にそのアプリケーションにその機能またはプラグインがまだないかどうかを確認します。 。たとえば Wordpress を使用する場合、これを非常に適切に処理する W3 Total Cache プラグインがあります。もちろん、PHPで記述されており、AWS API呼び出しを使用して、必要に応じてアップロード/削除を処理します。
独自のアプリケーションを作成している場合は、AWSとの通信を支援するライブラリを探します。 Pythonの場合、たとえば Boto を確認すると、AWS APIとシームレスに対話できます。同様に、いつでもチェックアウトできます Amazon 使用できる他のSDK APIについては、それ自体を参照してください。
HTTP経由で、他の場所からS3にアップロードするのと同じ方法です。