Piethein Strengholt (2017)
An example template for deploying Laravel applications with AWS CodePipeline across an autoscaling group. For more information see this tutorial: http://docs.aws.amazon.com/codepipeline/latest/userguide/getting-started-w.html
The deploy_laravel script takes care of the Laravel deployment. You might want to replace the git url with your own url. Additionally you might want to replace the sed arguments used to configure the environment script. At the moment it is not possible to make these arguments dynamic (see below).
Currently it is not possible to pass AWS variables into buildspec.yml from CodePipeline. See more info: https://stackoverflow.com/questions/41704517/aws-pass-in-variable-into-buildspec-yml-from-codepipeline
As an alternative you can consider the JSON snippet below for your CloudFormation script. The DBHost, DBName, DBUsername and DBPassword varables refer to your database parameters, which should also be defined in your CloudFormation script.
"files" : {
"/var/www/.env" : {
"content" : { "Fn::Join" : ["", [
"APP_ENV=local\n",
"APP_DEBUG=true\n",
"APP_KEY=base64:l6kg/jw8Bk1c70FztrJfhXz9mqocYp+aHT1F7JahjxQ=\n",
"\n",
"APP_URL=http://localhost\n",
"SESSION_DOMAIN=localhost\n",
"\n",
"DB_CONNECTION=mysql\n",
"DB_HOST=", { "Ref" : "DBHost" }, "\n",
"DB_PORT=3306\n",
"DB_DATABASE=", { "Ref" : "DBName" }, "\n",
"DB_USERNAME=", { "Ref" : "DBUsername" }, "\n",
"DB_PASSWORD=", { "Ref" : "DBPassword" }, "\n",
"\n",
"CACHE_DRIVER=file\n",
"SESSION_DRIVER=database\n",
"QUEUE_DRIVER=sync\n"
]]},
"mode" : "000644",
"owner" : "root",
"group" : "root"
}
}
If you want to clone a private repository and want to use a deploy key you can consider doing the following. Type the following command:
ssh-keygen -t rsa -C "your_email@youremail.com"
This will generate a public and a private key. It is best to not type a password, since we don't want to interrupt the deployment process. Add the public key to your GitHub Deploy keys section under settings. The private key should be packaged and added to the appspec.yml file and used during the deployment. See more information here: http://docs.aws.amazon.com/codedeploy/latest/userguide/reference-appspec-file-structure-files.html
Next step is the following commands. This will start the ssh-agent, trust github and import the private key for your project. You might want to change the location of the rsa file and need to type in your github repository location.
eval `ssh-agent -s`
echo -e "Host github.com\n\tStrictHostKeyChecking no\n" >> ~/.ssh/config
ssh-agent bash -c 'ssh-add /root/id_rsa_file; git clone https://github.com:user/project.git'
When using the steps above, the deployment will automatically run.
Make sure the EC2 instances have access to the AutoScaling API. You can achieve this by adding the following policy:
{
"Statement": [
{
"Effect": "Allow",
"Action": [
"autoscaling:Describe*",
"autoscaling:EnterStandby",
"autoscaling:ExitStandby",
"cloudformation:Describe*",
"cloudformation:GetTemplate",
"s3:Get*"
],
"Resource": "*"
}
]
}
See more information here: https://aws.amazon.com/blogs/devops/use-aws-codedeploy-to-deploy-to-amazon-ec2-instances-behind-an-elastic-load-balancer-2/