Skip to main content

Command Palette

Search for a command to run...

Getting Started with Django: Basic Setup and Overview

Updated
4 min read
Getting Started with Django: Basic Setup and Overview
R
Backend Engineer with experience building and deploying scalable AI-powered applications for enterprise pharma clients. Strong in designing high-performance APIs and backend systems using Python, FastAPI, and Django, and integrating LLM/RAG pipelines using LangChain, Pinecone, and PostgreSQL for intelligent search and contextual responses. Comfortable working across the full stack of production systems — from database design and authentication (OAuth 2.0 / Microsoft SSO / Okta) to cloud deployment on AWS (EC2, ALB, ECR, S3, Aurora, CloudWatch). Experienced in improving reliability and observability using tools like Langfuse for LLM tracing and Keploy for automated API testing. Passionate about building real-world backend systems that power GenAI products, with a focus on scalability, security, and clean system design.

What is Django ?

  • A Python-based Web Framework designed for rapid development of efficient web applications.

  • It is also referred as "batteries included" framework because it provides built-in features for various aspects of web development these features include the Django admin interface, default data base management system (SQLite 3) and other streamlining development processes.

Why Django and not any other framework ?

  • First reason is Rapid Development, Django enables the creation of fully-fledged web applications in a short time.

  • Second reason is Database Flexibility, while SQLite 3 is the default database, Django allows easy switching to other databases like PostgreSQL, MySQL, and others.

  • Third reason is Built-in Admin Interface, it simplifies administrative tasks related to website management.

Django Architecture

  • Django follows the MVT Architecture, which stands for Model-View-Template, separating the logic of your application into three different components.

  • The Model in Django represents the data structure of our application, essentially defining the schema of our database tables and encapsulating the logic for interacting with the database.

  • The View is simply a Python function or class that receives HTTP requests and returns HTTP responses. It is responsible for processing incoming requests, interacting with the database through models, and preparing data to be rendered in a response.

  • Templates in Django are the HTML files that contain the structure of our application's user interface. They also include placeholders and template tags, which are replaced with dynamic content when rendered by Django.

Internal Working of MVT Architecture

  • The diagram illustrates Django's MVT architecture where the core project's urls.py directs requests to each app's urls.py. Inside each app, views.py processes the requests, interacts with models.py to manage data, and then renders responses using templates.

Before starting a Django project, it's recommended to use a virtual environment. This keeps all project-specific dependencies isolated from the system-wide environment.

Before starting a Django project, it's recommended to use a virtual environment. This keeps all project-specific dependencies isolated from the system-wide environment.

Python Environment Setup

  • Installation of python3 virtual environment.
sudo apt install python3-virtualenv
  • Create virtual environment in python3.
#virtualenv -p python3 <environment-name>
virtualenv -p python3 venv
  • Activate the created environment.
#source <environment-name>/bin/activate
source ecom/bin/activate
  • Deactivating the environment.
deactivate

Django Installation in Environment.

  • Django Installation in created python environment.
python -m pip install django
#Tip: Type `django-admin` on terminal you will see all the django commands.
django-admin

Django Project and App creation.

In Django we will first create a Project inside it we creates App.

  • Creation of Django-Project.
#django-admin startproject <project-name> .
django-admin startproject core .
  • Creation of app inside the project.
#python manage.py startapp <app-name>
python manage.py startapp store
  • After this we will install in our project.
#Go to <project-name>/settings.py inside check for Installed_Apps in which write your app name.
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    #custom-app
    'Store' 
]

  • In core/urls.py we will add include so that we can add new urls in it.
from django.contrib import admin
from django.urls import path,include

urlpatterns = [
    path('admin/', admin.site.urls),
    path(' ', include('store.urls')),
]
  • Here we will create an function in views.py which is used for handling user requests in the form of html file.
from djnago.shortcuts import render

def home(request):
    return render(request, 'home.html', {})
  • In the store app, we'll create a templates folder with an HTML file to verify that the request is being served correctly.

  • Now in store we will create urls.py which is going to maps URLs to view functions in views.py to handle requests and return responses.
from django.urls import path
from . import views

urlpatterns = [
    path(' ',views.home, name='home')
]
  • Run the server in the terminal to check the output of the HTML file on port 8000.
python manage.py runserver


Connect with me :

More from this blog

Backend

8 posts

This page will have all content related to backend engineering.