# 문서 소개

ARCUS Cache Server가 제공하는 명령들의 ASCII Protocol을 기술한다. Binary protocol은 현재 지원하지 않으므로, 논의에서 제외한다.

본 문서는 ARCUS cache client 개발자를 주 대상으로 하며, ARCUS Cache Server에 관심있는 독자의 경우도 참고할 수 있다.

## Collection Support

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 처리에 적합

## Basic Concepts

ARCUS Cache Server를 사용함에 있어 필요한 cache key, item, slab 등의 기본 용어와 개념은 [1. ARCUS 기본 개념](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch01-arcus-basic-concept)에서 설명하므로, 이를 먼저 읽어보길 권한다.

ARCUS Cache Server가 제공하는 collection과 element 구조, b+tree key, element flag 등의 중요 요소들은 [2. Collection 기본 개념](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch02-collection-items)에서 소개한다.

Collection 기능을 제공함에 따라 item 속성들이 확장되었으며, 이들은 [3. Item 속성 설명](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch03-item-attributes)에서 자세히 다룬다.

## Simple Key-Value 기능

ARCUS Cache Server는 memcached 1.4 기준의 key-value 명령을 그대로 제공하며, 일부에 대해 확장된 명령을 제공한다. 따라서, 기존 memcached 1.4에서 사용한 명령들은 ARCUS Cache Server에서도 그대로 사용 가능하다. [4. Key-Value 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch04-command-key-value)에서 key-value 유형의 item에 대해 수행가능한 명령들을 소개한다.

## Collection 기능

Collection 명령의 자세한 설명은 아래를 참고 바랍니다.

* [5. List 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch05-command-list-collection)
* [6. Set 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch06-command-set-collection)
* [7. Map 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch07-command-map-collection)
* [8. B+Tree 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch08-command-btree-collection)

Collection 일부 명령들은 command pipelining 처리가 가능하며, [9. Command Pipelining 기능](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch09-command-pipelining)에서 설명한다.

## Item Attributes 기능

Collection 지원으로 인해 item 유형이 다양해 졌으며, 다양한 item 유형에 따라 item attributes도 확장되었다. Item attributes를 조회하거나 변경하기 위하여 [10. Item Attribute 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch10-command-item-attribute)을 제공한다.

## Scan 기능

조건에 맞는 item 혹은 prefix 목록을 가져오는 기능으로 [11. Scan 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch11-command-scan)을 제공한다.

## SASL Authentication 기능

ARCUS Cache Server의 인증/권한 관리 기능들은 [12. SASL 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch12-command-sasl)으로 제공한다.

## Admin & Monitoring 기능

ARCUS Cache Server의 운영 상에 필요한 기능들은 [13. Admin & Monitoring 명령](https://jam2in.gitbook.io/arcus-memcached/ascii-protocol/ch13-command-administration)으로 제공한다.
