: 여러가지 형태를 가져 다양한 동작을 할 수 있는 능력이고, 상속과 함께 객체지향의 가장 중요한 특징 중 하나이다. 자바에서의 다형성 : 자바에서는 한 타입의 참조변수로 여러 타입의 객체를 참조할 수 있도록 했다. List를 예로 생각해보면, List 참조변수로 ArrayList, LinkedList 타입을 받을 수 있다. 참조변수와 형...
스프링 인 액션 - 1. 스프링 기초 - 1. 스프링 시작하기
: 애플리케이션의 모든 기반을 자동으로 구성해주고, 이 것을 통해 개발자는 애플리케이션의 비즈니스 로직에만 집중할 수 있다. 용어 컨테이너 (스프링 애플리케이션 컨텍스트) : 빈 객체를 관리한다. 빈 생성, 관리를 하고, 필요한 곳에 (생성자와 같은 방법을 통해) 주입(연결)시켜준다. 컴포넌트: 빈 객체. 다른 애플리케이션 구성요소와 ...
쿠버네티스를 사용하는 이유
: 여러 컨테이너 오케스트레이션 기법 중 쿠버네티스를 사용하는 이유 컨테이너 오케스트레이션이 필요한 이유 : 많은 컨테이너를 더 편리하게 관리하기 위한 목적 도커 기반 컨테이너 환경이 등장하면서 애플리케이션 배포과정이 쉬워졌다. 그러나, 여전히 많은 컨테이너를 직접 관리해줘야 한다는 불편한 점이 있다. 여러 호스트에 걸쳐 띄워진 컨테...
쿠버네티스 아키텍처
쿠버네티스란? : (k8s, kube, …) 컨테이너된 애플리케이션을 자동으로 배포, 스케일링, 관리 컨테이너를 쉽게 관리하기 위해 논리적으로 그룹화(노드 or 파드 or service 등으로 추상화) 아키텍처 쿠버의 특징: Desired state : Observe 상태 체크 -> Diff 발견 -> Act 조치...
DB 접근 통제와 작업 요청
DB에 접근하는 일반적인 방법 : Client Tool(SQL developer, mysql workbench) 이용 or DB 콘솔로 직접 접근 DB 접근 통제 시스템이란? : 해당 DB에 접근 권한을 보유하고 있는지, 권한이 어느정도까지인지 제어하는 것. Client tool과 DB 사이의 통제 agent가 게이트웨이 역할을 수...
취약점과 대응방안
취약점이란? : 1. 소프트웨어의 결함 2. 공격자의 접근 3. 악용 가능성 세가지 모두 제거하려는 노력을 해야한다. 어떠한 경우라도 완벽하게 제거했다고 말하기 어렵기 때문 여러 취약점들이 계속해서 생기고 있다. 보안 관련 진단을 주기적으로 계속 해야한다. 다양한 사례 Local Web Pro...
RESTful과 Rest 유니폼 인터페이스(Uniform Interface)
HTTP API HTTP를 사용해서 서로 정해둔 스펙으로 통신 넓은 의미의 Rest API REST API(Restful) : http api와 같으나 추가적으로 Restful한 네가지 특징을 갖고 일관된 인터페이스를 만들어야 한다. 1. 자원 식별: 각각의 리소스는 URI를 통해 식별 가능해야한다. e.g) GET ...
Container 인스턴스 Locale 설정
: 한글이 마름모 + 물음표로 보인다면 locale 설정이 맞지 않는 것이다. 컨테이너 내부에서 한글 문자를 보면 아래와같이 마름모 + 물음표 + 특수문자 형태로 보이게 된다. locale을 통해 확인해보면 현재 컨테이너의 로케일 설정에서 LC_ALL= 이 값이 비어있고 나머지는 POSIX 라는 로케일로 설정되어있다. ...
Redis의 자료구조와 Full scan
: Redis에는 불가피하게 full scan을 해야하는 API를 제공한다. getKeys(hscan())와 같은 것이 그런 것에 속한다. 싱글스레드 기반의 redis를 block시키는 것은 큰 문제를 발생시킬 수 있어, 해결 방안 중 하나로 많은 곳에서 cursor 매커니즘을 이야기한다. cursor 매커니즘 Redis는 ope...
DB Indexing
인덱싱이란? DB 조회시 더 빠르게 할 수 있는 방법. 책 맨 첫페이지에 있는 목차 느낌 column(속성), 해당 레코드가 저장된 주소를 Key - value 쌍으로 인덱스를 만들어 두는 것 c.f) MariaDB 디폴트로 PK, FK 컬럼에 대해 인덱스 테이블을 만들어놓는다. 기본값으로 B-Tree 사용한다고 명시되...