'Redis'에 해당되는 글 2건

  1. 2016.06.14 [Redis] 우분투에서 레디스(Redis) 설치하기
  2. 2016.06.10 [Redis] 레디스 개념 및 특징 1

가상 OS를 생성하고 우분투에 정상적으로 접속을 했다면..

우분투 환경에서 마우스 오른쪽 클릭 - 터미널 열기를 해서 터미널을 연다.


그 다음에 redis파일을 다운받아야하는데 브라우저를 열고 

ZIP 파일을 직접 다운받을수도 있지만, URL주소를 통해 웹으로 다운을 받을수도 있다. 

다음과 같이 URL을 적어주면 된다.


아 그전에...


리눅스가 처음이라면 Ubuntu에 설치된 패키지들을 업데이트해줄 필요가 있다.


$sudo apt-get update 


Redis 설치


$ wget http://download.redis.io/releases/redis-3.2.0.tar.gz --> 파일 다운로드에 접속해서 파일 다운받기

$ tar xzf redis-3.2.0.tar.gz    --> 방금 받은 파일 압축 풀기

$ cd redis-3.2.0 --> 압축 푼 폴더로 이동

$ make

$ make test  

$ make install 

이것이 기본적인 Redis를 설치하는 방법이다. 

위 과정이 끝났다면 우분투에 Redis가 설치되었다.


...여기서 끝인줄 알았다.


src/redis-server도 잘 동작한다.

하지만, redis-cli는 거부된다.refuse 정상적으로 실행되지 않는다.

한 가지 빼먹은 사실이 존재했다.


위 명령어를 마치면 우분투에 redis가 설치된 상태이다.

서버를 실행하기 전에 세팅을 해줘야한다.




$ utils/install_server.sh

$ sudo apt-get install redis-tools
$ sudo apt-get install redis-server

Redis는 메모리 기반이기 때문에 


1. 최대 메모리를 얼마나 할 것인지, 

2. 포트번호는 어떻게 할 것인지

3. 로그 파일 이름은 어떻게 할 것인지,


등등 설정해 줄 것들이 있다. 자동으로 설정해주면서, 물어보는 방식이다.

그냥 Enter만 열심히 때려라.

이렇게 해야 설정한 환경으로 서버가 100% 정상적으로 동작하게 된다.

안그러면 포트가 지정이 안되어있으므로 안됨.

이제 하면된다.


Redis 서버 실행


$ src/redis-server --> 기본적인 Port로 서버가 연결된다.


Redis 클라이언트 실행

$ src/redis-cli --> 기본적인 Port로 연결되며 어떤 작업을 할 수 있는 화면으로 이동


위까지 진행헀을 때, 정상적인 동작


127.0.0.1:6379>

와 같이 표시된다면 정상적으로 설치가 완료가 되었고 작동하고 있다이다.


127.0.0.1는 당신의 IP 주소이며, 6379는 지금 동작중인 redis server의 포트번호이다.
이제 ping pong 테스트를 해보자.


127.0.0.1:6379>ping
PONG

재밌다. 이렇게 뽕이 나오면 100% 완벽하게 설치가 완료되었다.

이제 간단히 값을 한번 넣어보겠다.


127.0.0.1:6379> SET key "Hello Redis"

OK

127.0.0.1:6379> GET key

"Hello Redis"


String 하나를 넣고, 가져와봤다. 


이상으로 우분투에서 레디스를 설치하는 방법에 대해 알아봤다.


Posted by sungho88
,


[레디스 개념 및 특징]


Redis도 약자이다(REmote DIctionary Server)

Salvatore Sanfilippo라는 이탈리아 해커가 MySQL로 어떤 어플을 개발하다가 느려터졌다고 생각했고, 

직접 빠른 서버를 만들어봐야겠다고 생각했고, 

그 결과 Redis를 개발하게 되었다는 비하인드 스토리...


이 인간


