본문 바로가기

전체 글101

MicroService Architecture(MSA)란 무엇일까? MicroService Architecture(MSA)의 의미는 무엇일까요? MSA는 분산 시스템과 관련된 개념입니다. 따라서 대규모 애플리케이션을 구축하는 과정에서 접하게 됩니다. MSA란 대규모 sw를 이름 그대로 작은(micro) 서비스로 분해하고 독립적으로 배포, 확장, 관리할 수 있도록 설계하는 아키텍처라고 말할 수 있겠습니다. MSA는 하나의 애플리케이션에 모든 기능이 종속되어 있는 모놀리식(Monolithic) 아키텍처의 단점을 보완하여, 시스템의 확장성과 유연성을 높일 수 있도록 만들어 졌습니다. 모놀리식(Monolithic) 아키텍처에서는 전체 시스템이 하나의 큰 어플리케이션으로 구성되어 있으며, 각각의 기능이 서로 긴밀하게 결합되어 있습니다. 즉, 하나의 애플리케이션에 모든 기능이 포함.. 2023. 4. 29.
sqlite3에서 MySQL로 DB 변경 - with Django 해당 글에서는 Django에서 MySQL DB를 설정하는 방법을 다뤘습니다. 목차 1. MySQL 설치 2. MySQL 드라이버 설치 3. Django 설정 변경 4. 중간 마이그레이션 5. 확인 1. MySQL 설치 다운로드 및 설치 방법은 아래의 링크를 참조하자. MySQL 다운로드 및 설치 방법 📌Window10에 MySQL 다운로드 및 설치 하기 1. MySQL 홈페이지 접속 MySQL 링크 주소 : velog.io 위의 링크에 따라 MySQL을 다운로드를 완료했다면 Django와 MySql를 연결해보자. 2. MySQL 드라이버 설치 먼저 **드라이버(Driver)**란 무엇일까요? 드라이버(Driver)는 컴퓨터에서 다른 장치나 소프트웨어와 상호작용하기 위한 인터페이스를 제공하는 프로그램입니다.. 2023. 3. 16.
you’re seeing this error because you have DEBUG = True in your Django settings file. Change that to False, and Django will display a standard 404 page. 전체 메세지 Page not found (404) Directory indexes are not allowed here. Request Method:GET Request URL: Raised by:django.views.static.serve Using the URLconf defined in M_shopping_mall.urls, Django tried these URL patterns, in this order: admin/ user/ product/ ^(?P.*)$ The current path, admin, matched the last one. You’re seeing this error because you have DEBUG = True in your Django settings file. .. 2023. 3. 16.
HTTP GET, POST method의 차이점 / HTTP 상태코드 HTTP GET, POST method의 차이점. GET GET은 서버로부터 정보를 조회하기 위해 설계된 메소드입니다. GET은 요청을 전송할 때 필요한 데이터를 Body에 담지 않고, 쿼리스트링을 통해 전송합니다. POST POST는 리소스를 생성/변경하기 위해 설계되었다. GET과 달리 전송해야될 데이터를 HTTP 메세지의 Body에 담아서 전송합니다. 차이점 GET은 Idempotent, POST는 Non-idempotent하게 설계되었다. GET이 Idempotent하도록 설계되었다는 것은 GET으로 서버에게 동일한 요청을 여러 번 전송하더라도 동일한 응답이 돌아와야 한다는 것을 의미합니다. 이에 따라 GET은 설계원칙에 따라 서버의 데이터나 상태를 변경시키지 않아야 Idempotent하기 때문에.. 2022. 9. 23.
백준 2525번 파이썬 문제 KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다. 또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다. 훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오. 입력 첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진.. 2022. 9. 22.
백준 15552번 파이썬 문제 본격적으로 for문 문제를 풀기 전에 주의해야 할 점이 있다. 입출력 방식이 느리면 여러 줄을 입력받거나 출력할 때 시간초과가 날 수 있다는 점이다. C++을 사용하고 있고 cin/cout을 사용하고자 한다면, cin.tie(NULL)과 sync_with_stdio(false)를 둘 다 적용해 주고, endl 대신 개행문자(\n)를 쓰자. 단, 이렇게 하면 더 이상 scanf/printf/puts/getchar/putchar 등 C의 입출력 방식을 사용하면 안 된다. Java를 사용하고 있다면, Scanner와 System.out.println 대신 BufferedReader와 BufferedWriter를 사용할 수 있다. BufferedWriter.flush는 맨 마지막에 한 번만 하면 된다. P.. 2022. 9. 21.
Deadlock의 해결 방법 / 쿠키와 세션의 차이점. Deadlock이란? 해결할 수 있는 방안은? 두 개 이상의 작업이 서로 상대방의 작업이 끝나기 만을 기다리고 있기 때문에 결과적으로 아무것도 완료되지 못하는 상태를 가리킨다. 예를 들어 하나의 사다리가 있고, 두 명의 사람이 각각 사다리의 위쪽과 아래쪽에 있다고 가정한다. 이때 아래에 있는 사람은 위로 올라 가려고 하고, 위에 있는 사람은 아래로 내려오려고 한다면, 두 사람은 서로 상대방이 사다리에서 비켜줄 때까지 하염없이 기다리고 있을 것이고 결과적으로 아무도 사다리를 내려오거나 올라가지 못하게 되듯이, 전산학에서 교착 상태란 다중 프로그래밍 환경에서 흔히 발생할 수 있는 문제이다. 해결 방안 데드락이 발생하지 않도록 예방(prevention) 하기 데드락 발생 가능성을 인정하면서도 적절하게 회피(a.. 2022. 9. 20.
Transaction의 의미와 ACID 규칙 / Primary Key와 Foreign Key Transaction의 의미와 ACID 규칙에 대해서 설명해주세요. Transaction 트랜잭션(Transaction 이하 트랜잭션)이란, 데이터베이스의 상태를 변화시키기 해서 수행하는 작업의 단위를 뜻한다. 데이터베이스의 상태를 변화시킨다는 것은 아래의 질의어(SQL)를 이용하여 데이터베이스를 접근 하는 것을 의미한다. SELECT UPDATE INSERT DELETE ACID ACID(원자성, 일관성, 고립성, 지속성)는 데이터베이스 Transaction(트랜잭션)이 안전하게 수행된다는 것을 보장하기 위한 성질을 가리키는 약어이다. 원자성 트랜잭션과 관련된 작업들이 부분적으로 실행되다가 중단되지 않는 것을 보장하는 능력이다. 트랜잭션이 DB에 모두 반영되거나, 전혀 반영되지 않거나를 뜻한다. All.. 2022. 9. 16.
RDB와 NoSQL / Inner Join과 Left (Outer) Join RDB와 NoSQL의 뜻과 차이점, 장단점 RDBMS(DataBase Management System) 관계형 데이터베이스 관리 시스템을 의미합니다. 장점 정해진 스키마에 따라 데이터를 저장하여야 하므로 명확한 데이터 구조를 보장하고 있습니다. 또한 관계는 각 데이터를 중복없이 한 번만 저장할 수 있습니다. 단점 테이블간테이블 간 관계를 맺고 있어 시스템이 커질 경우 JOIN문이 많은 복잡한 쿼리가 만들어질 수 있습니다. 성능 향상을 위해서는 서버의 성능을 향상 시켜야하는 Scale-up만을 지원합니다. 이로 인해 비용이 기하급수적으로 늘어날 수 있습니다. 스키마로 인해 데이터가 유연하지 못합니다. 나중에 스키마가 변경 될 경우 번거롭고 어렵습니다. NoSQL(Not Only SQL) RDB 형태의 관계.. 2022. 9. 15.