Fase 3: carica l' WordPressapplicazione su Amazon S3 - AWS CodeDeploy

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

Fase 3: carica l' WordPressapplicazione su Amazon S3

Ora preparerai e caricherai i tuoi contenuti di origine in una posizione da cui CodeDeploy distribuirli. Le seguenti istruzioni mostrano come effettuare il provisioning di un bucket Amazon S3, preparare i file di revisione dell'applicazione per il bucket, raggruppare i file della revisione e quindi inserire la revisione nel bucket.

Nota

Sebbene non sia trattato in questo tutorial, puoi CodeDeploy utilizzarlo per distribuire applicazioni dai repository alle istanze. GitHub Per ulteriori informazioni, consulta Integrazione con CodeDeploy GitHub.

Esegui il provisioning di un bucket Amazon S3

Crea un contenitore o un bucket di storage in Amazon S3 o usa un bucket esistente. Assicurati di poter caricare la revisione nel bucket e che le istanze Amazon EC2 utilizzate nelle distribuzioni possano scaricare la revisione dal bucket.

Puoi usare la AWS CLI console Amazon S3 o le API Amazon S3 per creare un bucket Amazon S3. Dopo aver creato il bucket, assicurati di concedere le autorizzazioni di accesso al bucket e al tuo account. AWS

Nota

I nomi dei bucket devono essere univoci in Amazon S3 per AWS tutti gli account. Se non si è in grado di utilizzare codedeploydemobucket, provare un altro nome del bucket, ad esempio codedeploydemobucket seguito da un trattino e le iniziali o altri identificatori univoci. Assicurarsi quindi di sostituire il nome del bucket per codedeploydemobucket ovunque sia presente in questo tutorial.

Il bucket Amazon S3 deve essere creato nella stessa AWS regione in cui vengono lanciate le istanze Amazon EC2 di destinazione. Ad esempio, se crei il bucket nella regione Stati Uniti orientali (Virginia settentrionale), le istanze Amazon EC2 di destinazione devono essere avviate nella regione Stati Uniti orientali (Virginia settentrionale).

Per creare un bucket Amazon S3 (CLI)

Chiama il mb comando per creare un bucket Amazon S3 denominato: codedeploydemobucket

aws s3 mb s3://codedeploydemobucket --region region

Per creare un bucket Amazon S3 (console)

  1. Apri la console Amazon S3 all'indirizzo https://console.aws.amazon.com/s3/.

  2. Nella console Amazon S3, scegli Crea bucket.

  3. Nella casella Nome bucket, digitare un nome per il bucket.

  4. Nell'elenco Regione selezionare la regione di destinazione, quindi selezionare Crea.

Concedi le autorizzazioni al bucket e all'account Amazon S3 AWS

È necessario disporre delle autorizzazioni per il caricamento nel bucket Amazon S3. Puoi specificare queste autorizzazioni tramite una policy sui bucket di Amazon S3. Ad esempio, nella seguente policy sui bucket di Amazon S3, l'utilizzo del carattere wildcard (*) consente 111122223333 all' AWS account di caricare file in qualsiasi directory del bucket Amazon S3 denominata: codedeploydemobucket

{ "Statement": [ { "Action": [ "s3:PutObject" ], "Effect": "Allow", "Resource": "arn:aws:s3:::codedeploydemobucket/*", "Principal": { "AWS": [ "111122223333" ] } } ] }

Per visualizzare l'ID del tuo AWS account, consulta Finding Your account ID. AWS

Ora è il momento giusto per verificare che il bucket Amazon S3 consenta le richieste di download da ogni istanza Amazon EC2 partecipante. Puoi specificarlo tramite una policy sui bucket di Amazon S3. Ad esempio, nella seguente policy sui bucket di Amazon S3, l'utilizzo del carattere wildcard (*) consente a qualsiasi istanza Amazon EC2 con un profilo di istanza IAM allegato contenente l'ARN di scaricare file arn:aws:iam::444455556666:role/CodeDeployDemo da qualsiasi directory del bucket Amazon S3 denominata: codedeploydemobucket

{ "Statement": [ { "Action": [ "s3:Get*", "s3:List*" ], "Effect": "Allow", "Resource": "arn:aws:s3:::codedeploydemobucket/*", "Principal": { "AWS": [ "arn:aws:iam::444455556666:role/CodeDeployDemo" ] } } ] }

Per informazioni su come generare e allegare una bucket policy di Amazon S3, consulta Esempi di policy Bucket.

Per informazioni su come creare e allegare una policy IAM, consulta Working with policies.

Prepara i file dell'applicazione per il bucket

Assicurati che i file WordPress dell'applicazione, il AppSpec file e gli script siano organizzati sulla tua macchina di sviluppo in modo simile al seguente:

/tmp/ |--WordPress/ |-- appspec.yml |-- scripts/ | |-- change_permissions.sh | |-- create_test_db.sh | |-- install_dependencies.sh | |-- start_server.sh | |-- stop_server.sh |-- wp-admin/ | |-- (various files...) |-- wp-content/ | |-- (various files...) |-- wp-includes/ | |-- (various files...) |-- index.php |-- license.txt |-- readme.html |-- (various files ending with .php...)

Raggruppate i file dell'applicazione in un unico file di archivio e inviate il file di archivio

Raggruppa i file WordPress dell'applicazione e il AppSpec file in un file di archivio (noto come revisione dell'applicazione).

Nota

Potrebbero essere addebitati dei costi per lo storage degli oggetti in un bucket e per il trasferimento delle revisioni dell'applicazione dentro e fuori un bucket. Per ulteriori informazioni, consulta i Prezzi di Amazon S3.

  1. Sul computer di sviluppo, passare alla cartella in cui sono archiviati i file:

    cd /tmp/WordPress
    Nota

    Se non si passa a questa cartella, il raggruppamento dei file verrà avviato nella cartella corrente. Ad esempio, se la cartella corrente è /tmp invece di /tmp/WordPress, il raggruppamento verrà quindi avviato con i file e le sottocartelle presenti nella cartella tmp, che può includere più di una sottocartella WordPress.

  2. Chiamare il comando create-application per registrare una nuova applicazione denominata WordPress_App

    aws deploy create-application --application-name WordPress_App
  3. Richiama il comando CodeDeploy push per raggruppare i file, caricare le revisioni su Amazon S3 e registrare le informazioni CodeDeploy sulla revisione caricata, il tutto in un'unica operazione.

    aws deploy push \ --application-name WordPress_App \ --s3-location s3://codedeploydemobucket/WordPressApp.zip \ --ignore-hidden-files

    Questo comando raggruppa i file dalla directory corrente (esclusi i file nascosti) in un unico file di archivio denominatoWordPressApp.zip, carica la revisione nel codedeploydemobucket bucket e registra le informazioni sulla revisione caricata. CodeDeploy