이 글은 memcached의 일반적인 명령어를 주로 소개하고 있는데, 편집자는 꽤 좋다고 생각해서 공유하고 참고하겠습니다. 편집기를 따라 살펴보겠습니다
1. Memcache 시작을 위한 공통 매개변수
-p <num> 设置TCP端口号(默认设置为: 11211) -U <num> UDP监听端口(默认: 11211, 0 时关闭) -l <ip_addr> 绑定地址(默认:所有都允许,无论内外网或者本机更换IP,有安全隐患,若设置为127.0.0.1就只能本机访问) -c <num> max simultaneous connections (default: 1024) -d 以daemon方式运行 -u <username> 绑定使用指定用于运行进程<username> -m <num> 允许最大内存用量,单位M (默认: 64 MB) -P <file> 将PID写入文件<file>,这样可以使得后边进行快速进程终止, 需要与-d 一起使用
자세한 내용은 memcached -h
를 사용할 수 있습니다. Linux: ./usr/local/bin/memcached - d -u root -l 192.168.1.197 -m 2048 -p 12121
창 아래: d:App_Servmemcachedmemcached.exe -d RunService -l 127.0.0.1 -p 11211 -m 500
Windows에서 서비스로 등록한 후 실행:
sc.exe create Memcached_srv binpath= “d:\App_Serv\memcached\memcached.exe -d RunService -p 11211 -m 500″start= auto net start Memcached
2. 연결 및 종료
telnet 127.0.0.1 11211 quit
3. 기본 명령
5가지 기본 memcached 명령이 가장 간단한 작업을 수행합니다. 이러한 명령 및 작업은 다음과 같습니다.
set
add
replace
get
delete
키 값 올바른 표준 수정 명령입니다. 매우 간단하고 사용하기 쉬우며 모두 아래 표시된 구문을 사용합니다.
command <key> <flags> <expiration time> <bytes> <value>
매개변수는 다음과 같이 설명됩니다.
명령어 set/add/replace
키 키는 캐시된 값을 찾는 데 사용됩니다.
플래그에는 키-값 쌍이 포함될 수 있습니다. 키-값 쌍에 대한 추가 정보를 저장하기 위해 클라이언트가 사용하는 정수 매개변수
만료 시간 키-값 쌍이 보관되는 시간(초 단위, 0은 영원히 유지됨) the 캐시
bytes 캐시에 저장된 바이트 포인트 수
value 저장된 값(항상 두 번째 줄에 있음)
이제 이 명령의 실제 사용을 살펴보겠습니다.
3.1 set
set 명령은 캐시에 새로운 키-값 쌍을 추가하는 데 사용됩니다. 키가 이미 존재하는 경우 이전 값이 대체됩니다.
set 명령을 사용하는 다음 상호 작용에 유의하세요.
set userId 0 0 5 12345 STORED
set 명령을 사용하여 키-값 쌍이 올바르게 설정된 경우 서버는 STORED라는 단어로 응답합니다. 이 예에서는 키가 userId이고 값이 12345인 캐시에 키-값 쌍을 추가합니다. 만료 시간을 0으로 설정하면 이 값을 삭제할 때까지 캐시에 저장하려고 한다는 사실을 memcached에 알립니다.
3.2 add
add 명령은 키가 캐시에 없는 경우에만 캐시에 키-값 쌍을 추가합니다. 키가 캐시에 이미 존재하는 경우 이전 값은 여전히 동일하며 NOT_STORED 응답을 받게 됩니다.
다음은 add 명령을 사용하는 표준 상호 작용입니다.
set userId 0 0 5 12345 STORED add userId 0 0 5 55555 NOT_STORED add companyId 0 0 3 564 STORED
3.3 replacement
replace 명령은 키가 이미 존재하는 경우에만 캐시의 키를 교체합니다. 키가 캐시에 없으면 memcached 서버로부터 NOT_STORED 응답을 받게 됩니다.
다음은 바꾸기 명령을 사용하는 표준 상호 작용입니다.
replace accountId 0 0 5 67890 NOT_STORED set accountId 0 0 5 67890 STORED replace accountId 0 0 5 55555 STORED
마지막 두 가지 기본 명령은 가져오기 및 삭제입니다. 이러한 명령은 아래와 같이 매우 이해하기 쉽고 유사한 구문을 사용합니다.
command <key>
이 명령의 적용을 살펴보겠습니다.
3.4 get
get 명령은 이전에 추가된 키-값 쌍과 관련된 값을 검색하는 데 사용됩니다. get을 사용하여 대부분의 검색 작업을 수행합니다.
다음은 get 명령을 사용하는 일반적인 상호 작용입니다.
set userId 0 0 5 12345 STORED get userId VALUE userId 0 5 12345 END get bob END
보시다시피 get 명령은 매우 간단합니다. 키를 가지고 get을 호출하고, 캐시에 키가 존재하면 해당 값이 반환됩니다. 존재하지 않으면 아무것도 반환되지 않습니다.
3.5 delete
마지막 기본 명령어는 삭제입니다. delete 명령은 memcached의 기존 값을 삭제합니다. 키를 사용하여 삭제를 호출하고 키가 캐시에 있으면 값을 삭제합니다. 존재하지 않으면 NOT_FOUND 메시지가 반환됩니다.
다음은 삭제 명령을 사용한 클라이언트-서버 상호 작용입니다.
set userId 0 0 5 98765 STORED delete bob NOT_FOUND delete userId DELETED get userId END
memcached에서 사용할 수 있는 두 가지 고급 명령은 get과 cas입니다. get 및 cas 명령을 함께 사용해야 합니다. 값이 이미 업데이트된 경우 기존 이름/값 쌍이 새 값으로 설정되지 않도록 하려면 이 두 명령을 사용합니다. 이러한 명령을 개별적으로 살펴보겠습니다.
3.6 gets
gets 명령은 기본 get 명령과 유사하게 작동합니다. 두 명령의 차이점은 get이 이름/값 쌍의 "버전" 식별자와 매우 유사한 64비트 정수 값이라는 약간 더 많은 정보를 반환한다는 것입니다.
다음은 gets 명령을 사용한 클라이언트 서버 상호 작용입니다.
set userId 0 0 5 12345 STORED get userId VALUE userId 0 5 12345 END gets userId VALUE userId 0 5 4 12345 END
get과 gets 명령의 차이점을 고려하세요. gets 명령은 이름/값 쌍을 식별하는 추가 값(이 경우 정수 값 4)을 반환합니다. 이 이름/값 쌍에 대해 다른 set 명령이 실행되면 gets에서 반환된 추가 값은 이름/값 쌍이 업데이트되었음을 나타내도록 변경됩니다. 예가 표시됩니다:
set userId 0 0 5 33333 STORED gets userId VALUE userId 0 5 5 33333 END
您看到 gets 返回的值了吗?它已经更新为 5。您每次修改名称/值对时,该值都会发生更改。
3.7 cas
cas(check 和 set)是一个非常便捷的 memcached 命令,用于设置名称/值对的值(如果该名称/值对在您上次执行 gets 后没有更新过)。它使用与 set 命令相类似的语法,但包括一个额外的值:gets 返回的额外值。
注意以下使用 cas 命令的交互:
set userId 0 0 5 55555 STORED gets userId VALUE userId 0 5 6 55555 END cas userId 0 0 5 6 33333 STORED
如您所见,我使用额外的整型值 6 来调用 gets 命令,并且操作运行非常顺序。现在,我们来看看中的一系列命令:
使用旧版本指示符的 cas 命令
set userId 0 0 5 55555 STORED gets userId VALUE userId 0 5 8 55555 END cas userId 0 0 5 6 33333 EXISTS
注意,我并未使用 gets 最近返回的整型值,并且 cas 命令返回 EXISTS 值以示失败。从本质上说,同时使用gets 和cas 命令可以防止您使用自上次读取后经过更新的名称/值对。
缓存管理命令
最后两个 memcached 命令用于监控和清理 memcached 实例。它们是 stats 和 flush_all 命令。
3.8 stats
stats 命令的功能正如其名:转储所连接的 memcached 实例的当前统计数据。在下例中,执行 stats 命令显示了关于当前 memcached 实例的信息:
STAT pid 22459 进程ID STAT uptime 1027046 服务器运行秒数 STAT time 1273043062 服务器当前unix时间戳 STAT version 1.4.4 服务器版本 STAT libevent 2.0.21-stable STAT pointer_size 64 操作系统字大小(这台服务器是64位的) STAT rusage_user 0.040000 进程累计用户时间 STAT rusage_system 0.260000 进程累计系统时间 STAT curr_connections 10 当前打开连接数 STAT total_connections 82 曾打开的连接总数 STAT connection_structures 13 服务器分配的连接结构数 STAT reserved_fds 20 STAT cmd_get 54 执行get命令总数 STAT cmd_set 34 执行set命令总数 STAT cmd_flush 3 指向flush_all命令总数 STAT get_hits 9 get命中次数 STAT get_misses 45 get未命中次数 STAT delete_misses 5 delete未命中次数 STAT delete_hits 1 delete命中次数 STAT incr_misses 0 incr未命中次数 STAT incr_hits 0 incr命中次数 STAT decr_misses 0 decr未命中次数 STAT decr_hits 0 decr命中次数 STAT cas_misses 0 cas未命中次数 STAT cas_hits 0 cas命中次数 STAT cas_badval 0 使用擦拭次数 STAT touch_hits 0 STAT touch_misses 0 STAT auth_cmds 0 STAT auth_errors 0 STAT bytes_read 15785 读取字节总数 STAT bytes_written 15222 写入字节总数 STAT limit_maxbytes 67108864 分配的内存数(字节) STAT accepting_conns 1 目前接受的链接数 STAT listen_disabled_num 0 STAT time_in_listen_disabled_us 0 STAT threads 4 线程数 STAT conn_yields 0 STAT hash_power_level 16 STAT hash_bytes 524288 STAT hash_is_expanding 0 STAT malloc_fails 0 STAT conn_yields 0 STAT bytes 0 存储item字节数 STAT curr_items 0 item个数 STAT total_items 34 item总数 STAT expired_unfetched 0 STAT evicted_unfetched 0 STAT evictions 0 为获取空间删除item的总数 STAT reclaimed 0 STAT crawler_reclaimed 0 STAT crawler_items_checked 0 STAT lrutail_reflocked 0
此处的大多数输出都非常容易理解。我们先来看看输出,然后再使用新的键来运行一些 set 命令,并再次运行stats 命令,注意发生了哪些变化。
stats items
执行stats items,可以看到STAT items行,如果memcached存储内容很多,那么这里也会列出很多的STAT items行。
STAT items:1:number 3 STAT items:1:age 1698 STAT items:1:evicted 0 STAT items:1:evicted_nonzero 0 STAT items:1:evicted_time 0 STAT items:1:outofmemory 0 STAT items:1:tailrepairs 0 STAT items:1:reclaimed 0 STAT items:1:expired_unfetched 0 STAT items:1:evicted_unfetched 0 STAT items:1:crawler_reclaimed 0 STAT items:1:crawler_items_checked 0 STAT items:1:lrutail_reflocked 0 END
stats cachedump slabs_id limit_num
slabs_id:由stats items返回的结果(STAT items后面的数字)决定的
limit_num:返回的记录数,0表示返回所有记录
通过stats items、stats cachedump slab_id limit_num配合get命令可以遍历memcached的记录。
stats cachedump 1 0 ITEM userId [5 b; 1467903379 s] ITEM accountId [5 b; 1467903379 s] ITEM companyId [3 b; 1467903379 s] END stats cachedump 1 2 ITEM userId [5 b; 1467903379 s] ITEM accountId [5 b; 1467903379 s] END
stats slabs 显示各个slab的信息,包括chunk的大小、数目、使用情况等
STAT 1:chunk_size 96 STAT 1:chunks_per_page 10922 STAT 1:total_pages 1 STAT 1:total_chunks 10922 STAT 1:used_chunks 3 STAT 1:free_chunks 10919 STAT 1:free_chunks_end 0 STAT 1:mem_requested 232 STAT 1:get_hits 9 STAT 1:cmd_set 14 STAT 1:delete_hits 1 STAT 1:incr_hits 0 STAT 1:decr_hits 0 STAT 1:cas_hits 0 STAT 1:cas_badval 0 STAT 1:touch_hits 0 STAT active_slabs 1 STAT total_malloced 1048512
stats sizes 输出所有item的大小和个数
STAT 96 3
stats reset 清空统计数据
stats reset
RESET
3.9 flush_all
flush_all 是最后一个要介绍的命令。这个最简单的命令仅用于清理缓存中的所有名称/值对。如果您需要将缓存重置到干净的状态,则 flush_all 能提供很大的用处。下面是一个使用 flush_all 的例子:
set userId 0 0 5 55555 STORED get userId VALUE userId 0 5 55555 END flush_all OK get userId END
追加与清除命令
3.10 append
append 将数据追加到当前缓存数据的之后,当缓存数据存在时才存储。
set username 0 0 8 wayne173 STORED get username VALUE username 0 8 wayne173 END append username 0 0 5 _ages STORED get username VALUE username 0 13 wayne173_ages END
3.11 prepend
prepend 将数据追加到当前缓存数据的之前,当缓存数据存在时才存储。
set username 0 0 8 wayne173 STORED get username VALUE username 0 8 wayne173 END prepend username 0 0 5 name_ STORED get username VALUE username 0 13 name_wayne173 END
memcached还有很多命令,比如对于存储为数字型的可以通过incr/decr命令进行增减操作等等,这里只列出开发和运维中经常使用的命令,其他的不再一一举例说明。
위 내용은 Java의 일반적인 memcached 명령에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!