ENUM 이란? Rust에서 enum은 열거형 타입으로, 여러 개의 다른 값들 중 하나의 값을 가질 수 있는 타입이다. Enumeration (열거) 에서 기원한 키워드이다. 이는 Rust의 강력한 타입 시스템과 패턴 매칭 기능을 활용하여 다양한 종류의 데이터를 안전하고 효율적으로 처리할 수 있게 해준다. ENUM 의 특징 1) 다양한 값 정의가 가능 enum을 사용하여 서로 다른 값들을 정의할 수 있다. 각각의 값은 enum 타입의 '변종(variant)'이라고 불린다. 예를 들어, 트래픽 신호등의 상태를 나타내는 enum을 정의할 수 있다. (Red, Yellow, Green.) #[derive(Debug, PartialEq)] enum Color { Red, Green, Blue } fn mai..
구조체(structure) 란? Rust에서 구조체(structure), 일반적으로 struct라고 줄여 부르는 것은 여러 데이터를 하나의 논리적 단위로 그룹화하는 데 사용되는 사용자 정의 데이터 타입이다. 구조체는 관련된 데이터들을 모아서 이름을 붙이고, 안전하게 구성하여 사용할 수 있게 해 준다. 이는 다른 프로그래밍 언어의 '클래스'와 비슷한 개념이지만, Rust의 구조체는 상속이나 다형성 같은 객체지향 기능을 지원하지 않는다. 구조체 타입 Named Field Structs Named field structs는 가장 일반적인 유형의 구조체로, 각 필드에 이름이 붙어 있다. 이를 통해 데이터에 쉽게 접근하고, 의미 있는 방식으로 데이터를 구성할 수 있다. 구조체는 아래와 같이 사용할 수 있다. #[..
Slice 란? Rust에서 슬라이스(slice)는 연속된 데이터의 일부 혹은 전체에 대한 참조를 제공하는 데이터 타입이다. 슬라이스는 컬렉션의 일부를 가리키지만, 소유하지는 않는다. 슬라이스를 사용함으로써 컬렉션의 특정 부분에 대한 접근을 효율적으로 제공할 수 있다. 슬라이스의 기본 특성 1) 참조자 슬라이스는 기본적으로 두 가지 정보를 가진다. 데이터를 가리키는 포인터와 슬라이스의 길이를 가진다. 2) 안전성 슬라이스는 컬렉션의 유효한 부분만을 참조하도록 제한되어 있어, 범위를 벗어난 접근을 방지한다. 3) 동적 크기 슬라이스는 런타임에 크기가 결정된다. 컴파일 타임에는 크기를 알 수 없다. 슬라이스의 사용 1) 배열 슬라이싱 배열이나 벡터에서 일부 범위를 참조하는 데 사용된다. 예를 들어, let ..
현재 회사에서 Elasticsearch를 운영하고 있다. Elasticsearch는 매일 monitoring-es ~라는 인덱스를 자동으로 인덱싱 한다. 해당 인덱스는 X-Pack 모니터링 기능이 활성화되어 있을 때 자동으로 생성되며, 클러스터의 성능, 상태 및 메트릭에 대한 상세 정보를 포함한다. 보통 monitoring-es 인덱스는 아래와 같은 정보를 저장해 준다. 1) 클러스터 상태 정보 클러스터의 건강 상태, 노드 수, 인덱스 수, 샤드 수 등 클러스터 전반에 대한 상태 정보. 2) 노드 메트릭 각 노드의 CPU 사용량, 메모리 사용량, 디스크 I/O 통계, JVM 통계(가비지 컬렉션, 힙 메모리 사용량 등), 네트워크 사용량 등 노드별 성능지표. 3) 인덱스 메트릭 각 인덱스의 샤드 할당 상태..
함수의 소유권 이전 아래는 함수의 소유권이 이전이 되는 예제이다. String 변수를 선언하고 초기화 한 다음 해당 문자열의 길이를 리턴해주는 함수를 사용한다. 여기서 문제가 발생한다. get_string_len() 함수에 String 파라미터를 입력하게 되어 있는데, 이때, String 데이터의 소유권이 변수 str에서 get_string_len() 함수로 넘어가게 되면서 다시 main 함수에서는 str 변수를 사용할 수 없게 된다. 이럴 경우에는 참조를 사용하면 된다. C / C++를 배워봤던 사람들에게는 친숙한 "&" 표시로 참조변수를 만들 수 있다. 참조(Reference) Rust에서 참조(reference)는 중요한 개념 중 하나로, 메모리 안전성을 보장하는 데 핵심적인 역할을 한다. 참조를 ..
프로그램 메모리 관리 방식 1) GC를 이용하는 언어들 - Java, Python, Go, JavaScript - Java, Python, Go, JavaScript 에서 사용됨. - compile time 이 아닌 실행 시간 중(Runtime)에 때때로 더 이상 쓰지 않는 메모리를 GC 가 알아서 정리해 준다. - 개발하기 대단히 편리함. - 운영할 때 성능상 문제가 되기도 함. 2) 수동으로 프로그래머가 메모리를 관리하는 언어들 - C / C++ - 개발자가 메모리 할당과 해제 작업을 지시한다. - 최적의 속도. 실행 시 메모리 관리 부담 최소 - 개발하기가 GC를 사용하는 언어에 비해 상대적으로 어려움, 실수 및 버그가 많이 생길 수 있음. 3) 컴파일 시점에 메모리 관리 규칙을 검사 - RUST ..
목표 이번 글의 목표는 아래글에서 작성한 소스를 좀 더 효율적으로 코드 리팩토링(Code Refactoring) 하는 것이 목표이다. https://goodbyeanma.tistory.com/175 [c++] Elasticsearch Cluster metric 알람 구현 목표 회사에서 여러 시스템에서 사용되는 Elasticsearch Cluster를 관리하고 있다. 클러스터 모니터링을 위해서 ElasticHQ, Cerebro, Prometheus, Grafana , Beats와 같은 솔루션을 이용할 수 있겠지만, 이 글에서는 goodbyeanma.tistory.com 앞의 글에서 C++ 를 통한 Elasticsearch Cluster의 CPU, JVM, DISK 사용률을 수집하고 특정 임계치가 넘게되면 ..
목표 회사에서 여러 시스템에서 사용되는 Elasticsearch Cluster를 관리하고 있다. 클러스터 모니터링을 위해서 ElasticHQ, Cerebro, Prometheus, Grafana , Beats와 같은 솔루션을 이용할 수 있겠지만, 이 글에서는 C++ 코딩을 통해서 해당 기능을 수행하는 프로그램을 만들어보겠다. 이 글에서는 특정 ES cluster 내부의 각각 노드의 metric 정보를 수집하여 임계치가 넘어가면, 관리자에게 알람을 전송하는 코드를 만들어보겠다. 수집할 metric 정보는 아래와 같다. 1. CPU 사용량 2. JVM 사용량 3. DISK 사용량 설계 시스템 아키텍처 위의 시스템 아키텍처를 보면, 컴파일된 c++ 프로그램이 각 ES Cluster에 curl HTTP GET ..
https://goodbyeanma.tistory.com/172 [C++] Mac os 에서 Mysql 연결하기 Mac os 환경에서 C++를 사용해서 Mysql과 연동하여 소스코드를 작성하는 방법을 보자. 일단, 해당글에서는 mac os 에 mysql 은 이미 설치되었다고 가정하고 설명을 진행하겠다. 1. mysql-connector-c++ 설치 202 goodbyeanma.tistory.com C++와 Mysql을 연결하는 방법은 이전 글에서 포스팅하였다. 이번 글에서는 C++를 통해서 mysql 인스턴스에 DML 작업을 어떤 식으로 수행할 수 있는지 확인해 보자. 예제 Mysql에서 예제로 사용할 스키마는 아래와 같다. CREATE TABLE EMP_TEST ( emp_seq BIGINT AUTO_..
멀티스레드 프로그래밍이란? 멀티스레드 프로그래밍은 하나의 프로세스 내에서 여러 개의 스레드를 사용하여 동시에 작업을 수행하는 프로그래밍 방식이다. 이를 통해 프로그램의 성능을 향상시키고 병렬 처리를 가능하게 하며, 여러 작업을 동시에 처리할 수 있도록 도와준다. 스레드는 경량 프로세스로, 하나의 프로세스 내에서 동작하는 여러 실행 흐름이다. 프로세스는 운영체제로부터 독립된 메모리 영역을 할당받아 실행되는 프로그램의 단위이며, 각 프로세스는 최소한 하나의 메인 스레드를 가지고 있다. 이 메인 스레드 외에도 프로세스 내에서 여러 개의 보조 스레드(멀티스레드)를 생성하여 병렬로 작업을 수행할 수 있다. 멀티스레드 프로그래밍의 이점 1) 성능 향상 여러 스레드가 동시에 작업을 처리하므로 병렬 처리로 인한 성능 ..