Here is what i did to Set up a laravel Project in Digital Ocean
Login Digital Ocean
Add Droplet
1 Click Install docker
Choose Droplet
reset ROOT password
check email
ssh root@ipaddress
you will be prompt of that password. type the password you receive in your email
then it will ask to you to change a new password just change it to the custom root password you want
After SSH you can check that docker command is working by typing
$root@midascode:~# docker
$root@midascode:~# apt-get install git
$root@midascode:~# git clone https://github.com/laravel/laravel
$root@midascode:~# cd laravel
$root@midascode:~/laravel# git checkout develop
$root@midascode:~/laravel/ git submodule add https://github.com/LaraDock/laradock.git
$root@midascode:~/laravel/ cd laradock
$root@midascode:~/laravel/laradock# curl -L https://github.com/docker/compose/releases/download/1.8.0/run.sh > /usr/local/bin/docker-compose
$root@midascode:~/chmod +x /usr/local/bin/docker-compose
$root@midascode:~/laravel/laradock# docker-compose up -d nginx mysql
docker-compose exec workspace bash
$ root@0e77851d27d3:/var/www/laravel# composer install
$ root@0e77851d27d3:/var/www/laravel# cp .env.example .env
$ root@0e77851d27d3:/var/www/laravel# php artisan key:generate
$ root@0e77851d27d3:/var/www/laravel# exit
$root@midascode:~/laravel/laradock# cd ..
$root@midascode:~/laravel# sudo chmod -R 777 storage bootstrap/cache
you can then view your laravel site at your ipaddress for example
192.168.1.1
You will see there Laravel Default Welcome Page
but if you need to view on your custom domain name which you would.
login to your DNS provider Godaddy, Namecheap what ever... And Point the Custom Domain Name Server to
ns1.digitalocean.com
ns2.digitalocean.com
ns3.digitalocean.com
In Your Digital Ocean Account go to
https://cloud.digitalocean.com/networking/domains
add your domain name and choose the server ip you provision earlier
Go back to command line
$root@midascode:~/laravel/laradock# cd nginx
$root@midascode:~/laravel/laradock/nginx# vim laravel.conf
remove default_server
listen 80 default_server;
listen [::]:80 default_server ipv6only=on;
and add server_name (your custom domain)
listen 80;
listen [::]:80 ipv6only=on;
server_name yourdomain.com;
$root@midascode:~/laravel/laradock/nginx# docker-compose down
$root@midascode:~/laravel/laradock/nginx# docker-compose build nginx
$root@midascode:~/laravel/laradock/nginx# docker-compose up -d nginx mysql
View Your Site with HTTP ONLY (http://yourdomain.com)
$root@midascode:~/laravel/laradock# cd caddy
$root@midascode:~/laravel/laradock/caddy# vim Caddyfile
Remove 0.0.0.0:80
0.0.0.0:80
root /var/www/laravel/public
and replace with your https://yourdomain.com
https://yourdomain.com
root /var/www/laravel/public
uncomment tls
#tls self-signed
and replace self-signed with your email address
tls [email protected]
This is needed Prior to Creating Let's Encypt
$root@midascode:~/laravel/laradock/caddy# docker-compose up caddy
you will be prompt here to enter your email... you may enter it or not
Attaching to laradock_mysql_1, laradock_caddy_1
caddy_1 | Activating privacy features...
caddy_1 | Your sites will be served over HTTPS automatically using Let's Encrypt.
caddy_1 | By continuing, you agree to the Let's Encrypt Subscriber Agreement at:
caddy_1 | https://letsencrypt.org/documents/LE-SA-v1.0.1-July-27-2015.pdf
caddy_1 | Activating privacy features... done.
caddy_1 | https://yourdomain.com
caddy_1 | http://yourdomain.com
After it finish Press Ctrl + C to exit ...
$root@midascode:~/laravel/laradock/caddy# docker-compose down
$root@midascode:~/laravel/laradock/caddy# docker-compose up -d mysql caddy
View your Site in the Browser Securely Using HTTPS (https://yourdomain.com)
https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-on-ubuntu-16-04 https://www.digitalocean.com/products/one-click-apps/docker/ https://docs.docker.com/engine/installation/linux/ubuntulinux/ https://docs.docker.com/compose/install/ https://caddyserver.com/docs/automatic-https https://caddyserver.com/docs/tls https://caddyserver.com/docs/caddyfile