Cloud-Barista Integrated Monitoring Framework
[NOTE]
CB-Dragonfly is currently under development. (the latest version is 0.2 cappuccino)
So, we do not recommend using the current release in production.
Please note that the functionalities of CB-Dragonfly are not stable and secure yet.
If you have any difficulties in using CB-Dragonfly, please let us know.
(Open an issue or Join the cloud-barista Slack)
- 설치 환경: 리눅스(검증시험:Ubuntu 18.04)
- Git 설치
- Go 설치
- Go 환경 변수 설정
- 실시간 모니터링 데이터 저장소 설치
- 시계열 모니터링 데이터 저장소 설치
- 멀티 클라우드 모니터링 프레임워크 (cb-dragonfly) 설치
- 멀티 클라우드 모니터링 프레임워크 (cb-dragonfly) 실행
-
Git 설치
$ sudo apt update
$ sudo apt install git
$ sudo apt-get install git-core
-
Go 설치
- https://golang.org/doc/install
(2019년 11월 현재
$ sudo apt install golang
으로 설치하면 1.10 설치됨. 이 링크에서 1.12 이상 버전으로 설치할 것(Go mod 호환성 문제)) $ wget https://dl.google.com/go/go1.13.4.linux-amd64.tar.gz
(설치 파일 다운로드)$ sudo tar -C /usr/local -xzf go1.13.4.linux-amd64.tar.gz
(압축해제)
- https://golang.org/doc/install
(2019년 11월 현재
-
Go 환경 변수 설정
$ sudo echo "export PATH=$PATH:/usr/local/go/bin" >> ~/.bashrc
(GOROOT{/usr/local/go/bin}를 PATH 환경 변수에 추가하여 ~/.bashrc 맨 아래줄에 추가)$ source ~/.bashrc
(수정한 bashrc 파일 반영)$ go version
(GO 버전 확인)
-
실시간 모니터링 데이터 저장소 설치
-
etcd (3.3.11) 설치 및 실행
- `$ wget https://github.com/coreos/etcd/releases/download/v3.3.11/etcd-v3.3.11-linux-amd64.tar.gz` (설치 파일 다운로드) - `$ sudo tar -xvf etcd-v3.3.11-linux-amd64.tar.gz` (압축해제) - `$ sudo mv etcd-v3.3.11-linux-amd64/etcd* /usr/local/bin/` (추출된 실행파일을 로컬 저장소로 이동) - `$ etcd --version` (버전 확인) - `$ sudo mkdir -p /var/lib/etcd/` (Etcd 구성 파일 폴더 생성) - `$ sudo mkdir /etc/etcd` (데이터 폴더 생성) - `$ sudo groupadd --system etcd` (etcd 시스템 그룹 생성) - `$ sudo useradd -s /sbin/nologin --system -g etcd etcd` (etcd 시스템 사용자 생성) - `$ sudo chown -R etcd:etcd /var/lib/etcd/` (/var/lib/etcd/ 폴더 소유권을 etcd사용자로 설정) - `$ sudo vim /etc/systemd/system/etcd.service` (etcd에 대한 새로운 시스템 서비스 파일 작성) (바로 밑에 코드 붙여넣기 후) - `$ sudo systemctl daemon-reload` (데몬 재시작) - `$ sudo systemctl start etcd.service` (etcd 서비스 시작)
-
etcd.service 등록
[Unit] Description=etcd key-value store Documentation=https://github.com/etcd-io/etcd After=network.target [Service] User=etcd Type=notify Environment=ETCD_DATA_DIR=/var/lib/etcd Environment=ETCD_NAME=%m ExecStart=/usr/local/bin/etcd Restart=always RestartSec=10s LimitNOFILE=40000 [Install] WantedBy=multi-user.target
-
-
모니터링 시계열 데이터 저장소 설치
-
influxdb(1.7.8) 설치 및 실행
- `$ wget https://dl.influxdata.com/influxdb/releases/influxdb_1.7.8_amd64.deb` (패키지 파일 다운로드) - `$ sudo dpkg -i influxdb_1.7.8_amd64.deb` (패키지 설치) - `$ sudo systemctl start influxdb` (influxDB 서비스 시작) - `$ influx --version` (버전 확인) - `$ influx` (influxDB 사용하기) - CREATE DATABASE cbmon
-
-
멀티 클라우드 모니터링 프레임워크 (cb-dragonfly) 설치
-
Git Project Clone
- `$ sudo git config --global color.ui "auto"` (Git 소스에 색 구분) - `$ sudo git clone https://github.com/cloud-barista/cb-dragonfly.git` (Git 프로젝트 CLone) - `username = {{GitUserEmail}}` (Clone시 자격여부 확인 : 자신의 Git Email 입력) - `Password = {{GitUserPW}}` (Clone시 자격여부 확인 : 자신의 Git PW 입력)
-
Go mod 기반 의존성 라이브러리 로드
- `$ cd ~/cb-dragonfly` (clone한 프로젝트 파일로 들어가기) - `$ go mod download` (.mod 파일에 등록된 라이브러리 다운로드 실행)
-
Go mod 기반 의존성 라이브러리 다운로드 확인
- `$ go mod verify` (다운로드 확인)
-
환경변수 설정
- `$ sudo vim conf/setup.env` (실행에 필요한 PATH를 처리할 파일 생성 (현 위치: ~/cb-dragonfly)) setup.env에 추가 export CBSTORE_ROOT=~/cb-dragonfly export CBLOG_ROOT=~/cb-dragonfly export CBMON_ROOT=~/cb-dragonfly export SPIDER_URL=http://localhost:1024 - `$ source conf/setup.env` (수정한 setup.env 반영) - `$ go run pkg/manager/main/main.go` (실행)
-
config 파일 설정 (config 파일에 influxdb IP 및 사용자 정보, etcd IP 정보, cb-dragonfly 호스트 IP 정보, 모니터링 정책을 순차적으로 입력)
- # influxdb connection info influxdb: endpoint_url: http://{{influxdb_ip}}:8086 database: cbmon user_name: {{user_name}} password: {{password}} # etcd connection info etcd: endpoint_url: http://{{etcd_ip}}:2379 ttl: 60 # time to live (s) # collect manager configuration info collect_manager: collector_ip: {{collector_ip}} collector_port: 8094 # udp port collector_count: 1 # default collector count # below is default setting # monitoring interval configuration info monitoring: agent_interval: 2 # agent interval (s) agent_TTL: 5 # agent TTL (s) collector_interval: 10 # aggregate interval (s) schedule_interval: 10 # scale interval (s) max_host_count: 10 # maximum host count per collector
-
-
멀티 클라우드 모니터링 프레임워크(cb-dragonfly) 실행
-
프로젝트 빌드 및 실행
- `$ cd ~/cb-dragonfly` - `$ go run pkg/manager/main/main.go` (cb-dragonfly 프로젝트 빌드 및 실행)
-