{"id":459978,"date":"2025-05-16T15:02:12","date_gmt":"2025-05-16T15:02:12","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=459978"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=459978","title":{"rendered":"<span>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0432 Redis \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f<\/span>"},"content":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u0427\u0430\u0441\u0442\u044c 1: <a href=\"https:\/\/habr.com\/ru\/articles\/907408\/\" rel=\"noopener noreferrer nofollow\">https:\/\/habr.com\/ru\/articles\/907408\/<\/a><\/p>\n<p>\u0414\u043e \u0432\u0435\u0440\u0441\u0438\u0438 7.4 \u0432 redis \u0441\u0440\u043e\u043a \u0436\u0438\u0437\u043d\u0438 \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u0441\u0440\u043e\u043a \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430. \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 7.4 \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0438 \u0434\u043b\u044f \u043f\u043e\u043b\u044f \u0432 \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446(hashes).<br \/>\u0421\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 2 \u0441\u043f\u043e\u0441\u043e\u0431\u0430 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f:<\/p>\n<ul>\n<li>\n<p>\u043b\u0435\u043d\u0438\u0432\u044b\u0439<\/p>\n<\/li>\n<li>\n<p>\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439<\/p>\n<\/li>\n<\/ul>\n<p>\u041a\u0430\u043a \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442? \u041a\u0430\u043a\u0438\u0435 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u0443\u0447\u0435\u0441\u0442\u044c \u043f\u0440\u0438 \u043f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0441\u0445\u0435\u043c\u044b \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f?<br \/>\u0422\u0435\u043a\u0443\u0449\u0430\u044f \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0442\u0430\u043a\u043e\u0432\u0430, \u0447\u0442\u043e \u0434\u043b\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0438 \u043f\u043e\u043b\u0435\u0439 \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446 \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u0440\u0430\u0437\u043d\u043e\u043c\u0443.<\/p>\n<h2>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f<\/h2>\n<p>\u041a\u0430\u043a \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0441\u0440\u043e\u043a\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439. \u0441\u043c. \u0444\u0430\u0439\u043b &#8216;server.h&#8217; \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430<\/p>\n<pre><code>typedef struct redisDb {  kvstore *keys; \/* The keyspace for this DB. As metadata, holds keysizes histogram *\/  kvstore *expires; \/* Timeout of keys with a timeout set *\/<\/code><\/pre>\n<p>\u041a\u0430\u043a \u0443\u0436\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e \u0432 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0434\u043b\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441\u0440\u043e\u043a\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u043c kvstore, \u0432 \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446\u0435: \u043a\u043b\u044e\u0447-&#171;\u0441\u0440\u043e\u043a \u0436\u0438\u0437\u043d\u0438&#187;<\/p>\n<p>\u0421\u0443\u0442\u044c \u043b\u0435\u043d\u0438\u0432\u043e\u0433\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u0430: \u043f\u0440\u0438 \u043b\u044e\u0431\u043e\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u0435 \u043a \u043a\u043b\u044e\u0447\u0443 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u0435\u0433\u043e \u0441\u0440\u043e\u043a \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f. \u0415\u0441\u043b\u0438 \u043a\u043b\u044e\u0447 \u043f\u0440\u043e\u0442\u0443\u0445, \u0442\u043e \u043f\u0435\u0440\u0435\u0434 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u0435\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0435\u0433\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435.<\/p>\n<h2>\u0410\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431<\/h2>\n<p>\u0420\u0430\u0431\u043e\u0442\u0430 \u043f\u043e \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043a\u043b\u044e\u0447\u0435\u0439 \u0432 \u0444\u0430\u0439\u043b\u0435 <code>expire.c<\/code><br \/> \u0410\u043a\u0442\u0438\u0432\u043d\u044b\u0439  \u0441\u043f\u043e\u0441\u043e\u0431 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445<\/p>\n<ul>\n<li>\n<p>\u0442.\u043d. FAST. \u0412\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 event loop. \u041e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442 \u043d\u0435\u043c\u043d\u043e\u0433\u043e, \u0437\u0434\u0435\u0441\u044c \u043c\u044b \u0435\u0433\u043e \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0435\u043c.  \u0414\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0446\u0438\u043a\u043b\u0430 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0438 \u043e\u0431\u044a\u0451\u043c \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439  \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d \u0438\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 <code>active-expire-effort<\/code> &#8212; 1 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u041a\u0430\u043a \u0431\u0443\u0434\u0435\u0442 \u0432\u0438\u0434\u043d\u043e \u043d\u0438\u0436\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 active-expire-effort \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c \u043e\u0431\u044a\u0451\u043c \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c\u044b\u0445 \u0437\u0430 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044e<\/p>\n<\/li>\n<\/ul>\n<pre><code>\/\/ \u043f\u0440\u0438\u043c. ACTIVE_EXPIRE_CYCLE_FAST_DURATION - 1000 \u043c\u043a\u0441 ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP - 20 \u0448\u0442. ..... effort = server.active_expire_effort-1, \/* Rescale from 0 to 9. *\/ config_keys_per_loop = ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP + ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP\/4*effort, config_cycle_fast_duration = ACTIVE_EXPIRE_CYCLE_FAST_DURATION + ACTIVE_EXPIRE_CYCLE_FAST_DURATION\/4*effort<\/code><\/pre>\n<p>\u041d\u0435 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442, \u0435\u0441\u043b\u0438 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0430\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432\u044b\u0448\u043b\u0430 \u0437\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u043b\u0438\u043c\u0438\u0442. (\u0442.\u0435. \u043d\u0435 \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u043c event loop \u0435\u0441\u043b\u0438 \u043f\u043e \u043e\u0431\u044a\u0451\u043c\u0443 \u043d\u0435\u0443\u0434\u0430\u043b\u0451\u043d\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u0432\u0441\u0451 \u043f\u043b\u043e\u0445\u043e)<\/p>\n<ul>\n<li>\n<p>\u0442.\u043d. SLOW.  \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u043a\u0440\u043e\u043d\u0443 (\u043c\u043e\u0436\u043d\u043e \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0432 debug-\u0440\u0435\u0436\u0438\u043c\u0435 \u0447\u0435\u0440\u0435\u0437 <code>set-active-expire 0<\/code>) \u0441 \u0447\u0430\u0441\u0442\u043e\u0442\u043e\u0439 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e 10 \u0440\u0430\u0437 \u0432 \u0441\u0435\u043a\u0443\u043d\u0434\u0443 (\u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 \u043a\u043e\u043d\u0444\u0438\u0433\u0430 <code>hz 10<\/code>).<\/p>\n<\/li>\n<\/ul>\n<pre><code>void databasesCron(void) {     \/* Expire keys by random sampling. Not required for slaves      * as master will synthesize DELs for us. *\/     if (server.active_expire_enabled) {         if (iAmMaster()) {             activeExpireCycle(ACTIVE_EXPIRE_CYCLE_SLOW);         } else {         \u043a\u0430\u043a \u043f\u043e \u043c\u043d\u0435 \u044d\u0442\u043e \u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0442\u0440\u044f\u043f\u043a\u0430 \u0438 \u044d\u0442\u0438\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0435\u043b\u044c\u0437\u044f         * Expires of keys created in writable slaves          * This implementation is currently not perfect but a lot better than leaking  * the keys as implemented in 3.2.             expireSlaveKeys();         }     }<\/code><\/pre>\n<p>\u041f\u043e \u0441\u0443\u0442\u0438 \u044d\u0442\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0440\u0435\u0436\u0438\u043c \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0436\u0438\u0437\u043d\u0438. \u0415\u0433\u043e \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0434\u0430\u043b\u0435\u0435. \u041e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0432 DEBUG \u0440\u0435\u0436\u0438\u043c\u0435 \u0447\u0435\u0440\u0435\u0437 <code>DEBUG set-active-expire 0<\/code><\/p>\n<ul>\n<li>\n<p>\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0435\u0449\u0451 \u0430\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u043d\u0430 &#171;writable slaves&#187; \u043d\u043e \u0434\u043b\u044f \u043c\u0435\u043d\u044f \u0432\u043e\u0442 \u0442\u0430\u043a\u043e\u0435 &#171;\u0438\u043d\u0442\u0440\u043e&#187; \u043f\u0435\u0440\u0435\u0434 \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>expireSlaveKeys<\/code> &#171;&#8230;Expires of keys created in writable slaves&#8230; This implementation is currently not perfect but a lot better than leaking the keys as implemented in 3.2.&#187; &#8212; \u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u0444\u043b\u0430\u0433 \u0434\u043b\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0432 \u043f\u0440\u043e\u0434 \u0440\u0435\u0436\u0438\u043c\u0435. \u0415\u0451 \u044f \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u043d\u0435 \u0432\u0438\u0436\u0443 \u0441\u043c\u044b\u0441\u043b\u0430.<\/p>\n<\/li>\n<\/ul>\n<h4>SLOW \u0440\u0435\u0436\u0438\u043c \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c <\/h4>\n<p>\u041f\u043e \u0441\u0443\u0442\u0438 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 FAST \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u043d\u044b\u043c\u0438 \u043b\u0438\u043c\u0438\u0442\u0430\u043c\u0438 \u043d\u0430 \u0447\u0438\u0441\u043b\u043e \u043a\u043b\u044e\u0447\u0435\u0439 \u0438 \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f. \u0421\u0445\u0435\u043c\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u043a\u0440\u0430\u0442\u043a\u043e:<\/p>\n<pre><code class=\"cpp\">void activeExpireCycle(int type){ ...         \/* \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u043f\u043e\u043b\u044f \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446-\u043e\u0432*\/         activeExpireHashFieldCycle(type); ...   for (j = 0; dbs_performed &lt; dbs_per_call &amp;&amp; timelimit_exit == 0 &amp;&amp; j &lt; server.dbnum; j++) {   ...                 \/\/\u043f\u043e\u0442\u043e\u043c \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u043c\u0441\u044f \u043f\u043e \u043a\u043b\u044e\u0447\u0430\u043c \u0431\u0430\u0437\u044b                 while (data.sampled &lt; num &amp;&amp; checked_buckets &lt; max_buckets) {                 db-&gt;expires_cursor = kvstoreScan(db-&gt;expires, db-&gt;expires_cursor, -1, expireScanCallback, isExpiryDictValidForSamplingCb, &amp;data);                 if (db-&gt;expires_cursor == 0) {                     db_done = 1;                     break;                 }                 checked_buckets++;             }     \/\/\u043f\u043e\u0434\u0431\u0438\u0432\u0430\u0435\u043c \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0443 \u0434\u043b\u044f \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433\u0430 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438   } }<\/code><\/pre>\n<p>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043a\u043b\u044e\u0447\u0435\u0439 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0431\u0430\u0437\u044b \u0432 redis \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e. \u0411\u0430\u0437\u044b \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u043b\u0438 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0439 \u0446\u0438\u043a\u043b \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u0445 \u043a\u043b\u044e\u0447\u0435\u0439. \u0426\u0438\u043a\u043b \u043f\u043e \u043a\u0430\u0436\u0434\u043e\u0439 \u0411\u0414 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0430: \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u043a\u043b\u044e\u0447\u0435\u0439 \u0434\u043b\u044f \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0430 \u0437\u0430 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044e <code>config_keys_per_loop = ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP + ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP\/4*effort<\/code>.<br \/> \u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043d\u0430\u0434 \u0431\u0430\u0437\u043e\u0439 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043e:<\/p>\n<ul>\n<li>\n<p>\u0434\u043e\u043f\u0443\u0441\u0442\u0438\u043c\u044b\u043c \u0443\u0440\u043e\u0432\u043d\u0435\u043c \u0443\u0434\u0430\u043b\u0451\u043d\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0442 \u0447\u0438\u0441\u043b\u0430 \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u043d\u044b\u0445, \u0442.\u0435. \u0435\u0441\u043b\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0440\u043e\u0433\u0430,  \u0441\u0447\u0438\u0442\u0430\u0435\u043c \u0434\u0430\u043b\u044c\u0448\u0435 \u0438\u0441\u043a\u0430\u0442\u044c \u043f\u043e \u0431\u0430\u0437\u0435 \u043d\u0435\u0442 \u0441\u043c\u044b\u0441\u043b\u0430, \u0448\u0430\u043d\u0441\u043e\u0432 \u043d\u0430\u0439\u0442\u0438 \u043a\u043b\u044e\u0447 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u043c\u0430\u043b\u043e.<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"cpp\">\/\/ACTIVE_EXPIRE_CYCLE_ACCEPTABLE_STALE 10% config_cycle_acceptable_stale = ACTIVE_EXPIRE_CYCLE_ACCEPTABLE_STALE- effort; repeat = db_done ? 0 : (data.sampled == 0 || (data.expired * 100 \/ data.sampled) &gt; config_cycle_acceptable_stale);<\/code><\/pre>\n<p>\u043f\u0440\u043e\u0446\u0435\u043d\u0442 \u0442\u0430\u043a \u0436\u0435 \u0440\u0435\u0433\u0443\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <code>active-expire-effort<\/code><\/p>\n<ul>\n<li>\n<p>\u043b\u0438\u043c\u0438\u0442\u043e\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043e\u0442\u043f\u0443\u0449\u0435\u043d\u043d\u044b\u043c \u043d\u0430 \u0446\u0438\u043a\u043b \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u043f\u043e \u0431\u0430\u0437\u0430\u043c. \u0414\u043b\u044f SLOW \u0446\u0438\u043a\u043b\u0430 \u044d\u0442\u043e\u0442 \u043f\u0435\u0440\u0438\u043e\u0434 &#8212; 25\u043c\u0441 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u041d\u0438\u0436\u0435 \u0438\u0437 \u0444\u043e\u0440\u043c\u0443\u043b \u043f\u043e\u043d\u044f\u0442\u043d\u043e \u043a\u0430\u043a \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c \u044d\u0442\u0438\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c. \u041b\u0438\u043c\u0438\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043a\u0430\u0436\u0434\u044b\u0435 16 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u043f\u043e \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"cpp\">#define ACTIVE_EXPIRE_CYCLE_SLOW_TIME_PERC 25 \/* Max % of CPU to use. *\/ ... timelimit = config_cycle_slow_time_perc*1000000\/server.hz\/100; ... config_cycle_slow_time_perc = ACTIVE_EXPIRE_CYCLE_SLOW_TIME_PERC + 2*effort<\/code><\/pre>\n<p>\u042d\u0442\u043e\u0442 \u043b\u0438\u043c\u0438\u0442 <strong>\u043e\u0431\u0449\u0438\u0439<\/strong> \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u0431\u0430\u0437, \u0442.\u0435. \u0435\u0441\u043b\u0438 \u043d\u0430 \u0446\u0438\u043a\u043b\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u043f\u0435\u0440\u0432\u043e\u0439 \u0431\u0430\u0437\u044b \u043c\u044b \u0432\u044b\u0448\u043b\u0438 \u0437\u0430 \u043d\u0435\u0433\u043e, \u0442\u043e \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u043d\u0438\u0435 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0431\u0430\u0437 <strong>\u043d\u0435 \u043d\u0430\u0447\u043d\u0451\u0442\u0441\u044f<\/strong> \u0432 \u044d\u0442\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043a\u0440\u043e\u043d\u0430.<\/p>\n<p>\u0421\u0430\u043c\u0430 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u043e \u0431\u0430\u0437\u0435 \u043f\u0440\u043e\u0441\u0442\u0430 (\u0435\u0441\u043b\u0438 \u043e\u043d\u0430 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 1 \u0442\u0430\u0431\u043b\u0438\u0446\u0435, \u0435\u0441\u043b\u0438 \u0443 \u043d\u0430\u0441 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u0438 16\u041a \u0441\u043b\u043e\u0442\u043e\u0432 \u0438 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u0438\u043b\u0438 \u043c\u044b \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043f\u0435\u0440\u0435\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f &#8212; \u0442\u0443\u0442 \u0441\u043b\u043e\u0436\u043d\u0435\u0435):<br \/> \u041f\u0440\u043e\u0445\u043e\u0434\u0438\u043c\u0441\u044f \u043f\u043e \u0431\u0430\u043a\u0435\u0442\u0430\u043c KV \u0445\u0440\u0430\u043d\u0438\u043b\u0438\u0449\u0430 db-&gt;expires \u0441 \u0442\u043e\u0433\u043e \u043c\u0435\u0441\u0442\u0430 \u0441 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u043b\u0438 \u0432 \u043f\u0440\u043e\u0448\u043b\u044b\u0439 \u0440\u0430\u0437 (expires_cursor)<\/p>\n<pre><code class=\"cpp\">while (data.sampled &lt; num &amp;&amp; checked_buckets &lt; max_buckets) { db-&gt;expires_cursor = kvstoreScan(db-&gt;expires, db-&gt;expires_cursor, -1, expireScanCallback, isExpiryDictValidForSamplingCb, &amp;data); if (db-&gt;expires_cursor == 0) { db_done = 1; break; } checked_buckets++; } <\/code><\/pre>\n<p>\u0438 \u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e DictEntry \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0422\u0422\u041b, \u0435\u0441\u043b\u0438 DictEntry \u043f\u0440\u043e\u0442\u0443\u0445, \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u043c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435.<\/p>\n<pre><code class=\"cpp\">int activeExpireCycleTryExpire(redisDb *db, dictEntry *de, long long now) {     long long t = dictGetSignedIntegerVal(de);     if (now &lt; t)         return 0;      enterExecutionUnit(1, 0);     sds key = dictGetKey(de);     robj *keyobj = createStringObject(key,sdslen(key));     deleteExpiredKeyAndPropagate(db,keyobj);     decrRefCount(keyobj);     exitExecutionUnit();     \/* Propagate the DEL command *\/     postExecutionUnitOperations();     return 1; }<\/code><\/pre>\n<p>\u043f\u043b\u044e\u0441\u044b \u043f\u043e\u0434\u0445\u043e\u0434\u0430:<\/p>\n<ul>\n<li>\n<p>\u043f\u043e\u0438\u0441\u043a, \u0432\u0441\u0442\u0430\u0432\u043a\u0430 \u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 &#8212; \u0438\u043c\u0435\u044e\u0442 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u043d\u0443\u044e \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c <\/p>\n<\/li>\n<\/ul>\n<p>\u043c\u0438\u043d\u0443\u0441\u044b:<\/p>\n<ul>\n<li>\n<p>\u043d\u0435\u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438. \u0412\u0430\u0436\u043d\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u043c\u044b \u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0439\u0442\u0438\u0441\u044c \u043f\u043e \u0431\u0430\u043a\u0435\u0442\u0430\u043c \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u043a\u043b\u044e\u0447\u0438 \u0442\u0430\u043c \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u044b \u043f\u043e \u0444\u0430\u043a\u0442\u0443 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c, \u0435\u0441\u043b\u0438 \u0433\u043e\u0434\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u0434\u043b\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 &#171;\u0432 \u043c\u043e\u043c\u0435\u043d\u0442\u0435&#187; \u043c\u0430\u043b\u043e, \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u043e\u0434\u043d\u0443 &#171;\u043f\u0440\u043e\u0431\u0443&#187; \u0438 \u043a\u043e\u0433\u0434\u0430 \u043e\u043d\u0430 \u043f\u043e\u043a\u0430\u0436\u0435\u0442 \u043d\u0438\u0437\u043a\u0438\u0439 \u043f\u0440\u043e\u0446\u0435\u043d\u0442 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043f\u0435\u0440\u0435\u0439\u0434\u0451\u043c \u043a \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0431\u0430\u0437\u0435. \u042d\u0442\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043c\u0435\u0442\u043e\u0434\u0430.<\/p>\n<\/li>\n<li>\n<p>\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f r\u043f\u0435\u0440\u0435\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0440\u0438 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432 kv-\u0441\u0442\u043e\u0440\u0435 expires \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438<\/p>\n<\/li>\n<li>\n<p>\u043e\u0431\u044a\u0451\u043c \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u043c\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u0438: 40 \u0431\u0430\u0439\u0442 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442.<\/p>\n<\/li>\n<\/ul>\n<h3>\u041c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430<\/h3>\n<p>\u041d\u0430 \u043a\u0430\u043a\u0438\u0435 \u043c\u0435\u0442\u0440\u0438\u043a\u0438 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f \u043f\u0440\u0438 \u043e\u0446\u0435\u043d\u043a\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u0434\u0451\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0436\u0438\u0437\u043d\u0438<\/p>\n<h4>INFO STATS<\/h4>\n<ul>\n<li>\n<p><code>avg_ttl<\/code> &#8212; \u043a\u0430\u0436\u0434\u044b\u0435 16 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 (\u043b\u0438\u0431\u043e \u0432 \u043a\u043e\u043d\u0446\u0435 \u0446\u0438\u043a\u043b\u0430) \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0431\u0430\u0437\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u0440\u0435\u0434\u043d\u0438\u0439 ttl \u043f\u043e \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u043d\u044b\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c;<\/p>\n<\/li>\n<li>\n<p><code>expired_time_cap_reached_count<\/code> &#8212; \u0444\u0430\u043a\u0442 \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u044f \u043e\u0431\u0449\u0435\u0433\u043e \u043b\u0438\u043c\u0438\u0442\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043d\u0430 \u0446\u0438\u043a\u043b \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0441\u0440\u043e\u0447\u0435\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439;<\/p>\n<\/li>\n<li>\n<p><code>expire_cycle_cpu_milliseconds<\/code> &#8212; \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u043e\u0442\u0440\u0430\u0447\u0435\u043d\u043e \u043d\u0430 \u0430\u043a\u0442\u0438\u0432\u043d\u0443\u044e \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044e<\/p>\n<\/li>\n<li>\n<p><code>expired_stale_perc<\/code> &#8212; \u043e\u0446\u0435\u043d\u043a\u0430 \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0436\u0438\u0434\u0430\u044e\u0442 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0438\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441\u0430 \u0432 \u0442\u0435\u043a\u0443\u0449\u0435\u043c \u0446\u0438\u043a\u043b\u0435<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"cpp\">if (total_sampled) { current_perc = (double)total_expired\/total_sampled; } else current_perc = 0; server.stat_expired_stale_perc = (current_perc*0.05)+ (server.stat_expired_stale_perc*0.95);<\/code><\/pre>\n<ul>\n<li>\n<p><code>expired_keys<\/code> &#8212; \u0432\u0441\u0435\u0433\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u043e \u043f\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043c\u043e\u043c\u0435\u043d\u0442\u0430 \u0441\u0431\u0440\u043e\u0441\u0430 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u043f\u043e \u0431\u0430\u0437\u0435.<\/p>\n<\/li>\n<\/ul>\n<h4>INFO KEYSPACE<\/h4>\n<pre><code>db0:keys=13906244,expires=13906244,avg_ttl=882,subexpiry=0<\/code><\/pre>\n<p>expires &#8212; \u0440\u0430\u0437\u043c\u0435\u0440 KV expires \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445<\/p>\n<h4>\u041a\u043e\u043d\u0442\u0440\u043e\u043b\u044c latency<\/h4>\n<p>\u041f\u0440\u0438 \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u0438 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043f\u043e\u0440\u043e\u0433\u0430 &#171;latency-monitor-threshold&#187; \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0431\u044b\u0442\u0438\u0435 &#171;expire-cycle&#187;.<br \/> \u041a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043c\u043e\u0436\u043d\u043e:<br \/> <code>latency history expire-cycle<\/code><br \/> \u043f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0432\u043e\u0434\u0430:<\/p>\n<pre><code>127.0.0.1:16379&gt; latency history expire-cycle   1) 1) (integer) 1747146747      2) (integer) 13   2) 1) (integer) 1747146749      2) (integer) 10   3) 1) (integer) 1747146750      2) (integer) 18   4) 1) (integer) 1747146751      2) (integer) 20   5) 1) (integer) 1747146752      2) (integer) 17   6) 1) (integer) 1747146753<\/code><\/pre>\n<p>\u041a\u043e\u0433\u0434\u0430 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d \u043f\u043e\u0440\u043e\u0433? \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043a\u043e\u0433\u0434\u0430 \u0443 \u043d\u0430\u0441 \u0432 \u043c\u043e\u043c\u0435\u043d\u0442\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044f \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439.<\/p>\n<h3>\u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u043f\u043e\u0449\u0443\u043f\u0430\u0442\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u0440\u0443\u043a\u0430\u043c\u0438<\/h3>\n<p>\u0418\u043c\u0435\u0435\u043c \u0432 \u0411\u0414 0 \u0434\u0432\u0430 \u0432\u0438\u0434\u0430 \u043a\u043b\u044e\u0447\u0435\u0439 (<a href=\"https:\/\/github.com\/xelavopelk\/redis-go-test\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/xelavopelk\/redis-go-test<\/a>): 30 \u043c\u043b\u043d \u0441 \u043f\u0440\u043e\u0442\u0443\u0445\u0430\u043d\u0438\u0435\u043c \u0432 \u0441\u0443\u0442\u043a\u0438 \u0438 2 \u043c\u043b\u043d \u0441 \u043f\u0440\u043e\u0442\u0443\u0445\u0430\u043d\u0438\u0435\u043c \u0432 \u0442\u0435\u0447\u0435\u043d\u0438\u0438 \u043c\u0438\u043d\u0443\u0442\u044b (\u0434\u0430\u043b\u0435\u0435 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u0430 \u0436\u0435 \u0441\u0445\u0435\u043c\u0430 \u0434\u043b\u044f \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f). \u0421\u043c\u043e\u0442\u0440\u0438\u043c \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438.<\/p>\n<ul>\n<li>\n<p>\u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0442\u0435\u043c\u043f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 case1, \u0432\u0441\u0435 \u043a\u043b\u044e\u0447\u0438 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0411\u0414 . \u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e, \u0437\u0430 3 \u043c\u0438\u043d\u0443\u0442\u044b \u0443\u0434\u0430\u043b\u0435\u043d\u043e \u0432\u0441\u0435\u0433\u043e \u043f\u043e\u0440\u044f\u0434\u043a\u0430 3 \u0442\u044b\u0441 \u043a\u043b\u044e\u0447\u0435\u0439. \u0415\u0441\u043b\u0438 \u0431\u0430\u0437\u0430 \u0431\u0443\u0434\u0435\u0442 \u043d\u0430\u043f\u043e\u043b\u043d\u044f\u0442\u044c\u0441\u044f, \u0442\u043e \u043f\u043e \u0441\u0443\u0442\u0438 \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u0443\u0434\u0430\u043b\u0435\u043d\u044b, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u0447\u043d\u0451\u0442\u0441\u044f \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0441\u0443\u0442\u043e\u0447\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u043b\u0438\u0431\u043e \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u043c \u0441 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435\u043c \u043e\u0431\u044a\u0451\u043c\u0430 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f.<\/p>\n<\/li>\n<\/ul>\n<pre><code>ts: 02:01:30 PM info: # Keyspace db0:keys=31999999,expires=31999999,avg_ttl=81010601,subexpiry=0  ...  ts: 02:04:40 PM info:  # Keyspace  db0:keys=31997626,expires=31997626,avg_ttl=86082556,subexpiry=0<\/code><\/pre>\n<ul>\n<li>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b\u043d\u0435\u0441\u0442\u0438 &#171;\u043c\u0438\u043d\u0443\u0442\u043d\u044b\u0435&#187; \u043a\u043b\u044e\u0447\u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e &#8212; case2 &#8212; \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u043e<\/p>\n<\/li>\n<\/ul>\n<pre><code>ts: 02:35:27 db1:keys=2000000,expires=2000000,avg_ttl=41059,subexpiry=0 ... ts: 02:36:27 PM info:  # Keyspace db1:keys=268836,expires=268836,avg_ttl=3407,subexpiry=0 \/\/\u0434\u0430\u043b\u0435\u0435 \u043f\u0443\u0441\u0442\u043e<\/code><\/pre>\n<p>\u0442.\u043e. \u0437\u0430 1 \u043c\u0438\u043d\u0443\u0442\u0443 \u0443\u0448\u043b\u043e 2 \u043c\u043b\u043d \u043a\u043b\u044e\u0447\u0435\u0439. <\/p>\n<p><strong>\u0412\u044b\u0432\u043e\u0434<\/strong>: \u0435\u0441\u043b\u0438 \u043d\u0435 \u0445\u043e\u0447\u0435\u0448\u044c, \u0447\u0442\u043e\u0431\u044b \u0431\u043e\u043b\u0435\u043b\u0430 \u0433\u043e\u043b\u043e\u0432\u0430 \u043d\u0435 \u0441\u0442\u043e\u0438\u0442 \u043c\u0435\u0448\u0430\u0442\u044c \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043e\u0434\u043a\u0443 \u0441 \u043f\u0438\u0432\u043e\u043c, \u043d\u043e \u0438 \u043a\u043b\u044e\u0447\u0438 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0436\u0438\u0437\u043d\u0438 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0411\u0414 redis<\/p>\n<h2>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u0435\u0439 hashes \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f<\/h2>\n<p>\u041c\u0435\u0445\u0430\u043d\u0438\u043a\u0430 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 \u0441\u0440\u043e\u043a\u0430 \u0436\u0438\u0437\u043d\u0438 \u0434\u043b\u044f \u043f\u043e\u043b\u0435\u0439 hashes \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0434\u0438\u043a\u0430\u043b\u044c\u043d\u043e. \u041f\u0440\u0438\u0447\u0438\u043d \u043d\u0430 \u0442\u043e \u043c\u043d\u043e\u0433\u043e, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f hashes \u0435\u0441\u043b\u0438 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044e \u0442\u0430\u043a \u0436\u0435 \u0438\u0445 \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0431\u0438\u0442\u044c \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u043e \u0440\u0430\u0437\u043d\u044b\u043c \u0431\u0430\u0437\u0430\u043c (\u0441\u043c. \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u0442\u0438\u043a\u0438 \u0432\u044b\u0448\u0435), \u0447\u0442\u043e \u0440\u0435\u0437\u043a\u043e \u0443\u0441\u043b\u043e\u0436\u043d\u0438\u0442 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b, \u0442.\u043a. \u043a\u0430\u043a \u0442\u0430\u043a\u043e\u0432\u043e\u0439 \u0435\u0434\u0438\u043d\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b hashes-\u0430 \u0443\u0436\u0435 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442.<\/p>\n<h3>\u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043b\u0435\u043d\u0438\u0432\u043e\u0433\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u0430 \u0434\u043b\u044f hashes<\/h3>\n<p>\u0422\u0435\u043e\u0440\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043a\u0430\u0436\u0434\u044b\u0439 \u0440\u0430\u0437 \u043f\u0440\u0438 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0438 \u043a \u043e\u0431\u044a\u0435\u043a\u0442\u0443 \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u043e \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u0438 lazy expiration \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0443\u0434\u0430\u043b\u044f\u0442\u044c \u0432\u0441\u0435 \u043f\u043e\u043b\u044f \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c. \u0422\u0430\u043a\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u0438\u043c\u0435\u0435\u0442 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u0442\u043e\u043a: \u043e\u043d \u043c\u043e\u0436\u0435\u0442 \u043d\u0430\u0434\u043e\u043b\u0433\u043e \u043f\u0440\u0438\u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u0443 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e \u043f\u043e\u0442\u043e\u043a\u0430, \u0435\u0441\u043b\u0438 \u0437\u0430 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0439 \u0441\u0440\u043e\u043a \u0438\u0441\u0442\u0435\u0447\u0451\u0442 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432. \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u044b \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043e \u0441\u0432\u043e\u0451 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 lazy expiration<\/p>\n<ul>\n<li>\n<p><strong>HGET<\/strong>, <strong>HMGET<\/strong>, <strong>HINCRBY(FLOAT)<\/strong>, <strong>HEXISTS<\/strong> &#8212; \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442 &#171;\u043b\u0435\u043d\u0438\u0432\u043e\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435&#187;<\/p>\n<\/li>\n<li>\n<p><strong>HRANDFIELD<\/strong> &#8212; \u0443\u0434\u0430\u043b\u0438\u0442 \u0432\u0441\u0435 \u043f\u043e\u043b\u044f \u0438 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u043f\u0435\u0440\u0435\u0434 \u0432\u044b\u0431\u043e\u0440\u0430 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u044f<\/p>\n<\/li>\n<li>\n<p><strong>HLEN<\/strong> &#8212; \u0432\u044b\u0434\u0430\u0441\u0442 \u0440\u0430\u0437\u043c\u0435\u0440 \u0431\u0435\u0437 \u0443\u0447\u0451\u0442\u0430 \u043f\u043e\u043b\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c<\/p>\n<\/li>\n<li>\n<p><strong>HGETALL<\/strong> &#8212; \u043e\u0442\u0444\u0438\u043b\u044c\u0442\u0440\u0443\u0435\u0442 \u043f\u043e\u043b\u044f \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c. \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0434\u0430\u0442\u044c \u043f\u0443\u0441\u0442\u043e\u0439 \u043c\u0430\u0441\u0441\u0438\u0432 \u043a\u0430\u043a KEYS<\/p>\n<\/li>\n<li>\n<p><strong>HSCAN<\/strong> &#8212; \u043e\u0442\u0444\u0438\u043b\u044c\u0442\u0440\u0443\u0435\u0442 \u043f\u043e\u043b\u044f \u0438 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c (\u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e SCAN)<\/p>\n<\/li>\n<\/ul>\n<h3>\u0410\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0434\u043b\u044f hashes<\/h3>\n<p>\u0425\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0441\u0440\u043e\u043a\u043e\u0432 \u0436\u0438\u0437\u043d\u0438 \u043f\u043e\u043b\u0435\u0439 hashes \u0432 ebuckets-\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430\u0445<br \/> \u0420\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043a\u0430\u043a &#171;expirity-buckets&#187; &#8212; \u043a\u043e\u0440\u0437\u0438\u043d\u0430 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0430\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0441 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0436\u0438\u0437\u043d\u0438. \u0420\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0430 \u043d\u0430 RAX-\u0434\u0435\u0440\u0435\u0432\u0435 (<a href=\"https:\/\/en.wikipedia.org\/wiki\/Radix_tree\" rel=\"noopener noreferrer nofollow\">https:\/\/en.wikipedia.org\/wiki\/Radix_tree<\/a>). \u0423 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0435\u0441\u0442\u044c api (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 &#8212; \u0432\u044b\u0431\u0435\u0440\u0438 \u043b\u0438\u0441\u0442 \u0441 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c) \u043f\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044e, \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044e \u0438 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.  \u0412\u0440\u0435\u043c\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 (\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043e \u0434\u043b\u0438\u043d\u043e\u0439 6 \u0431\u0430\u0439\u0442) \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043a\u0430\u043a \u043a\u043b\u044e\u0447 \u0434\u043b\u044f \u043f\u0435\u0440\u0435\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u043f\u043e RAX-\u0434\u0435\u0440\u0435\u0432\u0443, \u0442.\u043e. \u043f\u0440\u0435\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0433\u043b\u0443\u0431\u0438\u043d\u0430 RAX-\u0434\u0435\u0440\u0435\u0432\u0430 &#8212; 6 \u0443\u0440\u043e\u0432\u043d\u0435\u0439. \u0422.\u043e. \u0444\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u0440\u0438\u043d\u044f\u0442\u044c \u0447\u0442\u043e, \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u043c \u0441 \u0434\u0435\u0440\u0435\u0432\u043e\u043c \u0437\u0430 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f.<\/p>\n<h4>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043a\u043e\u0440\u0437\u0438\u043d<\/h4>\n<p>\u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u043a\u043e\u0440\u0437\u0438\u043d \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0447\u0435\u0441\u043a\u0438 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<ul>\n<li>\n<p><strong>ebuckets<\/strong> &#8212; \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0432\u0435\u0440\u0445\u043d\u0435\u0433\u043e \u0443\u0440\u043e\u0432\u043d\u044f, \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u043d\u0430 RAX. \u041a\u0430\u0436\u0434\u044b\u0439 \u043b\u0438\u0441\u0442 \u0432 \u0434\u0435\u0440\u0435\u0432\u0435 RAX \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u043a\u043e\u0440\u0437\u0438\u043d\u0443.<\/p>\n<\/li>\n<li>\n<p><strong>\u043a\u043e\u0440\u0437\u0438\u043d\u0430<\/strong>(bucket) &#8212; \u043a\u0430\u0436\u0434\u0430\u044f \u043a\u043e\u0440\u0437\u0438\u043d\u0430 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u0438\u043d\u0442\u0435\u0440\u0432\u0430\u043b \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u043e\u0434\u0438\u043d \u0438\u043b\u0438 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u043e\u0432. \u041a\u043b\u044e\u0447 \u0432 \u0434\u0435\u0440\u0435\u0432\u0435 RAX \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438\u0441\u0442\u0435\u0447\u0435\u043d\u0438\u044f \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0434\u043b\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u044d\u0442\u043e\u0439 \u043a\u043e\u0440\u0437\u0438\u043d\u044b,\u0430 \u043a\u043b\u044e\u0447 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0438\u0441\u0442\u0435\u0447\u0435\u043d\u0438\u044f \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f. \u041f\u043e\u0434 \u043a\u043e\u0440\u0437\u0438\u043d\u043e\u0439 \u043f\u043e \u0441\u0443\u0442\u0438 \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u0435\u0451 \u043f\u0435\u0440\u0432\u044b\u0439 \u0441\u0435\u0433\u043c\u0435\u043d\u0442 &#8212; FirstSegHdr.<\/p>\n<\/li>\n<li>\n<p><strong>segment<\/strong> &#8212; \u043a\u0430\u0436\u0434\u044b\u0439 \u0441\u0435\u0433\u043c\u0435\u043d\u0442 \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0435 \u043c\u043e\u0436\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0434\u043e EB_SEG_MAX_ITEMS (\u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0435\u0435 \u0432\u0440\u0435\u043c\u044f 16) \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0432 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u043c \u0441\u043f\u0438\u0441\u043a\u0435. \u0415\u0441\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0432 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u043d\u044b\u0439 \u0441\u0435\u0433\u043c\u0435\u043d\u0442,  \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442 \u043f\u043e\u043f\u044b\u0442\u043a\u0430 \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0430. \u0414\u043b\u044f \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u0438 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u043f\u0438\u0441\u043e\u043a \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u043e\u0432 \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u043e\u0431\u043e\u0439 \u043e\u0431\u044b\u0447\u043d\u044b\u0439 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a. \u041a\u0430\u0436\u0434\u044b\u0439 \u0441\u0435\u0433\u043c\u0435\u043d\u0442 \u043c\u043e\u0436\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0434\u043e EB_SEG_MAX_ITEMS (16) \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432. \u041f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u043d\u043e\u0432\u043e\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0435\u0441\u043b\u0438 \u043e\u043d \u0434\u043e\u0441\u0442\u0438\u0433 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0439 \u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438 \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442 \u043b\u0438\u0431\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0430  \u043b\u0438\u0431\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u043d\u0430 \u0431\u043e\u043b\u0435\u0435 \u043c\u0435\u043b\u043a\u0438\u0435 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u044b. \u041e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044e\u0449\u0438\u0439 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0439: \u0435\u0441\u043b\u0438  \u0441\u0435\u0433\u043c\u0435\u043d\u0442 \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d \u0434\u043e \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c\u0430 \u0438 \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0438\u043c\u0435\u044e\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b\u0439 \u043a\u043b\u044e\u0447 \u0438\u0441\u0442\u0435\u0447\u0435\u043d\u0438\u044f \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f, \u0442\u043e \u043c\u044b \u043d\u0435 \u0440\u0430\u0437\u0434\u0435\u043b\u044f\u0435\u043c \u043a\u043e\u0440\u0437\u0438\u043d\u0443, \u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u043c  \u0441\u0435\u0433\u043c\u0435\u043d\u0442 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u044f (NextSegHdr) \u0438 \u043f\u0440\u0438\u0432\u044f\u0437\u044b\u0432\u0430\u044f \u0435\u0433\u043e \u043a \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u043c\u0443 (\u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0435 \u043a \u043f\u0435\u0440\u0432\u043e\u043c\u0443 \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0443) \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0435. \u0412 \u044d\u0442\u043e\u043c \u0441\u043c\u044b\u0441\u043b\u0435 extended \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u044b \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u0431\u0443\u0434\u0443\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0441 \u043e\u0434\u043d\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f.<\/p>\n<\/li>\n<li>\n<p><strong>\u044d\u043b\u0435\u043c\u0435\u043d\u0442<\/strong>. \u041a\u0430\u0436\u0434\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u0445\u0440\u0430\u043d\u044f\u0449\u0438\u0439\u0441\u044f \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0430\u0445 \u0434\u043e\u043b\u0436\u0435\u043d \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 ExpireMeta. \u041e\u043d\u0430 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0432\u0440\u0435\u043c\u044f \u0438\u0441\u0442\u0435\u0447\u0435\u043d\u0438\u044f \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u043b\u0435\u0439 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0434\u043b\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0430. \u042d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u043c \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043a\u0430\u043a \u043a\u043b\u044e\u0447 \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0442\u0430\u043a \u0438 \u043a\u043b\u044e\u0447 \u043f\u043e\u043b\u044f.<\/p>\n<\/li>\n<\/ul>\n<p>\u0418\u0435\u0440\u0430\u0440\u0445\u0438\u044f \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u0430 \u043d\u0430 \u0434\u0438\u0430\u0433\u0440\u0430\u043c\u043c\u0435:<\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/92c\/48e\/b93\/92c48eb93231de622650e0bf22b7d2ec.png\" width=\"528\" height=\"533\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/92c\/48e\/b93\/92c48eb93231de622650e0bf22b7d2ec.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/92c\/48e\/b93\/92c48eb93231de622650e0bf22b7d2ec.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u041f\u0440\u0438\u043c\u0435\u0440:<br \/> \u0418\u043c\u0435\u0435\u043c 4 \u0438\u043d\u0442\u0435\u0440\u0432\u0430\u043b\u0430:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<th>\n<p align=\"left\">unixtime 32<\/p>\n<\/th>\n<th>\n<p align=\"left\">unixtime 48 (6 \u0431\u0430\u0439\u0442) HEX<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u0434\u0430\u0442\u0430-\u0432\u0440\u0435\u043c\u044f<\/p>\n<\/th>\n<th>\n<p align=\"left\">\u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043f\u043e\u043b\u0435\u0439<\/p>\n<\/th>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">1747157234<\/p>\n<\/td>\n<td>\n<p align=\"left\">682380F20000<\/p>\n<\/td>\n<td>\n<p align=\"left\">May 13 2025 17:27:14 GMT+0000<\/p>\n<\/td>\n<td>\n<p align=\"left\">18<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">1747164434<\/p>\n<\/td>\n<td>\n<p align=\"left\">68239D120000<\/p>\n<\/td>\n<td>\n<p align=\"left\">May 13 2025 19:27:14 GMT+0000<\/p>\n<\/td>\n<td>\n<p align=\"left\">4<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">1747337234<\/p>\n<\/td>\n<td>\n<p align=\"left\">682640120000<\/p>\n<\/td>\n<td>\n<p align=\"left\">May 15 2025 19:27:14 GMT+0000<\/p>\n<\/td>\n<td>\n<p align=\"left\">9<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">1747942034<\/p>\n<\/td>\n<td>\n<p align=\"left\">682640120000<\/p>\n<\/td>\n<td>\n<p align=\"left\">May 22 2025 19:27:14 GMT+0000<\/p>\n<\/td>\n<td>\n<p align=\"left\">39<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u0418\u043c\u0435\u0435\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 rax-\u0434\u0435\u0440\u0435\u0432\u043e c \u043a\u043e\u0440\u0437\u0438\u043d\u0430\u043c\u0438 \u043d\u0430 \u043b\u0438\u0441\u0442\u043e\u0432\u043e\u043c \u0443\u0440\u043e\u0432\u043d\u0435<\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/9fe\/071\/6df\/9fe0716dfeca353fb2d4f9f234fe10a8.png\" width=\"616\" height=\"291\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/9fe\/071\/6df\/9fe0716dfeca353fb2d4f9f234fe10a8.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/9fe\/071\/6df\/9fe0716dfeca353fb2d4f9f234fe10a8.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<h4>\u0412\u0438\u0434\u044b ebuckets<\/h4>\n<p>\u0421\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 ebuckets. \u0412 \u043d\u0435\u0439 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u044b \u043a\u043b\u044e\u0447\u0438 hashes \u0430 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432 hashes-\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435<br \/> \u0414\u0430\u043d\u043d\u044b\u0435 \u043f\u043e \u0441\u0440\u043e\u043a\u0443 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043f\u043e\u043b\u0435\u0439 \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446 \u043b\u0435\u0436\u0430\u0442 \u0432  \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 <code>ebuckets hexpires<\/code> \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445:<\/p>\n<pre><code class=\"cpp\">... kvstore *expires; \/* Timeout of keys with a timeout set *\/ ebuckets hexpires; \/* Hash expiration DS. Single TTL per hash (of next min field to expire) *\/ ... } redisDb;<\/code><\/pre>\n<p>\u041b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b. \u0414\u043b\u044f \u044d\u043a\u043e\u043d\u043e\u043c\u0438\u0438 \u043f\u0430\u043c\u044f\u0442\u0438 hashes \u043c\u043e\u0436\u0435\u0442 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u0432 2\u0445 \u0438\u043f\u043e\u0441\u0442\u0430\u0441\u044f\u0445 listpack &#8212; \u0435\u0441\u043b\u0438 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043c\u0435\u043d\u044c\u0448\u0435 <code>hash-max-listpack-entries<\/code> (512 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e) \u0438 dictionary. \u041f\u0440\u0438 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 \u0432 dictionary \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u0441\u0432\u043e\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 ebuckets:<\/p>\n<pre><code class=\"cpp\">\/* Each dict of hash object that has fields with time-Expiration will have the  * following metadata attached to dict header *\/ typedef struct dictExpireMetadata { ExpireMeta expireMeta; \/* embedded ExpireMeta in dict. To be used in order to register the hash in the global ebuckets (i.e db-&gt;hexpires) with next, minimum, hash-field to expire. TTL value might be inaccurate up-to few seconds due to optimization consideration. *\/ ebuckets hfe; \/* DS of Hash Fields Expiration, associated to each hash *\/ sds key; \/* reference to the key, same one that stored in db-&gt;dict. *\/ } dictExpireMetadata;<\/code><\/pre>\n<p>\u041a\u0440\u0430\u0442\u043a\u043e \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043f\u043e\u043b\u0435\u0439 hashes<\/p>\n<figure class=\"\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/615\/5f0\/598\/6155f0598677efc3c7feadc9624f5cc0.png\" width=\"508\" height=\"832\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/615\/5f0\/598\/6155f0598677efc3c7feadc9624f5cc0.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/615\/5f0\/598\/6155f0598677efc3c7feadc9624f5cc0.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<h3>\u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u043f\u043e\u0449\u0443\u043f\u0430\u0442\u044c \u0440\u0443\u043a\u0430\u043c\u0438<\/h3>\n<p>\u0421 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433\u0430 \u043f\u043e\u043a\u0430 \u0432\u0441\u0451 \u043f\u043b\u043e\u0445\u043e, \u0435\u0441\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e subkeys \u0432 &#8216;info keyset&#8217;, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u043b\u044e\u0447\u0435\u0439 \u0432 \u0433\u043b\u043e\u0431\u0430\u043b\u044c\u043d\u043e\u0439 ebucket \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435, \u0434\u043b\u044f \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u043e \u0432\u0440\u0435\u043c\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438. \u0414\u043b\u044f \u043e\u0446\u0435\u043d\u043a\u0438 \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u0439\u0442\u0438 \u043a\u043e\u0441\u0432\u0435\u043d\u043d\u044b\u043c \u043f\u0443\u0442\u0451\u043c \u0432\u044b\u0431\u0440\u0430\u0432 \u0434\u043b\u0438\u043d\u0443 \u043f\u043e 1 \u0442\u044b\u0441 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u0445 hashs (\u043a\u0430\u043a \u0443\u043a\u0430\u0437\u0430\u043d\u043e \u0432\u044b\u0448\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u0430 hlen \u043d\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442 \u043b\u0435\u043d\u0438\u0432\u043e\u0433\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f).<\/p>\n<ul>\n<li>\n<p>\u0422\u0435\u043c\u043f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 case4 &#8212; \u0434\u043b\u044f \u0444\u043e\u0440\u043c\u0430\u0442\u0430 dictionary (1000 \u043f\u043e\u043b\u0435\u0439 \u0432 hash)  &#8212; 2 \u043c\u043b\u043d. \u043f\u043e\u043b\u0435\u0439 \u0443\u0448\u043b\u043e \u0437\u0430 2 \u043c\u0438\u043d\u0443\u0442\u044b. \u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u0441 case2, \u0433\u0434\u0435 \u043f\u043e \u0441\u0443\u0442\u0438 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u043c \u043f\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0443 \u0432\u044b\u043d\u0435\u0441\u0435\u043d\u043d\u043e\u043c\u0443 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u0431\u0430\u0437\u0443 \u0441 \u0432\u044b\u0441\u043e\u043a\u043e\u0439 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c\u044e \u0443\u0434\u0430\u043b\u0438\u0442\u044c \u043a\u043b\u044e\u0447, \u0432\u0441\u0435\u0433\u043e \u0432 2 \u0440\u0430\u0437\u0430.<\/p>\n<\/li>\n<\/ul>\n<pre><code>ts: 01:13:57 PM avgLen(after): 999.167 ... ts: 01:15:48 PM avgLen(after): 932.718<\/code><\/pre>\n<ul>\n<li>\n<p>\u0422\u0435\u043c\u043f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 case3 \u0434\u043b\u044f listpack (500 \u043f\u043e\u043b\u0435\u0439 \u0432 hash) &#8212; \u043d\u0430 2 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430 \u043f\u043e\u043b\u0435\u0439 \u0443\u0448\u043b\u043e 5,5 \u043c\u0438\u043d\u0443\u0442<\/p>\n<\/li>\n<\/ul>\n<pre><code>ts: 05\/13\/25 01:26:07 PM avgLen(after): 499.938 ... ts: 05\/13\/25 01:31:47 PM avgLen(after): 466.332<\/code><\/pre>\n<p><strong>\u0412\u044b\u0432\u043e\u0434<\/strong>: \u0420\u0430\u0431\u043e\u0442\u0430 \u043f\u043e \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043f\u043e\u043b\u0435\u0439 \u0434\u043b\u044f \u0444\u043e\u0440\u043c\u0430\u0442\u0430 listpack \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u043c\u0435\u043d\u0435\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0430, \u043a\u0430\u043a \u0435\u0441\u043b\u0438 \u0431\u044b \u043f\u043e\u043b\u044f \u0431\u044b\u043b\u0438 \u0431\u044b \u0440\u0430\u0437\u043b\u043e\u0436\u0435\u043d\u044b \u0432 \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446\u044b. Ebuckets \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043f\u0440\u0438 \u0435\u0451 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0438 \u043a \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u043c\u0443 hash \u043f\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043d\u0435 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u0443\u0441\u0442\u0443\u043f\u0430\u044e\u0449\u0430\u044f \u0432\u044b\u0432\u0435\u0434\u0435\u043d\u0438\u044e \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0434\u043d\u043e\u0433\u043e \u0441\u0440\u043e\u043a\u0430 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u0411\u0414.<\/p>\n<h3>\u041e\u0446\u0435\u043d\u043a\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 ebuckets<\/h3>\n<p>\u041e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043a\u043e\u0433\u0434\u0430 \u0443 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u0434\u043d\u043e \u0438 \u0442\u043e \u0436\u0435 \u0432\u0440\u0435\u043c\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u0445\u0440\u0430\u043d\u0438\u0442\u044c\u0441\u044f \u0432 \u043e\u0434\u043d\u043e\u0439 \u043a\u043e\u0440\u0437\u0438\u043d\u0435 \u0443\u0442\u0438\u043b\u0438\u0437\u0438\u0440\u0443\u044f \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c extended segments \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u0432 \u0432\u0438\u0434\u0435 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u0441\u043f\u0438\u0441\u043a\u0430. \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u0440\u043e\u0438\u0433\u043d\u043e\u0440\u0438\u0440\u0443\u0435\u043c \u044d\u0442\u043e \u0438 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0447\u0442\u043e \u043a\u0430\u0436\u0434\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0438\u043c\u0435\u0435\u0442 \u0441\u0432\u043e\u0439 expiration time. \u0432 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0435 \u0432\u0441\u0435 \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u044b \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432\u043d\u0435 \u043a\u043e\u043d\u0446\u0435\u043f\u0446\u0438\u0438 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u043d\u044b\u0445 \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u043e\u0432.<br \/> \u0417\u0430\u043c\u0435\u0447\u0430\u043d\u0438\u044f:<\/p>\n<ul>\n<li>\n<p>\u043a\u0430\u0436\u0434\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 16 \u0431\u0430\u0439\u0442 \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445 Expire Meta;<\/p>\n<\/li>\n<li>\n<p>\u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0430 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 16 \u0431\u0430\u0439\u0442;<\/p>\n<\/li>\n<li>\n<p>\u043e\u0431\u044a\u0451\u043c \u043c\u0435\u0442\u0430\u0434\u0430\u043d\u043d\u044b\u0445 RAX \u043d\u0430 \u043b\u0438\u0441\u0442\/\u0441\u0435\u0433\u043c\u0435\u043d\u0442\/\u043a\u043e\u0440\u0437\u0438\u043d\u0443 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e 40 \u0431\u0430\u0439\u0442 (\u043a\u043b\u044e\u0447 \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u0432\u0441\u0435\u0433\u043e 6 \u0431\u0430\u0439\u0442)<\/p>\n<\/li>\n<\/ul>\n<p><strong>\u0421\u0446\u0435\u043d\u0430\u0440\u0438\u0439 1:<\/strong> \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442 \u043c\u0430\u043b\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u043d\u0435 \u0431\u043e\u043b\u0435\u0435 EB_LIST_MAX_ITEMS<br \/> \u041a\u043e\u0433\u0434\u0430 ebucket\u044b \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442 \u043d\u0435 \u0431\u043e\u043b\u0435\u0435 EB_LIST_MAX_ITEMS 16 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u043d\u0438 \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u044b \u043d\u0435 \u0430\u043b\u043b\u043e\u0446\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c. \u041e\u043d \u043f\u0440\u043e\u0441\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u0443\u044e expiremeta \u0434\u043b\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 \u0432\u0438\u0434\u0435 \u0441\u043f\u0438\u0441\u043a\u0430. \u0422.\u043e. \u0437\u0430\u0442\u0440\u0430\u0442\u044b \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 16 \u0431\u0430\u0439\u0442 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442<br \/> <strong>\u0421\u0446\u0435\u043d\u0430\u0440\u0438\u0439 2<\/strong>: \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0443\u0434\u0430\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438<br \/> \u0415\u0441\u043b\u0438 \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0443\u0434\u0430\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e \u0438\u0441\u0442\u0435\u0447\u0435\u043d\u0438\u0438 \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f, \u0442\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u043e\u0432(\u043a\u043e\u0440\u0437\u0438\u043d) \u0431\u0443\u0434\u0443\u0442 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u044b \u0432 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0435 \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u043a\u0430\u043a \u043c\u0438\u043d\u0438\u043c\u0443\u043c 8 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0438 \u043d\u0435 \u0431\u043e\u043b\u0435\u0435 \u0447\u0435\u043c EB_LIST_MAX_ITEMS (=16). \u041e\u043d \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u0443\u044e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 Expire Meta \u0434\u043b\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0430\u043d\u0438\u044f \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0432 \u0432\u0438\u0434\u0435 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u0441\u043f\u0438\u0441\u043a\u0430. \u0422\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u0440\u0430\u0441\u0445\u043e\u0434 \u043f\u0430\u043c\u044f\u0442\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 16 \u0431\u0430\u0439\u0442 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442<br \/> <strong>\u0421\u0446\u0435\u043d\u0430\u0440\u0438\u0439 3<\/strong>: \u042d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0443\u0434\u0430\u043b\u044f\u044e\u0442\u0441\u044f \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u0442\u043e\u0434\u043e\u043c \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438<br \/> \u0415\u0441\u043b\u0438 \u043e\u0436\u0438\u0434\u0430\u0435\u0442\u0441\u044f \u043c\u043d\u043e\u0433\u043e &#171;\u043d\u0435 \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0439&#187; \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0438\u0437 \u043a\u043e\u0440\u0437\u0438\u043d, \u0442\u043e \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u043c\u043e\u0433\u0443\u0442 \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u044c\u0441\u044f \u0434\u043e \u043c\u0435\u043d\u0435\u0435 \u0447\u0435\u043c 4 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0435. \u0421\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0432\u0435\u043d\u043d\u043e ebucket \u043f\u043e\u043f\u044b\u0442\u0430\u0435\u043cc\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0438\u0442\u044c \u0441\u043e\u0441\u0435\u0434\u043d\u0438\u0435 \u043a\u043e\u0440\u0437\u0438\u043d\u044b. \u0422.\u043e. \u043e\u0436\u0438\u0434\u0430\u0435\u0442\u0441\u044f \u0447\u0442\u043e \u0432 \u0441\u0440\u0435\u0434\u043d\u0435\u043c \u0432 \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0435 \u043a\u043e\u0440\u0437\u0438\u043d\u044b \u0431\u0443\u0434\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 10 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432.<br \/> \u0420\u0430\u0441\u0447\u0451\u0442:<\/p>\n<ul>\n<li>\n<p>\u0432 \u0441\u0440\u0435\u0434\u043d\u0435\u043c 10 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0435: 16+16\/10+40\/10 = 21.6 \u0431\u0430\u0439\u0442 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442<\/p>\n<\/li>\n<li>\n<p>\u0432 \u0445\u0443\u0434\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 4 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0432 \u043a\u043e\u0440\u0437\u0438\u043d\u0435: 16+16\/4+40\/4 = 30 \u0431\u0430\u0439\u0442 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 <\/p>\n<\/li>\n<\/ul>\n<p><strong>\u0421\u0446\u0435\u043d\u0430\u0440\u0438\u0439 4<\/strong>: \u0443 \u0432\u0441\u0435\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u0434\u043d\u043e \u0438 \u0442\u043e \u0436\u0435 \u0432\u0440\u0435\u043c\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0412 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432 ebuckets \u0431\u0443\u0434\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u0430 \u043a\u043e\u0440\u0437\u0438\u043d\u0430 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u043d\u044b\u0445 \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u043e\u0432. ExpireMeta \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0434\u043e\u043c\u0438\u043d\u0438\u0440\u0443\u044e\u0449\u0435\u0439 \u0438 \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0441\u0435\u0433\u043c\u0435\u043d\u0442 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0434\u0435\u043b\u044f\u0442\u044c\u0441\u044f \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044c NextSegHdr \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c 24 \u0431\u0430\u0439\u0442\u0430. \u0421\u0447\u0438\u0442\u0430\u044f \u0440\u0430\u0437\u043c\u0435\u0440 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0441\u0435\u0433\u043c\u0435\u043d\u0442\u0430 16 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043c: 16+24\/16 = 17.5 \u0431\u0430\u0439\u0442. \u0422.\u043e. \u0434\u0430\u0436\u0435 \u0445\u0443\u0434\u0448\u0438\u0439 \u0441\u043b\u0443\u0447\u0430\u0439 \u043b\u0443\u0447\u0448\u0435, \u0447\u0435\u043c \u0435\u0441\u043b\u0438 \u0431\u044b \u043c\u044b \u0445\u0440\u0430\u043d\u0438\u043b\u0438 \u0434\u0430\u043d\u043d\u044b\u0435 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043a\u043b\u044e\u0447\u0435\u0439 \u0432 \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446\u0435.<\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><!----><!----><\/div>\n<p><!----><!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/910060\/\"> https:\/\/habr.com\/ru\/articles\/910060\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u0427\u0430\u0441\u0442\u044c 1: <a href=\"https:\/\/habr.com\/ru\/articles\/907408\/\" rel=\"noopener noreferrer nofollow\">https:\/\/habr.com\/ru\/articles\/907408\/<\/a><\/p>\n<p>\u0414\u043e \u0432\u0435\u0440\u0441\u0438\u0438 7.4 \u0432 redis \u0441\u0440\u043e\u043a \u0436\u0438\u0437\u043d\u0438 \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u0441\u0440\u043e\u043a \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043a\u043b\u044e\u0447\u0430. \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 7.4 \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0438 \u0434\u043b\u044f \u043f\u043e\u043b\u044f \u0432 \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446(hashes).<br \/>\u0421\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 2 \u0441\u043f\u043e\u0441\u043e\u0431\u0430 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f:<\/p>\n<ul>\n<li>\n<p>\u043b\u0435\u043d\u0438\u0432\u044b\u0439<\/p>\n<\/li>\n<li>\n<p>\u0430\u043a\u0442\u0438\u0432\u043d\u044b\u0439<\/p>\n<\/li>\n<\/ul>\n<p>\u041a\u0430\u043a \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442? \u041a\u0430\u043a\u0438\u0435 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u0443\u0447\u0435\u0441\u0442\u044c \u043f\u0440\u0438 \u043f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0441\u0445\u0435\u043c\u044b \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f?<br \/>\u0422\u0435\u043a\u0443\u0449\u0430\u044f \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0442\u0430\u043a\u043e\u0432\u0430, \u0447\u0442\u043e \u0434\u043b\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0438 \u043f\u043e\u043b\u0435\u0439 \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446 \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u0440\u0430\u0437\u043d\u043e\u043c\u0443.<\/p>\n<h2>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f<\/h2>\n<p>\u041a\u0430\u043a \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0441\u0440\u043e\u043a\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439. \u0441\u043c. \u0444\u0430\u0439\u043b &#8216;server.h&#8217; \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430<\/p>\n<pre><code>typedef struct redisDb {  kvstore *keys; \/* The keyspace for this DB. As metadata, holds keysizes histogram *\/  kvstore *expires; \/* Timeout of keys with a timeout set *\/<\/code><\/pre>\n<p>\u041a\u0430\u043a \u0443\u0436\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u043d\u043e \u0432 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0434\u043b\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441\u0440\u043e\u043a\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u043c kvstore, \u0432 \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446\u0435: \u043a\u043b\u044e\u0447-&#171;\u0441\u0440\u043e\u043a \u0436\u0438\u0437\u043d\u0438&#187;<\/p>\n<p>\u0421\u0443\u0442\u044c \u043b\u0435\u043d\u0438\u0432\u043e\u0433\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u0430: \u043f\u0440\u0438 \u043b\u044e\u0431\u043e\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u0435 \u043a \u043a\u043b\u044e\u0447\u0443 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u0435\u0433\u043e \u0441\u0440\u043e\u043a \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f. \u0415\u0441\u043b\u0438 \u043a\u043b\u044e\u0447 \u043f\u0440\u043e\u0442\u0443\u0445, \u0442\u043e \u043f\u0435\u0440\u0435\u0434 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u0435\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0435\u0433\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435.<\/p>\n<h2>\u0410\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431<\/h2>\n<p>\u0420\u0430\u0431\u043e\u0442\u0430 \u043f\u043e \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043a\u043b\u044e\u0447\u0435\u0439 \u0432 \u0444\u0430\u0439\u043b\u0435 <code>expire.c<\/code><br \/> \u0410\u043a\u0442\u0438\u0432\u043d\u044b\u0439  \u0441\u043f\u043e\u0441\u043e\u0431 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0432 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445<\/p>\n<ul>\n<li>\n<p>\u0442.\u043d. FAST. \u0412\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 event loop. \u041e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442 \u043d\u0435\u043c\u043d\u043e\u0433\u043e, \u0437\u0434\u0435\u0441\u044c \u043c\u044b \u0435\u0433\u043e \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0435\u043c.  \u0414\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0446\u0438\u043a\u043b\u0430 \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0438 \u043e\u0431\u044a\u0451\u043c \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439  \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d \u0438\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430 \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 <code>active-expire-effort<\/code> &#8212; 1 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u041a\u0430\u043a \u0431\u0443\u0434\u0435\u0442 \u0432\u0438\u0434\u043d\u043e \u043d\u0438\u0436\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 active-expire-effort \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0442\u044c \u043e\u0431\u044a\u0451\u043c \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u043c\u044b\u0445 \u0437\u0430 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044e<\/p>\n<\/li>\n<\/ul>\n<pre><code>\/\/ \u043f\u0440\u0438\u043c. ACTIVE_EXPIRE_CYCLE_FAST_DURATION - 1000 \u043c\u043a\u0441 ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP - 20 \u0448\u0442. ..... effort = server.active_expire_effort-1, \/* Rescale from 0 to 9. *\/ config_keys_per_loop = ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP + ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP\/4*effort, config_cycle_fast_duration = ACTIVE_EXPIRE_CYCLE_FAST_DURATION + ACTIVE_EXPIRE_CYCLE_FAST_DURATION\/4*effort<\/code><\/pre>\n<p>\u041d\u0435 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442, \u0435\u0441\u043b\u0438 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0430\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432\u044b\u0448\u043b\u0430 \u0437\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439 \u043b\u0438\u043c\u0438\u0442. (\u0442.\u0435. \u043d\u0435 \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u043c event loop \u0435\u0441\u043b\u0438 \u043f\u043e \u043e\u0431\u044a\u0451\u043c\u0443 \u043d\u0435\u0443\u0434\u0430\u043b\u0451\u043d\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u0432\u0441\u0451 \u043f\u043b\u043e\u0445\u043e)<\/p>\n<ul>\n<li>\n<p>\u0442.\u043d. SLOW.  \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e \u043a\u0440\u043e\u043d\u0443 (\u043c\u043e\u0436\u043d\u043e \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0432 debug-\u0440\u0435\u0436\u0438\u043c\u0435 \u0447\u0435\u0440\u0435\u0437 <code>set-active-expire 0<\/code>) \u0441 \u0447\u0430\u0441\u0442\u043e\u0442\u043e\u0439 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e 10 \u0440\u0430\u0437 \u0432 \u0441\u0435\u043a\u0443\u043d\u0434\u0443 (\u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 \u043a\u043e\u043d\u0444\u0438\u0433\u0430 <code>hz 10<\/code>).<\/p>\n<\/li>\n<\/ul>\n<pre><code>void databasesCron(void) {     \/* Expire keys by random sampling. Not required for slaves      * as master will synthesize DELs for us. *\/     if (server.active_expire_enabled) {         if (iAmMaster()) {             activeExpireCycle(ACTIVE_EXPIRE_CYCLE_SLOW);         } else {         \u043a\u0430\u043a \u043f\u043e \u043c\u043d\u0435 \u044d\u0442\u043e \u043a\u0440\u0430\u0441\u043d\u0430\u044f \u0442\u0440\u044f\u043f\u043a\u0430 \u0438 \u044d\u0442\u0438\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0435\u043b\u044c\u0437\u044f         * Expires of keys created in writable slaves          * This implementation is currently not perfect but a lot better than leaking  * the keys as implemented in 3.2.             expireSlaveKeys();         }     }<\/code><\/pre>\n<p>\u041f\u043e \u0441\u0443\u0442\u0438 \u044d\u0442\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0440\u0435\u0436\u0438\u043c \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0436\u0438\u0437\u043d\u0438. \u0415\u0433\u043e \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0434\u0430\u043b\u0435\u0435. \u041e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0432 DEBUG \u0440\u0435\u0436\u0438\u043c\u0435 \u0447\u0435\u0440\u0435\u0437 <code>DEBUG set-active-expire 0<\/code><\/p>\n<ul>\n<li>\n<p>\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0435\u0449\u0451 \u0430\u043a\u0442\u0438\u0432\u043d\u0430\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u043d\u0430 &#171;writable slaves&#187; \u043d\u043e \u0434\u043b\u044f \u043c\u0435\u043d\u044f \u0432\u043e\u0442 \u0442\u0430\u043a\u043e\u0435 &#171;\u0438\u043d\u0442\u0440\u043e&#187; \u043f\u0435\u0440\u0435\u0434 \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>expireSlaveKeys<\/code> &#171;&#8230;Expires of keys created in writable slaves&#8230; This implementation is currently not perfect but a lot better than leaking the keys as implemented in 3.2.&#187; &#8212; \u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u0444\u043b\u0430\u0433 \u0434\u043b\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0432 \u043f\u0440\u043e\u0434 \u0440\u0435\u0436\u0438\u043c\u0435. \u0415\u0451 \u044f \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u043d\u0435 \u0432\u0438\u0436\u0443 \u0441\u043c\u044b\u0441\u043b\u0430.<\/p>\n<\/li>\n<\/ul>\n<h4>SLOW \u0440\u0435\u0436\u0438\u043c \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c <\/h4>\n<p>\u041f\u043e \u0441\u0443\u0442\u0438 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 FAST \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u043d\u044b\u043c\u0438 \u043b\u0438\u043c\u0438\u0442\u0430\u043c\u0438 \u043d\u0430 \u0447\u0438\u0441\u043b\u043e \u043a\u043b\u044e\u0447\u0435\u0439 \u0438 \u0432\u0440\u0435\u043c\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f. \u0421\u0445\u0435\u043c\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u043a\u0440\u0430\u0442\u043a\u043e:<\/p>\n<pre><code class=\"cpp\">void activeExpireCycle(int type){ ...         \/* \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0443\u0434\u0430\u043b\u044f\u0435\u043c \u043f\u043e\u043b\u044f \u0445\u0435\u0448\u0442\u0430\u0431\u043b\u0438\u0446-\u043e\u0432*\/         activeExpireHashFieldCycle(type); ...   for (j = 0; dbs_performed &lt; dbs_per_call &amp;&amp; timelimit_exit == 0 &amp;&amp; j &lt; server.dbnum; j++) {   ...                 \/\/\u043f\u043e\u0442\u043e\u043c \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u043c\u0441\u044f \u043f\u043e \u043a\u043b\u044e\u0447\u0430\u043c \u0431\u0430\u0437\u044b                 while (data.sampled &lt; num &amp;&amp; checked_buckets &lt; max_buckets) {                 db-&gt;expires_cursor = kvstoreScan(db-&gt;expires, db-&gt;expires_cursor, -1, expireScanCallback, isExpiryDictValidForSamplingCb, &amp;data);                 if (db-&gt;expires_cursor == 0) {                     db_done = 1;                     break;                 }                 checked_buckets++;             }     \/\/\u043f\u043e\u0434\u0431\u0438\u0432\u0430\u0435\u043c \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0443 \u0434\u043b\u044f \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433\u0430 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438   } }<\/code><\/pre>\n<p>\u0423\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u043a\u043b\u044e\u0447\u0435\u0439 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0431\u0430\u0437\u044b \u0432 redis \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e. \u0411\u0430\u0437\u044b \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u043b\u0438 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0439 \u0446\u0438\u043a\u043b \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u0445 \u043a\u043b\u044e\u0447\u0435\u0439. \u0426\u0438\u043a\u043b \u043f\u043e \u043a\u0430\u0436\u0434\u043e\u0439 \u0411\u0414 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0430: \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u043a\u043b\u044e\u0447\u0435\u0439 \u0434\u043b\u044f \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0430 \u0437\u0430 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044e <code>config_keys_per_loop = ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP + ACTIVE_EXPIRE_CYCLE_KEYS_PER_LOOP\/4*effort<\/code>.<br \/> \u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043d\u0430\u0434 \u0431\u0430\u0437\u043e\u0439 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043e:<\/p>\n<ul>\n<li>\n<p>\u0434\u043e\u043f\u0443\u0441\u0442\u0438\u043c\u044b\u043c \u0443\u0440\u043e\u0432\u043d\u0435\u043c \u0443\u0434\u0430\u043b\u0451\u043d\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0442 \u0447\u0438\u0441\u043b\u0430 \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u043d\u044b\u0445, \u0442.\u0435. \u0435\u0441\u043b\u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e\u0433\u043e \u043f\u043e\u0440\u043e\u0433\u0430,  \u0441\u0447\u0438\u0442\u0430\u0435\u043c \u0434\u0430\u043b\u044c\u0448\u0435 \u0438\u0441\u043a\u0430\u0442\u044c \u043f\u043e \u0431\u0430\u0437\u0435 \u043d\u0435\u0442 \u0441\u043c\u044b\u0441\u043b\u0430, \u0448\u0430\u043d\u0441\u043e\u0432 \u043d\u0430\u0439\u0442\u0438 \u043a\u043b\u044e\u0447 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u043c\u0430\u043b\u043e.<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"cpp\">\/\/ACTIVE_EXPIRE_CYCLE_ACCEPTABLE_STALE 10% config_cycle_acceptable_stale = ACTIVE_EXPIRE_CYCLE_ACCEPTABLE_STALE- effort; repeat = db_done ? 0 : (data.sampled == 0 || (data.expired * 100 \/ data.sampled) &gt; config_cycle_acceptable_stale);<\/code><\/pre>\n<p>\u043f\u0440\u043e\u0446\u0435\u043d\u0442 \u0442\u0430\u043a \u0436\u0435 \u0440\u0435\u0433\u0443\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <code>active-expire-effort<\/code><\/p>\n<ul>\n<li>\n<p>\u043b\u0438\u043c\u0438\u0442\u043e\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043e\u0442\u043f\u0443\u0449\u0435\u043d\u043d\u044b\u043c \u043d\u0430 \u0446\u0438\u043a\u043b \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u043f\u043e \u0431\u0430\u0437\u0430\u043c. \u0414\u043b\u044f SLOW \u0446\u0438\u043a\u043b\u0430 \u044d\u0442\u043e\u0442 \u043f\u0435\u0440\u0438\u043e\u0434 &#8212; 25\u043c\u0441 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e. \u041d\u0438\u0436\u0435 \u0438\u0437 \u0444\u043e\u0440\u043c\u0443\u043b \u043f\u043e\u043d\u044f\u0442\u043d\u043e \u043a\u0430\u043a \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c \u044d\u0442\u0438\u043c \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c. \u041b\u0438\u043c\u0438\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442\u0441\u044f \u043a\u0430\u0436\u0434\u044b\u0435 16 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u043f\u043e \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"cpp\">#define ACTIVE_EXPIRE_CYCLE_SLOW_TIME_PERC 25 \/* Max % of CPU to use. *\/ ... timelimit = config_cycle_slow_time_perc*1000000\/server.hz\/100; ... config_cycle_slow_time_perc = ACTIVE_EXPIRE_CYCLE_SLOW_TIME_PERC + 2*effort<\/code><\/pre>\n<p>\u042d\u0442\u043e\u0442 \u043b\u0438\u043c\u0438\u0442 <strong>\u043e\u0431\u0449\u0438\u0439<\/strong> \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u0431\u0430\u0437, \u0442.\u0435. \u0435\u0441\u043b\u0438 \u043d\u0430 \u0446\u0438\u043a\u043b\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u043f\u0435\u0440\u0432\u043e\u0439 \u0431\u0430\u0437\u044b \u043c\u044b \u0432\u044b\u0448\u043b\u0438 \u0437\u0430 \u043d\u0435\u0433\u043e, \u0442\u043e \u043e\u0431\u0441\u043b\u0443\u0436\u0438\u0432\u0430\u043d\u0438\u0435 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0431\u0430\u0437 <strong>\u043d\u0435 \u043d\u0430\u0447\u043d\u0451\u0442\u0441\u044f<\/strong> \u0432 \u044d\u0442\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043a\u0440\u043e\u043d\u0430.<\/p>\n<p>\u0421\u0430\u043c\u0430 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f \u043f\u043e \u0431\u0430\u0437\u0435 \u043f\u0440\u043e\u0441\u0442\u0430 (\u0435\u0441\u043b\u0438 \u043e\u043d\u0430 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 1 \u0442\u0430\u0431\u043b\u0438\u0446\u0435, \u0435\u0441\u043b\u0438 \u0443 \u043d\u0430\u0441 \u043a\u043b\u0430\u0441\u0442\u0435\u0440 \u0438 16\u041a \u0441\u043b\u043e\u0442\u043e\u0432 \u0438 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446\u0430 \u0438\u043b\u0438 \u043c\u044b \u0432 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u043f\u0435\u0440\u0435\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f &#8212; \u0442\u0443\u0442 \u0441\u043b\u043e\u0436\u043d\u0435\u0435):<br \/> \u041f\u0440\u043e\u0445\u043e\u0434\u0438\u043c\u0441\u044f \u043f\u043e \u0431\u0430\u043a\u0435\u0442\u0430\u043c KV \u0445\u0440\u0430\u043d\u0438\u043b\u0438\u0449\u0430 db-&gt;expires \u0441 \u0442\u043e\u0433\u043e \u043c\u0435\u0441\u0442\u0430 \u0441 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u043b\u0438 \u0432 \u043f\u0440\u043e\u0448\u043b\u044b\u0439 \u0440\u0430\u0437 (expires_cursor)<\/p>\n<pre><code class=\"cpp\">while (data.sampled &lt; num &amp;&amp; checked_buckets &lt; max_buckets) { db-&gt;expires_cursor = kvstoreScan(db-&gt;expires, db-&gt;expires_cursor, -1, expireScanCallback, isExpiryDictValidForSamplingCb, &amp;data); if (db-&gt;expires_cursor == 0) { db_done = 1; break; } checked_buckets++; } <\/code><\/pre>\n<p>\u0438 \u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e DictEntry \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0422\u0422\u041b, \u0435\u0441\u043b\u0438 DictEntry \u043f\u0440\u043e\u0442\u0443\u0445, \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u043c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435.<\/p>\n<pre><code class=\"cpp\">int activeExpireCycleTryExpire(redisDb *db, dictEntry *de, long long now) {     long long t = dictGetSignedIntegerVal(de);     if (now &lt; t)         return 0;      enterExecutionUnit(1, 0);     sds key = dictGetKey(de);     robj *keyobj = createStringObject(key,sdslen(key));     deleteExpiredKeyAndPropagate(db,keyobj);     decrRefCount(keyobj);     exitExecutionUnit();     \/* Propagate the DEL command *\/     postExecutionUnitOperations();     return 1; }<\/code><\/pre>\n<p>\u043f\u043b\u044e\u0441\u044b \u043f\u043e\u0434\u0445\u043e\u0434\u0430:<\/p>\n<ul>\n<li>\n<p>\u043f\u043e\u0438\u0441\u043a, \u0432\u0441\u0442\u0430\u0432\u043a\u0430 \u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 &#8212; \u0438\u043c\u0435\u044e\u0442 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u043d\u0443\u044e \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c <\/p>\n<\/li>\n<\/ul>\n<p>\u043c\u0438\u043d\u0443\u0441\u044b:<\/p>\n<ul>\n<li>\n<p>\u043d\u0435\u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u044b\u0439 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438. \u0412\u0430\u0436\u043d\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u043c\u044b \u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0439\u0442\u0438\u0441\u044c \u043f\u043e \u0431\u0430\u043a\u0435\u0442\u0430\u043c \u0445\u0435\u0448-\u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0438 \u043a\u043b\u044e\u0447\u0438 \u0442\u0430\u043c \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u044b \u043f\u043e \u0444\u0430\u043a\u0442\u0443 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c, \u0435\u0441\u043b\u0438 \u0433\u043e\u0434\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u0434\u043b\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 &#171;\u0432 \u043c\u043e\u043c\u0435\u043d\u0442\u0435&#187; \u043c\u0430\u043b\u043e, \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u043e\u0434\u043d\u0443 &#171;\u043f\u0440\u043e\u0431\u0443&#187; \u0438 \u043a\u043e\u0433\u0434\u0430 \u043e\u043d\u0430 \u043f\u043e\u043a\u0430\u0436\u0435\u0442 \u043d\u0438\u0437\u043a\u0438\u0439 \u043f\u0440\u043e\u0446\u0435\u043d\u0442 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u043f\u0435\u0440\u0435\u0439\u0434\u0451\u043c \u043a \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0431\u0430\u0437\u0435. \u042d\u0442\u043e \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043c\u0435\u0442\u043e\u0434\u0430.<\/p>\n<\/li>\n<li>\n<p>\u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f r\u043f\u0435\u0440\u0435\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0440\u0438 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432 kv-\u0441\u0442\u043e\u0440\u0435 expires \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043c\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438 \u043f\u0430\u043c\u044f\u0442\u0438<\/p>\n<\/li>\n<li>\n<p>\u043e\u0431\u044a\u0451\u043c \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u043c\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u0438: 40 \u0431\u0430\u0439\u0442 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442.<\/p>\n<\/li>\n<\/ul>\n<h3>\u041c\u043e\u043d\u0438\u0442\u043e\u0440\u0438\u043d\u0433 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430<\/h3>\n<p>\u041d\u0430 \u043a\u0430\u043a\u0438\u0435 \u043c\u0435\u0442\u0440\u0438\u043a\u0438 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f \u043f\u0440\u0438 \u043e\u0446\u0435\u043d\u043a\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u0434\u0451\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043a\u043b\u044e\u0447\u0435\u0439 \u0441 \u0438\u0441\u0442\u0435\u043a\u0448\u0438\u043c \u0441\u0440\u043e\u043a\u043e\u043c \u0436\u0438\u0437\u043d\u0438<\/p>\n<h4>INFO STATS<\/h4>\n<ul>\n<li>\n<p><code>avg_ttl<\/code> &#8212; \u043a\u0430\u0436\u0434\u044b\u0435 16 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 (\u043b\u0438\u0431\u043e \u0432 \u043a\u043e\u043d\u0446\u0435 \u0446\u0438\u043a\u043b\u0430) \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0431\u0430\u0437\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u0440\u0435\u0434\u043d\u0438\u0439 ttl \u043f\u043e \u043f\u0440\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u043d\u044b\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c;<\/p>\n<\/li>\n<li>\n<p><code>expired_time_cap_reached_count<\/code> &#8212; \u0444\u0430\u043a\u0442 \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u044f \u043e\u0431\u0449\u0435\u0433\u043e \u043b\u0438\u043c\u0438\u0442\u0430 \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043d\u0430 \u0446\u0438\u043a\u043b \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0441\u0440\u043e\u0447\u0435\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439;<\/p>\n<\/li>\n<li>\n<p><code>expire_cycle_cpu_milliseconds<\/code> &#8212; \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u043f\u043e\u0442\u0440\u0430\u0447\u0435\u043d\u043e \u043d\u0430 \u0430\u043a\u0442\u0438\u0432\u043d\u0443\u044e \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044e<\/p>\n<\/li>\n<li>\n<p><code>expired_stale_perc<\/code> &#8212; \u043e\u0446\u0435\u043d\u043a\u0430 \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043a\u043b\u044e\u0447\u0435\u0439 \u043e\u0436\u0438\u0434\u0430\u044e\u0442 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0438\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441\u0430 \u0432 \u0442\u0435\u043a\u0443\u0449\u0435\u043c \u0446\u0438\u043a\u043b\u0435<\/p>\n<\/li>\n<\/ul>\n<pre><code class=\"cpp\">if (total_sampled) { current_perc = (double)total_expired\/total_sampled; } else current_perc = 0; server.stat_expired_stale_perc = (current_perc*0.05)+ (server.stat_expired_stale_perc*0.95);<\/code><\/pre>\n<ul>\n<li>\n<p><code>expired_keys<\/code> &#8212; \u0432\u0441\u0435\u0433\u043e \u0443\u0434\u0430\u043b\u0435\u043d\u043e \u043f\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u0441\u0440\u043e\u043a\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043c\u043e\u043c\u0435\u043d\u0442\u0430 \u0441\u0431\u0440\u043e\u0441\u0430 \u0441\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043a\u0438 \u043f\u043e \u0431\u0430\u0437\u0435.<\/p>\n<\/li>\n<\/ul>\n<h4>INFO KEYSPACE<\/h4>\n<pre><code>db0:keys=13906244,expires=13906244,avg_ttl=882,subexpiry=0<\/code><\/pre>\n<p>expires &#8212; \u0440\u0430\u0437\u043c\u0435\u0440 KV expires \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445<\/p>\n<h4>\u041a\u043e\u043d\u0442\u0440\u043e\u043b\u044c latency<\/h4>\n<p>\u041f\u0440\u0438 \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u0438 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u043f\u043e\u0440\u043e\u0433\u0430 &#171;latency-monitor-threshold&#187; \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0430 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0431\u044b\u0442\u0438\u0435 &#171;expire-cycle&#187;.<br \/> \u041a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043c\u043e\u0436\u043d\u043e:<br \/> <code>latency history expire-cycle<\/code><br \/> \u043f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0432\u043e\u0434\u0430:<\/p>\n<pre><code>127.0.0.1:16379&gt; latency history expire-cycle   1) 1) (integer) 1747146747      2) (integer) 13   2) 1) (integer) 1747146749      2) (integer) 10   3) 1) (integer) 1747146750      2) (integer) 18   4) 1) (integer) 1747146751      2) (integer) 20   5) 1) (integer) 1747146752      2) (integer) 17   6) 1) (integer) 1747146753<\/code><\/pre>\n<p>\u041a\u043e\u0433\u0434\u0430 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d \u043f\u043e\u0440\u043e\u0433? \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043a\u043e\u0433\u0434\u0430 \u0443 \u043d\u0430\u0441 \u0432 \u043c\u043e\u043c\u0435\u043d\u0442\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u044f \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u0441\u0443\u0449\u043d\u043e\u0441\u0442\u0435\u0439.<\/p>\n<h3>\u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u043f\u043e\u0449\u0443\u043f\u0430\u0442\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u0440\u0443\u043a\u0430\u043c\u0438<\/h3>\n<p>\u0418\u043c\u0435\u0435\u043c \u0432 \u0411\u0414 0 \u0434\u0432\u0430 \u0432\u0438\u0434\u0430 \u043a\u043b\u044e\u0447\u0435\u0439 (<a href=\"https:\/\/github.com\/xelavopelk\/redis-go-test\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/xelavopelk\/redis-go-test<\/a>): 30 \u043c\u043b\u043d \u0441 \u043f\u0440\u043e\u0442\u0443\u0445\u0430\u043d\u0438\u0435\u043c \u0432 \u0441\u0443\u0442\u043a\u0438 \u0438 2 \u043c\u043b\u043d \u0441 \u043f\u0440\u043e\u0442\u0443\u0445\u0430\u043d\u0438\u0435\u043c \u0432 \u0442\u0435\u0447\u0435\u043d\u0438\u0438 \u043c\u0438\u043d\u0443\u0442\u044b (\u0434\u0430\u043b\u0435\u0435 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u0430 \u0436\u0435 \u0441\u0445\u0435\u043c\u0430 \u0434\u043b\u044f \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f). \u0421\u043c\u043e\u0442\u0440\u0438\u043c \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u044f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438.<\/p>\n<ul>\n<li>\n<p>\u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0442\u0435\u043c\u043f \u044d\u043a\u0441\u043f\u0438\u0440\u0430\u0446\u0438\u0438 case1, \u0432\u0441\u0435 \u043a\u043b\u044e\u0447\u0438 \u0432 \u043e\u0434\u043d\u043e\u0439 \u0411\u0414 . \u041a\u0430\u043a \u0432\u0438\u0434\u043d\u043e, \u0437\u0430 3 \u043c\u0438\u043d\u0443\u0442\u044b \u0443\u0434\u0430\u043b\u0435\u043d\u043e \u0432\u0441\u0435\u0433\u043e \u043f\u043e\u0440\u044f\u0434\u043a\u0430 3 \u0442\u044b\u0441 \u043a\u043b\u044e\u0447\u0435\u0439. \u0415\u0441\u043b\u0438 \u0431\u0430\u0437\u0430 \u0431\u0443\u0434\u0435\u0442 \u043d\u0430\u043f\u043e\u043b\u043d\u044f\u0442\u044c\u0441\u044f, \u0442\u043e \u043f\u043e \u0441\u0443\u0442\u0438 \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u0443\u0434\u0430\u043b\u0435\u043d\u044b, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u0447\u043d\u0451\u0442\u0441\u044f \u0430\u043a\u0442\u0438\u0432\u043d\u043e\u0435 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435 \u0441\u0443\u0442\u043e\u0447\u043d\u044b\u0445 \u043a\u043b\u044e\u0447\u0435\u0439 \u043b\u0438\u0431\u043e \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u043c \u0441 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435\u043c \u043e\u0431\u044a\u0451\u043c\u0430 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f.<\/p>\n<\/li>\n<\/ul>\n<pre><code>ts: 02:01:30 PM info: # Keyspace db0:keys=31999999,expires=31999999,avg_ttl=81010601,subexpiry=0  ...  ts: 02:04:40 PM info:  # Keyspace  db0:keys=31997626,expires=31997626,avg_ttl=86082556,subexpiry=0<\/code><\/pre>\n<ul>\n<li>\n<p>\u0415\u0441\u043b\u0438 \u0432\u044b\u043d\u0435\u0441\u0442\u0438 &#171;\u043c\u0438\u043d\u0443\u0442\u043d\u044b\u0435&#187; \u043a\u043b\u044e\u0447\u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e &#8212; case2 &#8212; \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u043e<\/p>\n<\/li>\n<\/ul>\n<pre><code>ts: 02:35:27 db1:keys=2000000,expires=2000000,avg_ttl=41059,subexpiry=0 ...<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-459978","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/459978","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=459978"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/459978\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=459978"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=459978"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=459978"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}