backend (6) 썸네일형 리스트형 동시성 문제 - Synchronized, 낙관적 락, 비관적 락, 분산 락 비교 분석 애플리케이션에서 사용자가 동시에 동일한 자원을 수정하려고 할 때 경쟁 상태(Race Condition)가 발생할 수 있으며, 개발자는 이러한 동시성 문제가 발생하지 않도록 설계해야 합니다. 이때 개발자가 선택할 수 있는 4가지의 주요 전략을 분석합니다. 락(Lock)이란 무엇이며 왜 필요할까? 락(Lock)은 여러 주체가 하나의 공유 자원에 동시에 접근하려 할 때, 순서를 제어하고 데이터의 정합성을 유지하기 위한 권한 제어 메커니즘입니다. 공유 자원에 대해 여러 작업이 동시에 일어날 때 한 작업의 결과가 다른 작업에 의해 임의로 변경되는 등의 현상(Race Condition)을 막기 위해서 락이 필요합니다! 공유 자원여러 주체가 동시에 접근할 수 있는 데이터Race Condition공유자원에 동시에 접.. 웹 어플리케이션 보안 취약성 공격자는 공격을 시작하기 전에 애플리케이션의 취약성(Vulnerability)을 파악하고 공략해야 함≫ 취약성 : 악의적 의도를 가지고 원치 않는 작업을 수행하는 데 이용할 수 있는 약점 인증과 권한 부여의 취약성인증 (Authentication) : 애플리케이션이 이를 이용하려는 사람을 식별하는 프로세스어떤 사용자나 존재가 앱을 이용하려고 하면 추가 접근을 허가하기 전에 먼저 이들의 ID를 확인해야 함실제 앱에서는 익명 액세스를 지원할 때도 있지만 대부분은 식별된 사용자만 데이터를 이용하거나 특정 작업을 수행할 수 있음권한부여 또는 인가 (Authorization) : 인증된 호출자가 특정 기능과 데이터에 대한 이용 권리가 있는지 확인하는 프로세스예) 대부분의 인증된 사용자는 자금을 이체할 수 있지만 .. ORM Object Relational Mapping (객체-관계-매핑)어플리케이션 객체와 관계형 데이터베이스의 데이터를 매핑해주는 도구객체 지향 프로그래밍 - 클래스 사용 / 관계형 데이터베이스 - 테이블 사용대표적인 ORM : Hibernate, JPA 등 ORM 사용 이유객체 모델과 관계형 모델 간의 불일치 존재객체 지향 프로그래밍의 클래스 / 관계형 데이터베이스의 테이블데이터베이스 접근을 프로그래밍 언어의 관점에서 접근!ORM을 이용해서 객체 간의 관계를 바탕으로 SQL을 자동 생성하여 불일치 해결 ORM의 장점직관적인 코드로 데이터를 조작할 수 있음개발자가 비즈니스 로직에 집중할 수 있음부수적인 코드가 줄어들어 단순해지고 가독성 상승재사용 및 유지보수 편리ORM은 독립적으로 작성되어 있기 때문에 객체들.. JDBC 서버와 DB의 연결 DB 교체가 발생한다면?데이터베이스마다 커넥션 연결 방법과 SQL 전달 방법, 결과 응답을 받는 방법이 모두 다름이러한 방식은 데이터베이스 변경에 매우 취약하다는 문제가 있음이러한 방식을 해결할 수 있는 것 ≫ 자바 표준 JDBC JDBCJava Database Connectivity자바에서 DB 프로그래밍을 하기 위해 사용되는 API (표준 인터페이스)데이터베이스에 맞는 JDBC 드라이버를 사용 JDBC 표준 인터페이스3가지 기능을 표준 인터페이스로 정의하여 제공인터페이스를 구현하여 제공하는 라이브러리 = JDBC Driver(Oracle DB에 접근할 수 있는 라이브러리 = Oracle JDBC Driver) ** JDBC 이용하기!환경 설정build.gradle 파일에 JDBC.. 템플릿 엔진(Template Engine) 템플릿 엔진 (Template Engine)템플릿 양식과 데이터가 합쳐져 HTML 문서를 출력하는 소프트웨어뷰 코드 (HTML)과 데이터 로직 코드 (DB Connection)을 분리하는 역할템플릿 엔진의 필요성HTML에 비해 간단한 문법으로 코드 수 감소같은 페이지에 데이터만 바뀌는 경우에 활용하여 재사용성 높음하나의 템플릿으로 여러 페이지를 렌더링하는 경우가 있어 유지보수 용이 렌더링 주체에 따른 구분서버 사이드 템플릿 엔진클라이언트 사이드 템플릿 엔진 서버 사이드 템플릿 엔진서버에서 구동되는 템플릿 엔진서버에서 데이터를 미리 정의된 템플릿에 넣어서 HTML을 생성하여 클라이언트에 전달 ** 동작 과정클라이언트에서 요청 수신서버에서 데이터를 획득 (DB or API)템플릿에 데이터를 배치데이터가 반영.. MVC 패턴 MVCModel - View - Controller소프트웨어 아키텍처 디자인 패턴사용자 인터페이스 / 비즈니스 로직을 분리하고, 각각을 독립적으로 유지 Model데이터가 들어있는 객체데이터를 관리하고 변경이 발생하면 View에게 알림DB와의 연동을 위한 DAO(Data Access Object)와 데이터 구조를 표현하는 DO(Data Object)로 구성ex) 쇼핑몰의 검색 기능 - 검색 키워드가 넘어오면 (뷰를 통해) 관련된 상품의 데이터를 찾아 결과를 뷰에 전달View데이터를 사용자에게 보여주는 사용자 인터페이스(UI)모델의 데이터를 특정 형식으로 표현하여 사용자에게 보여줌사용자 입력을 받아 컨트롤러에 전달ex) 검색 키워드를 받아 컨트롤러에 전달 / 검색 결과를 모델로부터 받아 화면 등에 배치Co.. 이전 1 다음