Django 입문, 한줄한줄 따라하기!! (1)
나는 인공지능 개발자다. 맨날 pytorch로 자연어처리, GAN 모델들만 개발해왔다.
근데 정작 이모델들을 서비스하려고 하면 어?? 어쩌지??? 하면서 전혀 감이 안 왔다.
내가 할 줄 아는 거라고는 문장/이미지를 입력으로 줬을 때 json 포맷의 결과뿐이니까
물론 인공지능 개발팀과 서비스팀이 각각 존재해야 하는 게 맞다.
그러나..... 현실은따로 서비스팀이 없기 때문에 직접 해봐야겠다 싶어 시작했는데 헬게이트가 열렸다.....
웹/앱/서버에 대한 지식이 없이 뭐부터 해야 하는지 전혀 감이 안 왔다.
그래서 이래저래 많이 알아보다 보니
React/Bootstrap 등등으로 Front-end를 만들고
서버에 Flask or Django로 Back-end를 구축하고 웹을 연결하고 등등 어마 무시한 일이 있다는 걸 알았다!!!!!!
또 Flask나 Django도 비동기, 멀티스레드/프로세스를 하려면 Gunicorn, Celery, Nginx 등등 주렁주렁 달아야 할게 많았다.
어디서부터 뭘 시작해야 하나 갑갑해하다가 https://www.youtube.com/playlist?list=PLvX6vpRszMkwECdbxNX8s9R-vcUFGqqtC 에서웹을 만들고 사진을 업로드 후 opencv로 처리해서 다시 보여주는 강좌가 있었다.
이걸 따라 해보려 한다. 근데 장고에 대해 알고 가기 위해 공부를 시작했다!
Django!!!
장고 교육자료 : tutorial.djangogirls.org와 https://developer.mozilla.org/ko/docs/Learn/Server-side/Django/Introduction 에 장고 교육자료가 좋다. 최고!! 이 튜토리얼을 한줄한줄 따라 해 보겠다ㅎㅎ
Django(장고)는 파이썬으로 100% 작성된 web framework이다. 아래는 장고 영화 포스터다 ㅎㅎ
보안이 우수하고 유지보수가 편리한 웹사이트를 빠르게 개발할 수 있도록 도와주는 웹 프레임워크다.
무료 오픈소스고 커뮤니티가 활발하여 참고할 수 있는 자료가 많다. 신문 웹사이트를 만들던 팀이 여러 사이트들을 만들면서 계속 공통 코드와 설계를 반복하다가 이거 이거 안 되겠는데? 하고 만들어졌다고 한다.
Django의 구조 : MVT(Model View Template)
장고는 Model, View, Template로 구성되며 아래와 같다. 예시를 들며 설명했는데 진지하게 파고들진 말자 ㅎㅎ
1. 웹사이트의 웹 애플리케이션은 외부(웹브라우저, 클라이언트)로 부터 HTTP 요청(request)을 기다리고 있다.
- 백화점 안내데스크에서 손님을 기다리고 있듯이
2. URLs : 요청을 알맞은 view에 보낸다(urls.py)
- 손님이 와서 뭐라 뭐라 얘기하면 무엇을 원하는지 이해하는 과정
- 요청(Request)을 받으면 웹 애플리케이션은 URL의 POST/GET 데이터로 요구사항을 알아낸다.
- URL mapper는 요청 URL을 기준으로 HTTP 요청을 적절한 view로 보내준다.
- urls.py에 저장, 아래와 같이 조건에 맞는 URL 패턴과 일치하는 HTTP 요청이 들어오면 View 함수에 요청을 전달
urlpatterns = [
path('admin/', admin.site.urls),
path('book/<int:id>/', views.book_detail, name='book_detail'),
path('catalog/', include('catalog.urls')),
re_path(r'^([0-9]+)/$', views.best),
]
3. View : 요청을 처리한다(views.py)
- 손님이 문의한 내용을 알아본다.
- 요청을 이해한 후 DB에 정보를 read/write 하거나 다른 작업을 수행한다.
- view는 HTTP 요청을 수신하고 HTTP 응답을 반환하는 요청 처리 함수입니다. View는 Model을 통해 요청을 충족시키는 데 필요한 데이터에 접근합니다. 그리고 탬플릿에게 응답의 서식 설정을 맡깁니다.
- 아래 코드는 예시이다. request가 들어오면 view 함수에서 'Hello from Django!'라는 글을 뱉어준다.
## filename: views.py (Django view functions)
from django.http import HttpResponse
def index(request):
return HttpResponse('Hello from Django!')
4. Models : 데이터 모델 정의(models.py)
- 백화점의 응대 매뉴얼 같은??? 비유가 좀 이상한데.....
- 데이터 구조 정의, DB 기록 관리(CRUD, 추가 수정 삭제), 쿼리 하는 방법 제공하는 파이썬 객체
- models라는 파이썬 객체로 데이터를 관리 밑 쿼리 수행
- 그냥 가운데서 일처리 해주는 부분
. Templatess : 작업이 끝난 후 웹브라우저에 응답(Response)한다.
- 처리 후 손님에게 결과를 알려준다. "환불은 10층입니다~~"라고 말로 하거나 손으로 10층을 알려주던가
- 데이터 렌더링 하기(with HTML 템플릿들)
- 보여주기 위해 HTML 같은 형식으로 파일의 구조나 레이아웃을 정의
- View는 model에서 가져온 적절한 데이터를 HTML 템플릿을 이용하여 HTML 페이지를 만들어준다.
- 꼭 html일 필요는 없다
자 그럼 에라 모르겠다. 냅다 따라 해 보자!!
1. 장고 설치
>> pip install django~=2.0.0
2. 장고 기본 골격 만들기
>> django-admin startproject mysite .
manage.py : 사이트 관리를 도와줌, 다른 설치 없이 컴퓨터에서 웹서버를 시작할 수 있음!
settings.py : 웹사이트 설정
urls.py : urlresolver가 사용하는 패턴 목록 포함(우편배달부가 어느 곳으로 편지를 배달해야 하는지 판단 때 필요)
3. 설정 변경
mysite/settings.py 에서 아래 변수들 변경
TIME_ZONE = 'Asia/Seoul' # 정확한 현재시간 사용 위해
STATIC_URL = '/static/' # CSS 다룰 때 정적 파일 경로 추가
STATIC_ROOT = os.path.join(BASE_DIR, 'static') # ROOT 경로 그냥 생성, 나중에 편히 쓰려고
ALLOWED_HOSTS = ['127.0.0.1', '.pythonanywhere.com'] # PythonAnywhere 녀석들과 자기 자신만 허용 가능!
4. 데이터베이스 설정
장고로 운영하는 사이트 내 데이터 저장을 위해 데이터베이스를 설치하자
DB의 종류는 많지만 장고는 sqlite3이 기본으로 설치돼있다
mysite/settings.py에서
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
데이터베이스 생성을 위해 아래 명령어를 수행하자 1초 만에 만들어진다 ㅎㅎ
>> python manage.py migrate
5. 웹서버 시작
인쟈 준비가 끝났다 냅다 시작해보자!!
>> python manage.py runserver
127.0.0.1의 8000번 포트에서 잘 시작됐다고 나온다. Ctrl-C를 누르면 종료된다
그럼 웹에서 127.0.0.1:8000을 접속하면 아래와 같은 화면이 나온다. 성공~!
Reference
tutorial.djangogirls.org
developer.mozilla.org/ko/docs/Learn/Server-side/Django/Introduction