[레디스 특징


1. 오픈 소스 소프트웨어고,

2. 디스크가 아닌 메모리 기반의 데이터 저장소이다. (In-Memory data structure store) 

3. NoSQL & Cache 솔루션이며 메모리 기반으로 구성된다.

4. 명시적으로 삭제, expire를 설정하지 않으면 데이터는 삭제되지 않는다(영구적 보존)

5. 여러대의 서버 구성 가능하다.

6. 데이터베이스로 사용될 수 있으며, Cache로도 사용될 수 있는 기술이다.

7. 성능은 서버에 따라 다르나 초당 2만 ~ 10만회 수행한다. 


Memory 위에서 동작하는 Key/value 저장소(Store)인 레디스는 NoSQL DBMS로 분류되며 동시에 Memcached와 같은 인메모리(In-memory) 솔루션으로 분리된다. 

성능은 Memcached이 갖고 있는 좋은점을 기반으로 만들어졌기 때문에 Memcached보다 우수하긴하지만 더욱 복잡하며, 다양한 데이터 구조체를 지원하기 때문에 Message Queue, Shared memory, Remote Dictionary 용도로 사용될 수도 있다. 

대부분의 언어를 사용할 수 있지만, Linux를 이용하기를 권장하고 있다.

그리고, 안전한 데이터의 보관과 백업을 위해 두 가지 방법을 제공한다.


1. 다른 서버의 메모리에 실시간으로 복사본을 남길 수 있다. 

2. 디스크에 직접 저장하는 방법도 존재한다.


NoSQL 중에서도 Redis가 주목을 받는 이유는 다음과 같다.

- 데이터 저장소로 입력/출력이 가장 빠른 메모리를 채택.

- 단순한 구조의 데이터 모델인 Key-Value 방식을 통해 빠른 속도.

- 캐시 및 데이터 스토어에 유리.

- 다양한 API 지원.


Redis는 페이스북, 인스타그램, 네이버 LINE 서비스, StackOverflow, 블리자드 등 대형 서비스 없체들이 사용자들의 대규모 메세지를 실시간으로 처리하기 위하여 사용하고 있다.


※인메모리 캐시(In-memory Cache)란?


메모리 캐시 기반의 제품이 많은 시스템에서 사용되는 이유는 단연 성능!!!

캐시 방식을 통해 DB Read의 부하를 감소할 수 있기 때문이다.

서비스 요청이 증가하여 DB요청이 많아지면 DB서버 부하가 증가하게 되는데 메모리 

캐시가 적용되면 성능 및 처리속도가 향상된다.


[레디스 장점]


1. 리스트, 배열과 같은 데이터를 처리하는데 유용하다.

 - value 값으로 문자열, 리스트, Set, Sorted set, Hash 등 여러 데이터 형식을 지원.

 - 따라서 다양한 방식으로 데이터를 활용할 수 있다. 

 - 리스트형 데이터 입력과 삭제가 MySQL에 비해서 10배정도 빠르다고 한다.

 - 

2. 여러 프로세스에서 동시에 같은 key에 대한 갱신을 요청할 경우,

   Atomic 처리로 데이터 부정합 방지 Atomic처리 함수를 제공(뭔 소린지 모르겠다...)


3. 메모리를 활용하면서 영속적인 데이터 보존

 - 명령어로 명시적으로 삭제, expires를 설정하지 않으면 데이터가 삭제되지 않는다.

 - 스냅샷(기억장치) 기능을 제공하여 메모리의 내용을 *.rdb 파일로 저장하여 해당 시점으로 복구할 수 있다.


4. Redis Server는 1개의 싱글 쓰레드로 수행되며, 따라서 서버 하나에 여러개의 서버를  

   띄우는 것이 가능하다.

 - Master - Slave 형식으로 구성이 가능함

 - 데이터 분실 위험을 없애주는 것이 바로 위 Master - Slave 방식이다.



위 기능을 이용하면 실시간으로 데이터를 다른 서버에 복제한다. 

즉, Master server가 down되어도, slave server로 접속하면 바로 서비스를 계속할 수 있다.

그리고 레디스의 성능을 거의 떨어뜨리지 않고 디스크 쓰기 기능을 제공한다. 

레디스 시작 시 이 데이터를 읽어 들어므로 데이터 분실 위험은 거의 없다고 봐도 된다.


5. Redis에는 5가지의 데이터형을 사용할 수 있다.

 - String

 - Lists

 - Sets

 - Sorted sets

 - Hashs



다음 블로그에서...



[참고 사이트]


http://ojava.tistory.com/70

http://bcho.tistory.com/654

http://mydb.tistory.com/210

http://redis.io/documentation

http://crystalcube.co.kr/176 


Posted by sungho88
,