Kafka 란 무엇인가? Kafka 는 가장 널리 쓰이고 있는 메시지 큐 솔루션 중 하나이다. 메시지 큐 (Message Queue) 는 프로세스 또는 프로그램 간에 데이터를 교환할 때 사용하는 통신 방법 중에 하나로, 메시지 지향 미들웨어를 구현한 시스템을 말한다. 메시지 지향 미들웨어란 비동기 메시지를 사용하는 응용 프로그램들 사이에서 데이터를 송수신하는 것을 의미한다. 메시지 큐는 메시지를 임시로 저장하는 버퍼와 비슷한 역할을 수행한다. 메시지큐는 실시간으로 처리되지 않아도 크게 문제없는 작업에 많이 적용하고는 한다. 예를 들면, 이메일 전송과 같은 작업에서 메시지큐를 사용할 수 있다. 서비스에서 이미 이메일을 전송했고, 실제 받는 사람이 읽을 때까지 시간이 얼마나 걸릴지는 모르지만, 해당 작업이 ..
C/C++ 를 쓸때마다 항상 헷갈리는 단어가 존재한다. 바로 "포인터 배열"과 "배열 포인터" 이다. 그럼 두 단어가 의미하는바가 어떤식으로 다른지 알아보자. 1. 포인터 배열 (Pointer Array) 포인터 배열은 말 그대로 "포인터의 배열"을 의미한다. 배열이란 단일 식별자를 통해 같은 자료형의 여러 변수에 접근할 수 있게 해주는 집계 데이터유형 이다. 즉, 같은 자료형의 변수를 일렬로 늘어놓은 형태라고 생각하면 된다. 포인터 배열은 변수 자체가 포인터를 의미하므로 포인터 변수를 일렬로 늘어놓은 데이터 유형이라고 생각하면 된다. #include using namespace std; int main() { int a = 10; int b = 20; int c = 30; int *ptr_array[3..
Kafka 2.0 이상에서는 버전을 확인하기 위해서는 bin 디렉토리 하위에 있는 kafka-topic.sh 파일을 실행시키면 된다. ### kafka 내의 bin 디렉토리로 이동후에 아래의 명령어 실행 ./kafka-topic.sh --version 또한 많은 서비스회사에서 Kafka 를 Zookeeper 위에 띄워놓고 운영한다. Zookeeper 도 비슷한 방식으로 버전을 확인할 수 있다. 일단, zookeeper-shell.sh 가 존재하는 kafka 내의 bin 디렉토리로 이동해주자 (위에서 카프카 버전 확인했던 디렉토리랑 같은 위치) 그 다음 zookeeper-shell.sh 로 접속해준다. ### 아래의 명령어를 실행시켜준다. ./zookeeper-shell.sh {ip address}:{po..
계속 인프라 관련 글만 올리다가 오랜만에 개발관련 글을 올려본다. 일반적으로 서버에 문제가 생기거나, api 쪽에 문제가 발생하였을 경우에 SMTP를 통해서 outlook으로 메일을 전송하여 장애대응을 할 수 있게 해준다. 실제 운영환경에서는 훨씬 더 복잡한 로직이 있지만, 이 글에서는 SMTP 사용에만 포커스에 두고 설명할 것이다. Spring framework를 기반으로 구성해 보겠다. 일단 아래와 같이 dependency를 pom.xml 에 추가해 주자. com.sun.mail javax.mail 1.6.2 테스트는 구글 계정을 통해 진행할 것이다. 일단 구글에 로그인을 해주고 계정설정탭으로 들어가 준다. 아래의 그림과 같이 보안탭으로 이동해 준다. 아래와 같은 탭에서 앱 비밀번호 쪽을 눌러준다. ..
설치 테스트는 Ububtu 20.04 버전, Java11 버전에서 확인하였다. Ububtu 환경에서 MongoDB 를 설치하기 위해서 아래의 메뉴얼을 따르면 된다. mongosh란 MongoDB 인스턴스를 조작할 수 있도록 도와주는 shell 이다. ※ 참고URL : https://www.mongodb.com/docs/mongodb-shell/install/ Install mongosh — MongoDB Shell Docs Home → MongoDB Shell To use the MongoDB Shell, you must have a MongoDB deployment to connect to.You can use the MongoDB Shell to connect to MongoDB version 4.0..
설치 테스트는 Ububtu 20.04 버전, Java11 버전에서 확인하였다. Ububtu 환경에서 MongoDB 를 설치하기 위해서 아래의 메뉴얼을 따르면 된다. ### mongodb user/group 추가 adduser mongodb ### 패키지 정보 업데이트 sudo apt-get update ### home 디렉토리로 이동 cd /home ### MongoDB tgz 파일 다운로드 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu2004-6.0.2.tgz ### 압축풀기 tar -xzvf mongodb-linux-x86_64-ubuntu2004-6.0.2.tgz ### 디렉토리명 변경 mv mongodb-linux-x86_64..
설치 테스트는 Ububtu 20.04 버전, Java11 버전에서 확인하였다. Ububtu 환경에서 MongoDB 를 설치하기 위해서 아래의 메뉴얼을 따르면 된다. ### mongodb user/group 추가 adduser mongodb ### 패키지 정보 업데이트 sudo apt-get update ### home 디렉토리로 이동 cd /home ### MongoDB tgz 파일 다운로드 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu2004-6.0.2.tgz ### 압축풀기 tar -xzvf mongodb-linux-x86_64-ubuntu2004-6.0.2.tgz ### 디렉토리명 변경 mv mongodb-linux-x86_64..
설치 테스트는 Ububtu 20.04 버전, Java11 버전에서 확인하였다. Ububtu 환경에서 MongoDB 를 설치하기 위해서 아래의 메뉴얼을 따르면 된다. ### mongodb user/group 추가 adduser mongodb ### 패키지 정보 업데이트 sudo apt-get update ### home 디렉토리로 이동 cd /home ### MongoDB tgz 파일 다운로드 wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu2004-6.0.2.tgz ### 압축풀기 tar -xzvf mongodb-linux-x86_64-ubuntu2004-6.0.2.tgz ### 디렉토리명 변경 mv mongodb-linux-x86_64..
요즘 시대에는 구글이나 아마존, 페이스북 같은 글로벌 서비스를 제공하는 회사가 늘어나면서 방대한 양의 데이터를 서비스를 제공하는데 문제없이 빠른 속도로 처리할 수 있는 데이터베이스에 대한 필요성이 강해졌다. 대용량 데이터 서비스를 제공하기 위해서는 전통적인 RDBMS만으로는 처리하기에는 한계가 존재한다. MySQL 같이 오픈 소스 RDBMS는 비용적인 문제를 해결해주기는 하지만 이러한 MySQL도 빅데이터를 처리하기에는 무리가 있다. 예를들어 엄청난 양의 데이터가 있고, 매번 데이터베이스 스키마에 맞게 데이터를 조작하여 작업을 수행한다면 여러가지 리소스의 낭비가 발생된다고 볼 수 있다. 이를 해결하기 위해서 NoSQL이 등장하였고 다른 NoSQL과 같이 MongoDB는 이러한 문제를 해결하기 위해 적합한..
무선랜은 유선 케이블 없이 랜을 구축할 수 있는 기술이다. 지금까지는 케이블을 통해 기기 장치들을 연결하는 유선 이더넷에 대해서 알아보았다. 이와 달리 무선랜은 유선 케이블을 이용하지 않으면서도 랜을 구축할 수 있는 기술이다. 무선랜은 케이블 없이 간편하게 네트워크를 만들기 위하여 개발되었다. 랜 케이블을 사용하지 않기 때문에 케이블 배선의 관리가 필요하지 않다 보니 관리의 편의성이 높아진다. 그러나 무선 방식은 유선보다 속도가 불안정하며 전파에 영향을 많이 받는다. 또한 유선연결보다 보안상의 위험이 높아진다. type 보안 속도 안정성 편의성 유선 랜 상대적으로 보안에 취약하지 않음 빠름 안정적 선관리를 해줘야 하므로 불편함 무선 랜 상대적으로 보안에 취약함 유선 랜에 비해 느림 유선 랜에 비해 불안정..