분류 전체보기
-
[Etcd] Watch 기능 알아보기 ( HTTP2, WatchCreateRequest )Etcd 2024. 6. 17. 05:59
- 목차 들어가며.Etcd 는 Distributed Application 의 상태를 저장하는 저장소로써 동작합니다.일반적인 분산 시스템은 네트워크적으로 떨어져 존재하는데요.하지만 이들은 마치 한 몸처럼 동작해야만 합니다.대표적인 분산 시스템의 예시로써 Kafka 가 존재합니다.보통 3개 이상의 Kafka 서버는 네트워크적으로 떨어져있지만 Kafka Client 는 Kafka Broker 들이 마치 하나의 시스템인 것처럼 보여집니다.즉, 분산 시스템은 멀리 떨어져 있지만 한 몸처럼 동작해야한 하는 것이죠. Kafka 는 Etcd 가 아닌 Zookeeper 를 사용하긴 하지만 Etcd, Zookeepr, Consul 등 이들은 분산 시스템의 상태를 저장하기 위한 저장소로써 동일한 목적을 가집니다.그리고 이러..
-
[Etcd] WAL Log (Write Ahead Log) 알아보기Etcd 2024. 6. 17. 05:59
- 목차 들어가며.Etcd 는 데이터의 영속성 (Persistence) 를 구현하기 위해서 여러가지 데이터 저장 요소들이 존재합니다.크게 세가지 구성 요소를 통해서 Etcd 는 데이터의 영속성을 구현하는데요.WAL LogSnapshotBoltDB와 같이 3개의 Disk 내의 File 들이 존재합니다. 먼저 각각의 파일의 역할들에 대해서 간단히 알아보도록 하겠습니다. WAL Log.WAL Log 는 Write Ahead Log 의 줄임말입니다.이는 수 많은 서비스에서 여러가지 이름으로 사용되는 기능으로 데이터베이스에 추가되는 모든 데이터 변경사항들이 기록되는 영역입니다.MySQL 의 Redo Log 는 데이터를 생성, 수정, 삭제하는 모든 DML 쿼리들이 Redo Log 에 추가됩니다.Hadoop 에서도 ..
-
[Etcd] --listen-peer-urls 설정 알아보기 (--initial-advertise-peer-urls)Etcd 2024. 6. 17. 05:59
- 목차 들어가며.Etcd 는 최소 3개의 Etcd Server 들로 하나의 클러스터를 구성합니다.일반적으로 Etcd 는 중앙 저장소로써 Distributed Application 들의 적절한 실행을 위해서 Key-Value 타입의 데이터들을 저장합니다.이러한 Distributed Application 들이 필요로하는 데이터를 안정적으로 관리하기 위해서 최소 3개 이상의 Etcd Server 들이 하나의 Cluster 를 구성하죠. Etcd Server 들이 하나의 Cluster 를 구성하기 위해서 Peer to Peer 네트워크 통신을 수행합니다.그리고 이러한 네트워크 통신 과정에서 데이터를 안정적으로 복제하고 ( Replication ), 서로의 생존 여부를 확인합니다. ( High Availabli..
-
[Etcd] --initial-cluster 설정 알아보기Etcd 2024. 6. 16. 08:12
- 목차 들어가며.Etcd 는 데이터 저장소로써 동작합니다.이는 Key-Value 타입의 데이터를 저장하며, 일반적으로 Client 의 상태값을 저장하는 용도로 사용됩니다.그리고 Etcd 는 여러개의 Etcd 서버들이 모여서 하나의 클러스터를 형성합니다.흔히 고가용성 ( High Availability ) 를 구현하기 위해서 최소한 3개의 Etcd 서버들이 하나의 클러스터를 구성하죠.--initial-cluster 는 서로 떨어져 있는 Etcd 서버들끼리 서로의 위치를 공유하기 위해서 사용됩니다.각 Etcd 서버의 Host 와 Port 를 작성해서 서로가 서로의 네트워크 위치 정보를 식별할 수 있습니다. --initial-cluster 란 ?Etcd 는 여타 프로그램과 같이 etcd 실행파일을 통해서 실..
-
[Golang] Go 의 range 와 channel 함께 사용하기Golang 2024. 6. 15. 17:58
- 목차 들어가며.Go 언어는 channel 과 range 를 함께 사용하여 데이터를 효율적으로 처리할 수 있는 간단하고 강력한 메커니즘을 제공합니다.특히, 고루틴(goroutine)과 함께 사용할 때 데이터의 동시성 처리를 쉽게 구현할 수 있습니다. Channel.Go 의 채널은 고루틴 간의 통신을 위한 도구로, 데이터를 전송하거나 수신할 때 사용됩니다.주로 아래와 같은 방식으로 Channel 변수를 초기화할 수 있습니다. ch := make(chan int) Range. range 는 슬라이스, 배열, 맵, 채널 등에서 데이터를 순회(iterate)하는 데 사용됩니다.채널에서 range를 사용하면 채널이 닫힐 때까지 데이터를 자동으로 수신합니다.golang 에서는 채널을 닫기 위한 close 함수가 ..
-
[Golang] go install 과 go get 의 차이 알아보기Golang 2024. 6. 15. 17:58
- 목차 들어가며.Go 언어를 사용하다 보면 go install 과 go get 이라는 명령어를 자주 접하게 됩니다. 이 두 명령어는 비슷해 보이지만, 사실 목적과 동작 방식이 다릅니다. 이번 글에서는 go install 과 go get 의 차이를 명확히 이해하고, 상황에 맞게 올바르게 사용하는 방법을 알아보겠습니다. go install ?go install 은 Binary 실행파일을 내려받기 위한 명령어입니다. 이는 Go 프로젝트에 의존성을 추가하는 작업이 아닙니다. go install 로부터 설치된 파일은 $GOPATH/bin 디렉터리에 저장됩니다. 주로 CLI 도구나 독립 실행형 프로그램을 설치할 때 사용됩니다. golang 1.22.10 환경에서 go install 의 예시를 살펴보겠습니다. D..
-
[Golang] time 패키지의 기본적인 사용법 알아보기 ( Now, LoadLocation )Golang 2024. 6. 12. 07:23
- 목차 들어가며.Golang 의 time 패키지는 날짜와 시간을 처리하기 위한 다양한 기능을 제공하는 표준 라이브러리입니다.이번 글에서는 time 패키지의 기본적인 사용법과 주요 기능들을 살펴보겠습니다. 현재 시각 가져오기.time 패키지는 여타 프로그래밍 언어와 같이 현재 시각 정보를 가져올 수 있습니다.time.Now()time.Now()를 사용하여 현재 시간을 가져올 수 있습니다. package example_timeimport ( "fmt" "time")func TimeExample() { var now time.Time = time.Now() fmt.Println(now)} Timezone 을 변경하는 방법.time.Now() 와 같은 함수를 사용하여 time.Time 구조체를 생성할 수 있..
-
[Golang] encoding/json 패키지 알아보기Golang 2024. 6. 12. 07:23
- 목차 들어가며.Go 의 encoding/json 패키지는 JSON 데이터를 처리할 수 있도록 지원합니다.본 글에서는 encoding/json 패키지의 주요 기능과 다양한 예제를 통해 심층적으로 다뤄보겠습니다. Marshal ( struct 를 Json 으로 인코딩 ).encoding/json 패키지는 Marshal 함수를 제공합니다.Marshal 이라는 표현인 Encoding 과 유사한 개념으로 이해하시면 되며, Go struct 를 JSON으로 인코딩하는 역할을 수행합니다. Marshal 함수의 시그니처는 아래와 같습니다.Marshal 함수는 인자로써 interface{} 타입을 필요로 합니다.interface{} 타입은 다른 프로그래밍 언어의 Any 나 Object 같이 모든 데이터 타입을 의미하..
-
[Gin Gonic] Gin Gonic 에서 Query String 처리 방법 알아보기Golang/Gin Gonic 2024. 6. 11. 06:35
- 목차 들어가며.Gin Gonic 은 Go 언어 기반의 고성능 웹 프레임워크로, 간결하면서도 강력한 기능을 제공합니다. Gin Gonic 은 gin.Context 구조체를 통해서 Query String 을 간단하고 효율적으로 처리할 수 있는 메서드들을 제공합니다. 이번 글에서는 Query String 처리 방법과 관련된 다양한 사례를 살펴보겠습니다. Query String 처리하는 주요 메소드 알아보기.Gin Gonic 에서는 Middleware 와 Handler 에서 요청 URL 의 Query String 을 처리합니다.그리고 이 처리 과정에서 gin.Context 구조체가 활용됩니다.일반적으로 Gin Gonic 의 Query String 을 처리하는 전반적인 기능은 gin.Context 구조체의 메..
-
[Java NIO] Selector register 이해하기Java/NIO 2024. 6. 11. 06:35
- 목차 들어가며.Java NIO 의 Selector 는 비동기적으로 여러 채널(Channel)을 모니터링할 수 있는 강력한 도구입니다. 이 중에서도 register 메서드는 특정 채널을 Selector에 등록하고 관심 이벤트를 설정하는 중요한 역할을 합니다. 이 글에서는 register 메서드의 사용법과 작동 원리를 살펴보겠습니다. Selector와 Channel의 관계.Selector 는 여러 개의 Channel 을 등록하여, 읽기, 쓰기, 연결 수락 등의 이벤트를 비동기적으로 감지할 수 있습니다. register 메서드는 Selector 와 Channel 사이의 연결 고리 역할을 합니다.Selector: 이벤트를 감지하고, 필요한 처리를 트리거합니다.Channel: Selector 에 등록되어 이벤..