So after a number of lines of code, brilliance and dreaming. Your next dream is for the world to see. Of course you can walk around with your computer and doing a 'manage.py runserver' But cumon guys, lets embrace the cloud.
Not like this guy though! I choose to deploy on PythonAnywhere. So you ask why?
1) Free amazing support - You actually talk to a live human !
2) Easy - Very easy
3) Affordable - As you scale up, it gets way better!
So by now I assume you are already on a version control system (So I will not waste much energy on that one). Maybe Ill someday write on my two favs Github and Bitbucket.
STEP 1:
Create an account on pythonanywhere. Kindly note that your username will be included in your apps url. So it will be like :
STEP 2:
Select other and set a bash console.
STEP 3:
Push your code from version control
This will push from (in my example) github to your pythonanywhere. You will also do something similar with your version control system.
STEP 4:
Setup a virtual environment then do your dependencies.
STEP 5:
Now to link your uploaded code and libraries with pythonanywhere. Leave the consoles tab and head over to the web tab.
Add a new web app.
Select manual configuration and proceed to select your python distro.
Enter name of your virtual env
Enter source code directory.
One thing that's important here: your Django project (if you're using a recent version of Django) will have a file inside it called
Instead, the WSGI file to change is the one that has a link inside the "Code" section of the Web tab -- it will have a name something like
Click on the WSGI file link, and it will take you to an editor where you can change it.
Delete everything except the Django section and then uncomment that section.
Ensure to change the path variable and the DJANGO_SETTINGS_MODULE.
After this, go to bash, navigate to manage.py and migrate. If you go back to Web Tab and hit reload. You should see your site there. If not, there will be links to your logs and you can surely check as to why its happening.
STEP 6:
To serve static files open your settings.py and add this line:
STATIC_ROOT = os.path.join(BASE_DIR, "static")
Finally, set up a static files mapping to get our web servers to serve out your static files for you.
Not like this guy though! I choose to deploy on PythonAnywhere. So you ask why?
1) Free amazing support - You actually talk to a live human !
2) Easy - Very easy
3) Affordable - As you scale up, it gets way better!
So by now I assume you are already on a version control system (So I will not waste much energy on that one). Maybe Ill someday write on my two favs Github and Bitbucket.
STEP 1:
Create an account on pythonanywhere. Kindly note that your username will be included in your apps url. So it will be like :
"yourUsername.pythonanywhere.com"
Select other and set a bash console.
STEP 3:
Push your code from version control
This will push from (in my example) github to your pythonanywhere. You will also do something similar with your version control system.
STEP 4:
Setup a virtual environment then do your dependencies.
STEP 5:
Now to link your uploaded code and libraries with pythonanywhere. Leave the consoles tab and head over to the web tab.
Add a new web app.
Select manual configuration and proceed to select your python distro.
Enter name of your virtual env
Enter source code directory.
One thing that's important here: your Django project (if you're using a recent version of Django) will have a file inside it called
wsgi.py
. This is not the one you need to change to set things up on PythonAnywhere -- the system here ignores that file.Instead, the WSGI file to change is the one that has a link inside the "Code" section of the Web tab -- it will have a name something like
/var/www/yourusername_pythonanywhere_com_wsgi.py
or /var/www/www_yourdomain_com_wsgi.py
.Click on the WSGI file link, and it will take you to an editor where you can change it.
Delete everything except the Django section and then uncomment that section.
Ensure to change the path variable and the DJANGO_SETTINGS_MODULE.
After this, go to bash, navigate to manage.py and migrate. If you go back to Web Tab and hit reload. You should see your site there. If not, there will be links to your logs and you can surely check as to why its happening.
STEP 6:
To serve static files open your settings.py and add this line:
STATIC_ROOT = os.path.join(BASE_DIR, "static")
Proceed to bash again and do a manage.py collectstatic.
Finally, set up a static files mapping to get our web servers to serve out your static files for you.
- Go to the Web tab on the PythonAnywhere dashboard
- Go to the Static Files section
- Enter the same URL as
STATIC_URL
in the url section (typically,/static/
) - Enter the path from
STATIC_ROOT
into the path section (the full path, including/home/username/etc
)
Amazing experience on reading your article. It is really nice and informative.
ReplyDeletePython Training in Chennai
Python Training in Anna Nagar
JAVA Training in Chennai
Hadoop Training in Chennai
Selenium Training in Chennai
Python Training in Chennai
Python Training in Velachery