Search Results for 'NoSQL'

6 POSTS

  1. 2012.08.31 MongoDB 오픈세미나 후기
  2. 2012.04.12 Cassandra 시작시 MalformedURLException 발생
  3. 2011.11.30 MongoDB Naming Rule

MongoDB 오픈세미나 후기

Posted 2012. 8. 31. 01:00

MongoDB 국내 사용자 모임 카페(네이버)에서 주관하는 오픈세미나 참석

첫 참석이라 낯설고 지식도 없어 걱정했지만 나름 유용했음.

 

아래의 내용은 기억속에 있는 것을 까먹기 위해서 작성한 것임. 기술적인 명확한 검토는 천천히 하고자 한다.

 

오늘의 주제는 크게 FluentD 와 Redis 를 이용한 MongoDB 구성.

 

1. FluentD (www.fluentd.org)

 - 각종 파일로 쌓이게 되는 로그(아파치로그, 시스템 로그등등)를 정기적으로 access 하여 MongoDB에 넣어주는 솔루션

 ( MySQL 에도 insert할수 있도록 변형이 가능하다고 함.)

 - Ruby로 작성된 초경량 프로그램이면서 막강한 기능을 제공

 - 파일로그가 아닌 트래픽을 중간에 가로채서 MongoDB에 insert 동 가능

 - 적절히 이용할 경우 MongoDB 앞단에서 buffer의 형태로 작동하여 mongodb 부하를 줄일수 있음.

 -  Fail over 나 Load Balance 에 대한 기능은 없음. 이러한 기능을 이용하려면 Hadoop에서 이용하고 있는 Flume을 MongoDB에 맞게 변형해서 사용해야 함. (소스가 공개되어 있는 상태라서 변형에 대한 난이도는 어렵지 않다고 함.)

 - 또한 직접구현을 한다면 ascii 형태의 파일뿐 아니라 binary형태의 파일도 가능함.

 - 국내는 사용빈도가 거의 없으나 해외에서는 나름 많이 사용됨.

 

2. Redis (Membase 기반의 메모리 DB)

 - MongoDB를 서브가 아닌 메인으로 사용한다면 동적증가에 따른 성능저하를 유발한다. 그 첫번째 이유로 Locking 이다.
 - MongoDB의 고질적인 문제인 Lock(Global Lock > Db Lock > collection Lock?) 에 대한 해결책(?)으로 사용하기 위한 구성방안.

 - Redis를 읽기 전용, MongoDB는 insert, select 로 사용.

 - MongoDB로부터 주기적으로 데이터를 받아서 Redis에  insert하는 agent를 만들어야 한다.

 - Cache server형태로 사용 Memcache가 전형적인 cache server 형태로 사용되기 때문에 데이터 전체가 휘발성이 되어 전원차단시 데이터가 전부 날라가는 문제가 있으나 Redis는 DB형태를 띄기 때문에 비휘발성데이터 형태로 백업이 가능. 때문에 전원차단시에도 데이터가 날라가지 않음.

 

의문 :

NoSQL은 고성능 서버 스펙을 요구한다?

MongoDB에 사용되는 서버는 얼마만큼의 고사양으로 구현해야 하는가?

분산환경에서 Bigdata를 커버하기 위해 탄생된 것이 NoSQL인데,

고가의 고성능 서버를 요구한다는것이 쉽게 납득이 가지 않는다.

기본적으로 메모리 기반의 데이터베이스이기 때문에 메모리의 양은 충분히(적어도 16GB이상) 잡아주는 것은 인정한다.

더군다나 예전과 달리 서버에 사용되는 ECC메모리도 PC메모리 수준으로 가격이 떨어졌기 때문에 서버를 구성하는데 메모리는 더이상 부담되는 요소가 아니라고 본다.

어찌되었든 NoSQL이 수직적 확장이 아닌 수평적 확장을 표방하는 만큼 성능이 낮는 서버를 트래픽이 증가함에 따라 계속 추가하면서 BigData를 감당해야 함이 맞지 않나 생각해 본다.

물론 그 적정선의 사양이라 함이 어느정도인지는 테스트(?)가 필요할 것이다.

 

예전 카산드라의 경우 하루 1GB정도(로그성 데이터가 주를 이룸. 정확한 수치는 확인해봐야 함)의 데이터가 쌓이는 환경에서 7대정도로 커버가 가능했었다.

그때의 서버 스펙은 다음과 같다.

Dell R410 (Quad Core 2.6?) 16GB RAM, 1TB SATA HDD(No RAID 구성)

'DBMS > NoSQL' 카테고리의 다른 글

Cassandra 시작시 MalformedURLException 발생  (0) 2012.04.12
Jedis를 이용한 Redis 따라가기  (0) 2012.02.28
MongoDB Naming Rule  (0) 2011.11.30
MongoDB GUI Tool for Mac osx : MongoHub  (0) 2011.11.23
MongoDB 컴포넌트 목록  (0) 2011.10.03


여러대의 카산드라 서버중 한놈이 비정상 작동을 한다. 이유없이 트래픽이 폭주하고 덩달아 Load Average도 폭주한다.

compaction 이나 cleanup을 해봐도 제대로 말을 듣지 않는다. 하여 대기중이던 다른서버로 교체를 시작.

일을 크게 만들지 않으려고 구성된 node를 최대한 유지하는 방향으로 변경.

원격에서 작업하려니 조금은 조심스러운 상황.

 

작업순서 (Old Server )

 1. nodetool -h localhost disablethrift

 2. nodetool -h localhost disablegossip

 3. nodetool -h localhost flush

 4. killall java

 5. ip & hostname 변경

 

 작업순서 (New Server)

 1. cassandra 설정 변경(cassandra-env.sh, cassandra.yaml)

 2. ip & hostname 변경

 3. bin/cassandra 를 이용하여 시작

 

이전부터 몇번 해왔던 작업이라 아무의심없이 실행을 했다. 그런데 예상치 못한 에러 발생.

 

java.net.MalformedURLException: Local host name unknown: java.net.UnknownHostException

 

이럴때 당황치 말고 일단은 검색...

 

원인은 hostname변경이 제대로 되지 않았다는 것.

 

/etc/hosts 파일에 있는 hostname도 다시한번 확인하도록 하자.

'DBMS > NoSQL' 카테고리의 다른 글

MongoDB 오픈세미나 후기  (0) 2012.08.31
Jedis를 이용한 Redis 따라가기  (0) 2012.02.28
MongoDB Naming Rule  (0) 2011.11.30
MongoDB GUI Tool for Mac osx : MongoHub  (0) 2011.11.23
MongoDB 컴포넌트 목록  (0) 2011.10.03


MongoDB Naming Rule

Posted 2011. 11. 30. 19:36

1. Collection
Collection 은 그 이름자체로 고유ID 성격을 가진다. Collection 이름은 여느 UTF-8 문자열로 작성 가능하지만 다음의 제약이 존재한다.
- "" 빈 문자열
- null
- system. 으로 시작하는 문자열
- $ 가 들어간 문자열


2. Database
- "" 빈문자열은 사용불가
- '', .,공백문자열,$, /,\, null은 사용불가
- 모든 문자열이 소문자로 구성되어야 한다.
- 64bytes 제약
- admin : root database, 권한 관련 항목이 포함되어 있음
- local :단일 서버로만 사용될것이라면 사용가능하다. 즉 단일서버로만 사용할 경우에
- config : 샤딩구성으로 사용하고자 할때 샤딩정보를 저장하기 위해 내부적으로 사용되는 Database