Last active
February 25, 2020 10:00
-
-
Save ashishkharcheiu/b728b10c91d78b6f183c2c5cdf16e5ad to your computer and use it in GitHub Desktop.
DigitalOcean Django Postgres Nginx unicorn ubuntu 18.0.4
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| https://www.digitalocean.com/community/tutorials/how-to-set-up-django-with-postgres-nginx-and-gunicorn-on-ubuntu-18-04 | |
| https://www.digitalocean.com/community/tutorials/how-to-install-the-django-web-framework-on-ubuntu-18-04 | |
| https://www.digitalocean.com/community/tutorials/initial-server-setup-with-ubuntu-18-04 | |
| https://www.digitalocean.com/community/tutorials/how-to-secure-nginx-with-let-s-encrypt-on-ubuntu-18-04 | |
| https://www.digitalocean.com/community/tutorials/how-to-set-up-object-storage-with-django | |
| Prerequisites: | |
| - MobaXTerm | |
| - DigitalOcean Account | |
| Steps: | |
| - Create a Droplet [ubuntu, 5usd, enable backup, datacenter = Bangalore, authentication = one-time password (later we will enable ssh auth) | |
| - Copy IP address generated by DigitalOcean. | |
| - Check email send by DigitalOcean | |
| - Go to MobaXterm --> session --> ssh --> paste the IP address in "Remote host" field, username = root --> Click OK | |
| - Copy password from email --> paste in MobaXterm terminal after root@ipadress password: | |
| - Paste again the same password in [current] UNIX password | |
| - Enter new password | |
| - Close tab and reopen | |
| https://www.digitalocean.com/community/tutorials/initial-server-setup-with-ubuntu-18-04 | |
| - after root@hostname:# --> adduser sammy | |
| - enter password | |
| - provide permissions --> usermod -aG sudo sammy | |
| - Open CMD --> ssh-keygen --> rename files to `sammy` in .ssh folder --> repeat same process for `root` user | |
| - Copy root.pub key --> in MobaXterm --> go to /root/.ssh/authorized_keys --> edit and paste | |
| - Copy mitch.pub key --> in MobaXterm --> go to /home/mitch/.ssh/authorized_keys --> edit and paste (might need to create .ssh and authorized_keys manually) | |
| - open CMD --> ssh sammy@ipaddress --> test login | |
| - open MobaXterm --> session --> ssh --> Remote host = ipadderss --> username = sammy --> advanced SSH settings --> enable "User private key" --> find/browser for sammy PUBLIC key --> Click OK | |
| - now under user sessions --> edit session for root ipaddress and repeat the above setp while selecting root PUBLIC key --> Click OK | |
| - in MobaXterm terminal after root@hostname: --> sudo nano /etc/ssh/sshd_config --> set "PasswordAuthentication" to no --> save the file and exit | |
| - sudo ufw app list | |
| - sudo ufw allow openssh | |
| - sudo ufw enable | |
| - sudo ufw status | |
| - sudo apt update | |
| - sudo apt install python3.7 | |
| - python3.7 --> to check shell --> exit() | |
| - sudo update -alternatives --install /usr/bin/python python /usr/bin/python3.6 2 | |
| - sudo update -alternatives --install /usr/bin/python python /usr/bin/python3.7 1 | |
| - sudo update-alternatives --config python | |
| - set selection to "python3.7" number | |
| - sudo apt-get install -y python3-pip | |
| - pip3 --> to check | |
| - sudo -H pip3 install virtualenv | |
| - cd /home/sammy | |
| - mkdir djangoprojectdir | |
| - cd djangoprojectdir | |
| [Inside /djangoprojectdir] | |
| - virtualenv djangoprojectenv | |
| - source djangoprojectenv/bin/activate | |
| - pip3 install gunicorn | |
| - pip3 install django==2.2.2 | |
| - cd .. | |
| [Inside /sammy] | |
| - django-admin startproject mysite djangoprojectdir | |
| - Edit settings.py --> ALLOWED_HOSTS = localhost, ipaddress --> add OUR apps to INSTALLED_APPS --> then add line AUTH_USER_MODEL = 'account.Account' --> TEMPLATES -> DIRS add os path --> COPY STATIC FILES CODE below from our local to settings.py | |
| - Drag all `app` [account, blog, personal, templates, requirements] folders from local to /djangoprojectdir in MobaXterm | |
| - Drag urls.py from local to MobaXterm and remove MEDIA root code from below | |
| - Create new dir "static" and drag logo from local "static" to MobaXterm "static" | |
| - cd djangoprojectdir | |
| [Inside /djangoprojectdir] | |
| - pip3 install -r requirements.txt | |
| - python manage.py makemigrations | |
| - python manage.py migrate | |
| - python manage.py collectstatic | |
| - sudo ufw allow 8000 | |
| - python manage.py runserver 0.0.0.0:8000 | |
| - Check ipaddress:8000 in browser | |
| - gunicorn --bind 0.0.0.0:8000 mysite.wsgi | |
| https://www.digitalocean.com/community/tutorials/how-to-set-up-django-with-postgres-nginx-and-gunicorn-on-ubuntu-18-04 | |
| - deactivate [deactivates virtualenv] | |
| - pip3 install -r requirements.txt + pip3 install gunicorn | |
| - In MobaXterm sidebar FTP --> go to /etc/systemd/system --> create file 'gunicorn.socket' --> paste the code from digitalocean docs | |
| - In MobaXterm sidebar FTP --> go to /etc/systemd/system --> create file 'gunicorn.service' --> paste the code from digitalocean docs --> make appropriate changes --> "mysite.wssgi", user, dir, env... | |
| - sudo systemctl start gunicorn.socket | |
| - sudo systemctl enable gunicorn.socket | |
| - file /run/gunicorn.sock | |
| - sudo systemctl status gunicorn.socket | |
| [If error --> sudo shutdown -r now] | |
| - curl --unix-socket /run/gunicorn.sock localhost --> should get HTML file syntax | |
| [If change gunicorn service file --> either shutdown server by sudo shutdown -r now or do --> sudo systemctl daemon-reload --> sudo systemctl restart gunicorn.socket gunicorn.service] | |
| - sudo systemctl status gunicorn | |
| - sudo apt install nginx | |
| - go to /etc/nginx/sites-available --> create new file "djangoproject" --> paste digitalocean docs code --> add ipaddress and change "root" path | |
| - sudo ln -s /etc/nginx/sites-available/djangoproject /etc/nginx/sites-enabled | |
| - sudo nginx -t | |
| - sudo systemctl restart nginx | |
| - sudo ufw delete allow 8000 | |
| - sudo ufw allow 'Nginx Full' | |
| - Go to browser and paste ipaddress --> check | |
| - 2 --------------------------------------------------------------------------- | |
| - In DigitalOcean --> Create Domain/DNS --> enter domain 'hello.com' | |
| - In Hostname add "@" --> 3600 --> create record | |
| - In Hostname add "www" --> 3600 --> create record | |
| - Namecheap --> Manage --> add Nameservers --> ns1.digitalocean.com --> ns2 and ns3 | |
| - In MobaXterm --> settings.py --> add domain with and without "www" both to ALLOWED_HOSTS | |
| - service gunicorn restart | |
| - go to /etc/nginx/sites-available/djangoproject --> edit file djangoproject --> add domain name to server_name without comma seperation. Add both www and simple version domain name | |
| - sudo systemctl restart nginx | |
| - sudo systemctl status gunicorn.service | |
| - go to domain name eg. hello.com in incognito mode --> check | |
| [If error --> sudo shutdown -r now or /sites-available --> copy contents of 'default' file safely, delete the file and create again] | |
| - 3 --------------------------------------------------------------------------- | |
| https://www.digitalocean.com/community/tutorials/how-to-secure-nginx-with-let-s-encrypt-on-ubuntu-18-04 | |
| - sudo add-apt repository ppa:certbot/certbot | |
| - sudo apt install python-certbot-nginx | |
| - sudo nano /etc/nginx/sites-available/djangoproject | |
| - sudo ufw status | |
| - sudo certbot --nginx -d hello.com -d www.hello.com | |
| - enter email | |
| - choose 2 | |
| - sudo certbot renew --dry-run | |
| [If error --> sudo ufw allow https , sudo ufw delete allow '443/tcp' or check the number 442/443] | |
| - 4 --------------------------------------------------------------------------- | |
| https://www.digitalocean.com/community/tutorials/how-to-set-up-object-storage-with-django | |
| - In DigitalOcean --> Create Spaces --> datacenter --> restrict file listing --> hello-space --> create a space | |
| - Create New Folder in space named "hello-static" | |
| - Go to API section in left side bar --> Generate Key --> Name = hello-space-key --> Secure Secret and hello-static-key | |
| - In MobaXterm --> pip3 install boto3 --> pip3 install django-storages [Do in virtual env] | |
| - Delete static_cdn folder | |
| - In settings.py --> add storages to INSTALLED_APPS --> configure AWS keys and all below settings.py | |
| - cd /home/sammy/djangoprojectdir | |
| [Inside /djangoprojectdir] | |
| - source djangoprojectenv/bin/activate | |
| - pip3 install boto3 | |
| - pip3 install django-storages | |
| - python manage.py collectstatic | |
| - sudo nano /etc/nginx/sites-available/djangoproject --> change "root" to "alias" --> save | |
| - sudo shutdown -r now | |
| - wait 20 sec | |
| - relogin | |
| - python manage.py createsuperuser | |
| - cd .. | |
| [Inside /sammy] | |
| - chown sammy djangoprojectdir/ | |
| cd djangoprojectdir | |
| [Inside /djangoprojectdir] | |
| - chown sammy db.sqlite3 [If you are using sqlite3] | |
| - ls -l --> to check | |
| - pip3 install python-decouple | |
| - Create new file in /djangoprojectdir "settings.ini" --> make releveant changes | |
| - make appopriate changes in "settings.py" | |
| [If secret key of django in settings.ini has % then concatenate another "%%" | |
| - service gunicorn restart | |
| - 5 --------------------------------------------------------------------------- | |
| - Google Account --> myaccount.google.com --> security --> enable 2-Step verification --> Create App passwords --> other --> any name --> generate | |
| - Add email Backend code in settings.py and make relevant changes | |
| - service gunicorn restart |
Author
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Django Deployment to Ubuntu 18.04
In this guide I will go through all the steps to create a VPS, secure it and deploy a Django application. This is a summarized document from this digital ocean doc
Any commands with "$" at the beginning run on your local machine and any "#" run when logged into the server
Create A Digital Ocean Droplet
Use this link and get $10 free. Just select the $5 plan unless this a production app.
Security & Access
Creating SSH keys (Optional)
You can choose to create SSH keys to login if you want. If not, you will get the password sent to your email to login via SSH
To generate a key on your local machine
Hit enter all the way through and it will create a public and private key at
You want to copy the public key (.pub file)
Copy the entire output and add as an SSH key for Digital Ocean
Login To Your Server
If you setup SSH keys correctly the command below will let you right in. If you did not use SSH keys, it will ask for a password. This is the one that was mailed to you
Create a new user
It will ask for a password, use something secure. You can just hit enter through all the fields. I used the user "djangoadmin" but you can use anything
Give root privileges
SSH keys for the new user
Now we need to setup SSH keys for the new user. You will need to get them from your local machine
Exit the server
You need to copy the key from your local machine so either exit or open a new terminal
You can generate a different key if you want but we will use the same one so lets output it, select it and copy it
Log back into the server
Add SSH key for new user
Navigate to the new users home folder and create a file at '.ssh/authorized_keys' and paste in the key
Login as new user
You should now get let in as the new user
Disable root login
Change the following
Reload sshd service
Simple Firewall Setup
See which apps are registered with the firewall
Allow OpenSSH
Enable firewall
To check status
We are now done with access and security and will move on to installing software
Software
Update packages
Install Python 3, Postgres & NGINX
Postgres Database & User Setup
You should now be logged into the pg shell
Create a database
Create user
Set default encoding, tansaction isolation scheme (Recommended from Django)
Give User access to database
Quit out of Postgres
Vitrual Environment
You need to install the python3-venv package
Create project directory
Create venv
Activate the environment
Git & Upload
Pip dependencies
From your local machine, create a requirements.txt with your app dependencies. Make sure you push this to your repo
Create a new repo and push to it (you guys know how to do that)
Clone the project into the app folder on your server (Either HTTPS or setup SSH keys)
Install pip modules from requirements
You could manually install each one as well
Local Settings Setup
Add code to your settings.py file and push to server
Create a file called local_settings.py on your server along side of settings.py and add the following
Run Migrations
Create super user
Create static files
Create exception for port 8000
Run Server
Test the site at YOUR_SERVER_IP:8000
Add some data in the admin area
Gunicorn Setup
Install gunicorn
Add to requirements.txt
Test Gunicorn serve
Your images, etc will be gone
Stop server & deactivate virtual env
Open gunicorn.socket file
Copy this code, paste it in and save
Open gunicorn.service file
Copy this code, paste it in and save
Start and enable Gunicorn socket
Check status of guinicorn
Check the existence of gunicorn.sock
NGINX Setup
Create project folder
Copy this code and paste into the file
Enable the file by linking to the sites-enabled dir
Test NGINX config
Restart NGINX
Remove port 8000 from firewall and open up our firewall to allow normal traffic on port 80
You will probably need to up the max upload size to be able to create listings with images
Open up the nginx conf file
Add this to the http{} area
Reload NGINX
Media File Issue
You may have some issues with images not showing up. I would suggest, deleting all data and starting fresh as well as removeing the "photos" folder in the "media folder"
Domain Setup
Go to your domain registrar and create the following a record
Go to local_settings.py on the server and change "ALLOWED_HOSTS" to include the domain
Edit /etc/nginx/sites-available/btre_project
Reload NGINX & Gunicorn