ARCUS Cache Server가 제공하는 명령들의 ASCII Protocol을 기술한다. Binary protocol은 현재 지원하지 않으므로, 논의에서 제외한다.
본 문서는 ARCUS cache client 개발자를 주 대상으로 하며, ARCUS Cache Server에 관심있는 독자의 경우도 참고할 수 있다.
ASCII Protocol 관점에서 ARCUS Cache Server는 기존 memcached 기능 외에 collection 기능을 제공한다. 하나의 data만을 가지는 simple key-value 외에도 여러 data를 구조화된 형태로 저장/조회할 수 있으며, 제공하는 collection 유형은 아래와 같다.
- list : 데이터들의 linked list 구조
- set : 유일한 데이터들의 집합으로 membership 검사에 적합
- map : <field, value>쌍으로 구성된 데이터들의 집합으로 field 기준의 hash 구조
- b+tree : b+tree 키 기준으로 정렬된 데이터들의 집합으로 range scan 처리에 적합
ARCUS Cache Server를 사용함에 있어 필요한 cache key, item, slab 등의 기본 용어와 개념은 ARCUS 기본 개념에서 설명하므로, 이를 먼저 읽어보길 권한다.
ARCUS Cache Server가 제공하는 collection과 element 구조, b+tree key, element flag 등의 중요 요소들은 Collection 기본 개념에서 소개한다.
Collection 기능을 제공함에 따라 item 속성들이 확장되었으며, 이들은 Item 속성 설명에서 자세히 다룬다.
ARCUS Cache Server는 memcached 1.4 기준의 key-value 명령을 그대로 제공하며, 일부에 대해 확장된 명령을 제공한다. 따라서, 기존 memcached 1.4에서 사용한 명령들은 ARCUS Cache Server에서도 그대로 사용 가능하다. Key-Value 명령에서 key-value 유형의 item에 대해 수행가능한 명령들을 소개한다.
Collection 명령의 자세한 설명은 아래를 참고 바랍니다.
Collection 일부 명령들은 command pipelining 처리가 가능하며, Command Pipelining 기능에서 설명한다.
Collection 지원으로 인해 item 유형이 다양해 졌으며, 다양한 item 유형에 따라 item attributes도 확장되었다. Item attributes를 조회하거나 변경하기 위하여 Item Attribute 명령을 제공한다.
조건에 맞는 item 혹은 prefix 목록을 가져오는 기능으로 Scan 명령을 제공한다.
ARCUS Cache Server의 운영 상에 필요한 기능들은 Admin & Monitoring 명령으로 제공한다.