I posted this content once before, but it was a chronological list of items only, so this time I will summarize it a bit more thoroughly while deploying the “voting application” I created yesterday.
(Later, I moved the above application to digitalOcean.)
- Separate development and production environments
- local_settings.py
- Create an instance in vultr
- Install nginx, pip, venv
- Create src folder and Remote SSH
- git clone
- Virtual environment, upgrade, requirements.txt, nginx folder
- Used to set the “.env” environment variable and execute commands
- django.core.exceptions.ImproperlyConfigured: Set the SECRET_KEY environment variable
- The css is not reflecting!
- nginx restart
- Register server startup, shutdown, and restart with System Control.
Separate development and production environments
- Create a “.gitignore” file.
- Delete SECRET_KEY from “setting.py” and put it in “local_settings.py
- Set DEBUG to False for the production environment in “setting.py
- Add local settings to “setting.py
data:image/s3,"s3://crabby-images/d196c/d196ce60cd79ba50c432842e62604d5435cc789c" alt=""
local_settings.py
In the development environment, set DEBUG = True. Paste the SECRET_KEY you just cut from settings.py
data:image/s3,"s3://crabby-images/5395f/5395ff9abc2f640d6dc6d66f295a4b6d33b1326f" alt=""
Create an instance in vultr
- Create an account
- Ubuntu 18.04 -> deploy now
- SSH key and firewall are assigned from the pre-created ones.
How to make SSH connection on VPS(Vultr), from VPS startup to firewall setting.
Configuring the Vultr Firewall
data:image/s3,"s3://crabby-images/886fd/886fd83acd7176dbc0ae014cbb866b4fde58f9ad" alt=""
Create a user via SSH, grant administrative privileges, and once logged in as a user, update/upgrade to keep the environment up-to-date.
data:image/s3,"s3://crabby-images/5c94b/5c94b6b7cafbdbc7eff39351fa37ff7387f0d28c" alt=""
data:image/s3,"s3://crabby-images/8045a/8045a518b058c4c448700c35be7d9b231500dc83" alt=""
Install nginx, pip, venv
data:image/s3,"s3://crabby-images/56c10/56c10b8b102ab273cc607a65efbf3dcfcc89b6dc" alt=""
Create src folder and Remote SSH
After creating the “src” folder, connect to Remote SSH (Remote SSH: Connect to Host and use “ssh yamaco@xxx.xxx.xxx” to open the “src” folder you just created)
data:image/s3,"s3://crabby-images/9a31a/9a31abc35acc7777a0fca3297689a02bc932429c" alt=""
git clone
Copy the code from github and clone it to vultr
data:image/s3,"s3://crabby-images/b1156/b11568ab73b23408ff3c5c85b86a1b5da35c2820" alt=""
data:image/s3,"s3://crabby-images/1ae23/1ae2380b892a3d8f3d35ad4bbfbcab71e4c14ad6" alt=""
data:image/s3,"s3://crabby-images/7f9e1/7f9e1bc7c6b410f91071c7a6441ca9b49b52a34e" alt=""
Virtual environment, upgrade, requirements.txt, nginx folder
After building the virtual environment (python3 -m venv myvenv), enter myvenv and update to the latest commands (pip3 install -upgrade pip setuptools). Install “requirements.txt”. Create a folder for “nginx
data:image/s3,"s3://crabby-images/2af43/2af4378685b99ac9ac8f6eaaae4bee1fa7c7456b" alt=""
data:image/s3,"s3://crabby-images/00c67/00c67770e64df0232e671324ed86448bb4e1b8fd" alt=""
data:image/s3,"s3://crabby-images/963be/963be6cbd90bba15a817a3d1400860b5ea4d89d5" alt=""
Used to set the “.env” environment variable and execute commands
Both “SECRET_KEY” and “ALLOWED_HOSTS” do not need spaces before and after “=”. Also, ” ‘ ‘” should be deleted.
data:image/s3,"s3://crabby-images/ce698/ce698046cd39c271c2252371b31258e4f1b902d4" alt=""
django.core.exceptions.ImproperlyConfigured: Set the SECRET_KEY environment variable
I got an error with “python3 manage.py migrate”!
I looked closely and found that the “.env” file was directly under “src” and was the same as “polls”. I stored it in “polls” and successfully migrated!
data:image/s3,"s3://crabby-images/cd60d/cd60dae6cf059f11cfeeab40713b95867fd721bf" alt=""
data:image/s3,"s3://crabby-images/bfcbd/bfcbd3d92e39d43ad151f49a32cc97a0c01605ad" alt=""
The css is not reflecting!
When I started the server with “python3 manage.py runserver”, the navbar looked strange. The css is not reflected!
data:image/s3,"s3://crabby-images/8cf26/8cf264a8ab33f9cb6d4d36def2d7b4925c935fa9" alt=""
- 「sudo python3 manage.py collectstatic」=>131 static files copied to ‘/usr/share/nginx/html/static’.
- 「sudo nano /etc/nginx/sites-available/default」(Fixed nginx)
data:image/s3,"s3://crabby-images/b833b/b833b21f2287286afb69c1b2de8fcf7540cdb75c" alt=""
nginx restart
When I restarted nginx, I was able to successfully view the vultr IP address.
data:image/s3,"s3://crabby-images/2bc4d/2bc4d72c40923937d924251265a57741caf574d2" alt=""
data:image/s3,"s3://crabby-images/c4c36/c4c36860bdb0d93a541c5b3e61c1840c731fcd4b" alt=""
Register server startup, shutdown, and restart with System Control.
sudo nano /etc/systemd/system/poll_project.service
[Service]
WorkingDirectory=/home/yamco/src/poll_project
EcexStart=/home/yamaco/src/poll_project/myvenv/bin/bunicorn –bind 127.0.0.1:8000 poll_project.wsgi:application
- start the server:sudo systemctl start poll_project
- Status check:sudo systemctl statud poll_project
- stop the server:sudo systemctl stop poll_project
- restart the server:sudo systemctl restart poll_project
Get your Domein
I bought it before and had a domain I wasn’t using, so I set vultr on the name server.
data:image/s3,"s3://crabby-images/a55f1/a55f1ee5ff66bae60c1cb8bde60fd7d97761f5b7" alt=""
- Set DNS and domain on the vultr side as well
- Add the acquired domain to “ALLOWED_HOSTS” in the “.env” file
data:image/s3,"s3://crabby-images/bedcb/bedcbd11aa1d0ce3eb9ee6922a008c0cf38cde4e" alt=""
I was able to view it in the domain, but “no security protection”
data:image/s3,"s3://crabby-images/ef406/ef4063a28d05574c5f6c77520f354a3e39c96d99" alt=""
Make your site HTTPS
- sudo apt-get install letsencrypt
- sudo letsencrypt certonly –standalone -d ask946.info
- After rewriting nginx for Https (sudo nano / etc / nginx / sites-available / default), change the server to domain name
data:image/s3,"s3://crabby-images/54410/54410c4c498b4021f086e36e9d87e2255fd754cf" alt=""
Later, I moved this app to Digital Ocean. Click here for the finished product