IT_study/스터디
객체지향 설계 원칙, 트랜잭션 격리, 해쉬테이블
객체 지향 설계 원칙인 SOLID 원칙에 대해서 설명해주세요. 예시를 들어주세요. 객체지향 프로그래밍을 할때 지켜야할 5대 원칙을 말한다. 1. SRP(Single Responsibility Principle) 단일 책임의 원칙 하나의 클래스은 하나의 책임(기능)을 가져야 한다는 것 예시) 어떤 자동차 클래스가 있는데, 엔진, 히터 등등 복잡한 시스템이 있다 class car { // 여기에 모두 넣어버리면 복잡해짐 seat : 다른 클래스 불러옴(쪼갬) heater : 다른 클래스 불러옴(쪼갬) } => 이러한 복잡한 시스템을 여러개로 쪼개서 나누고 하나로 묶는 것 2. OCP(Open Close Principle) 개방 폐쇄의 원칙 확장에는 열려있고, 수정에는 닫혀있어야 한다는 원칙 확장 - 요구사항..
공인ip, 사설ip, nat, 프록시서버, DHCP
1. 공인 ip 와 사설 ip의 차이는 무엇일까요? nat 는 무슨 역할을 할까요? ip (Internet Protocol address) 이란? 컴퓨터와 연결된 네트워크 주소 기기가 인터넷에 접속한 곳의 네트워크 상 위치 인터넷 전체에서 서로 다른 기기들을 구분하기 위한 구분자! ip 는 변동함 IPv4 : 0.0.0.0부터 255.255.255.255까지 (일반적 사용) IPv6 : IPv4 주소 부족으로 인한 주소길이 늘림 공유기 기기에서 한 공인 ip아래 기기마다 사설 ip 부여되는 식으로 인터넷 사용 공인 ip : 외부로 노출되는 ip | 네이버, 구글 > ip 주소 확인 검색 사설 ip : 내부에서 사용하는 ip | 윈도우 > ipconfig 사설 ip 주소 범위 사설ip -> 공인ip 로 접..
CDN, CORS, 배포 인프라
1. CDN이란? - CDN 정의, 작동방식, etc (Option) Edge 서버 CDN(Content Delivery Network) 이란? 콘텐츠 전송 네트워크 지리, 물리적으로 떨어진 사용자에게 컨텐츠(그래픽, 이미지, 동영상 파일 등)를 더욱 빠르게 제공할 수 있는 기술 세계 각지에서 한 국가의 서버로 접속할때 느린 응답속도와 다운로드 타임을 극복하기 위해 나온 분산 기술 컨텐츠 전달에 특화 본사 미국(예. 넷플릭스, 유투브 등등)로 부터 한국, 캐나다, 호주 등등 의 다른 나라에서 서버를 받아 온다면, 굉장히 속도가 느림!!! 오리진 서버로 부터 각 지역마다 캐시 서버를 두고 해당 컨텐츠 등을 실시간으로 공유하거나 타임별로 저장하고 , 컨텐츠를 본사에 요청할 경우 CDN을 통해서 해당 캐쉬 ..
Rest api, 클러스터형 vs Non클러스터형, 가비지콜렉터
Rest api 설명 다른 사람들이 이해하기 어렵다 명확한 패턴이 없다 URL 에는 동사를 쓸 수없다 -> 명사로 구분해야함(add, create, delete...CRUD) uniform interface 스타일 1. 자원에 대한 식별 - 자원은 객체 (자원 = URI) 상태는 변화 가능 -> 변하지 않는 식별자 필요 고유한 식별자로 URI를 통해 자원을 식별해야한다 식별자를 통해 특정한 데이터를 지정할 수 있다 (영화에 대한 정보면 movies로 자원을 지정) 2. 표현을 통한 자원에 대한 조작 - 특정한 상태의 자원에 대한 표현 자원은 다양한 방식으로 표현 가능 자원 : 해당 소프트웨어가 관리하는 모든 것 문서, 그림, 데이터 ... 등등 클라이언트 서버 자원의 상태 정보를 전달한다 - 보통 jso..
TCP vs UDP, 라우터 vs 스위치
TCP와 UDP는 어떠한 차이를 갖는가? 전송계층에서 사용하는, 데이터를 보내기 위해 사용하는 프로토콜 포트 번호 이용해 주소 지정 데이터 오류 검사를 위한 체크섬 존재 TCP는 연결형 서비스로 가상 회선 방식을 제공하고, 높은 신뢰성을 보장하고 흐름 제어 및 혼잡 제어 기능을 제공함 (정확성) 데이터를 중요하게 생각하여 확실히 주고 받고 싶을때 사용 통신할 컴퓨터끼리 보냈습니다(SYN), 수락합니다( SYN ACK),도착했습니다(ACK) 서로 확인 메시지 메시지보내며 데이터 주고 받음 (3-way handshaking) 연결지향 프로토콜 - 클라이언트와 서버가 연결된 상태에서 데이터 주고 받음 데이터 보내기 전에 반드시 연결되어 있어야함 1:1 통신만 가능 상대적으로 UDP보다 전송 속도 느림 UDP는..
가상메모리, Redis vs Memcached
운영체제: 메모리관리 가상 메모리에 대해 설명해보세요. → 내용참고 자료 https://core.ewha.ac.kr/publicview/C0101020140425151219100144?vmode=f 반효경 [운영체제] 18. Memory Management 1 설명이 없습니다. core.ewha.ac.kr 메모리 Logical address (virtual address) 논리적주소, 가상주소 프로세스마다 독립적으로 가지는 주소공간 각 프로세스마다 0번지부터 시작 CPU가 보는 주소는 logical address임 Physical address 물리적주소 메모리에 실제 올라가는 위치 주소에서 데이터를 읽고 /쓸때만 물리주소로 바꾼다 💡 주소 바인딩 : 주소를 결정하는 것 Symbolic Address(소..