-
Notifications
You must be signed in to change notification settings - Fork 0
/
huan-cun-zhi-shi-dian.html
261 lines (221 loc) · 16.1 KB
/
huan-cun-zhi-shi-dian.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="author" content="CatsAction" />
<meta property="og:type" content="article" />
<meta name="twitter:card" content="summary">
<meta name="keywords" content="Redis, Memcached, Cached, " />
<meta property="og:title" content="缓存知识点"/>
<meta property="og:url" content="./huan-cun-zhi-shi-dian.html" />
<meta property="og:description" content="记录Redis和Memcached学习和使用的问题及思考,先简单记录,再抽时间详细完善。 缓存可能存在的问题 缓存雪崩 定义:缓存同时过期失效。 解决方法:交错失效时间,或者限制访问后端db的并发量。 缓存穿透 定义:缓存没有,数据库也没有。 解决方法:可以通过布隆过滤器过滤恶意的请求key。或者缓存空值提高命中率。 缓存击穿 定义:热点key未命中。 解决方法:可以增加多级缓存解决。 Memcached和Redis的区别 Memcached单进程多线程,而Redis单进程单线程。处理小数据时,Redis性能比Memcached高,而在100K以上的数据中,Memcached性能要高于Redis。 Memcached只支持key-value数据类型,而Redis支持丰富的数据类型。 Redis并不是将所有数据存储在内存中。当内存容量用完时,Redis会swap一部分数据到磁盘上,而且也支持数据持久化。 从内存利用率来讲,使用简单的key-value存储的话,Memcached的内存利用率更高。而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。 Memcached本身并不支持分布式,因此只能在客户端通过像一致性哈希这样的分布式算法来实现Memcached的分布式存储。相较于Memcached只能采用客户端实现分布式存储,Redis更偏向于在服务器端构建分布式存储。 Redis支持服务端的数据操作,而Memcached需要将数据拿到客户端修改再set回去,增加了io操作。 关于Memcached和redis对比,可以参考 …" />
<meta property="og:site_name" content="CatsAction's blog" />
<meta property="og:article:author" content="CatsAction" />
<meta property="og:article:published_time" content="2019-10-13T00:00:00+08:00" />
<meta name="twitter:title" content="缓存知识点">
<meta name="twitter:description" content="记录Redis和Memcached学习和使用的问题及思考,先简单记录,再抽时间详细完善。 缓存可能存在的问题 缓存雪崩 定义:缓存同时过期失效。 解决方法:交错失效时间,或者限制访问后端db的并发量。 缓存穿透 定义:缓存没有,数据库也没有。 解决方法:可以通过布隆过滤器过滤恶意的请求key。或者缓存空值提高命中率。 缓存击穿 定义:热点key未命中。 解决方法:可以增加多级缓存解决。 Memcached和Redis的区别 Memcached单进程多线程,而Redis单进程单线程。处理小数据时,Redis性能比Memcached高,而在100K以上的数据中,Memcached性能要高于Redis。 Memcached只支持key-value数据类型,而Redis支持丰富的数据类型。 Redis并不是将所有数据存储在内存中。当内存容量用完时,Redis会swap一部分数据到磁盘上,而且也支持数据持久化。 从内存利用率来讲,使用简单的key-value存储的话,Memcached的内存利用率更高。而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。 Memcached本身并不支持分布式,因此只能在客户端通过像一致性哈希这样的分布式算法来实现Memcached的分布式存储。相较于Memcached只能采用客户端实现分布式存储,Redis更偏向于在服务器端构建分布式存储。 Redis支持服务端的数据操作,而Memcached需要将数据拿到客户端修改再set回去,增加了io操作。 关于Memcached和redis对比,可以参考 …">
<title>缓存知识点 ·
CatsAction's blog
</title>
<link href="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet">
<link rel="icon" type="image/x-icon" href="./theme/image/logo.ico" />
<link rel="stylesheet" type="text/css" href="./theme/css/elegant.prod.css" media="screen">
<link rel="stylesheet" type="text/css" href="./theme/css/custom.css" media="screen">
</head>
<body>
<div id="content">
<div class="navbar navbar-static-top">
<div class="navbar-inner">
<div class="container-fluid">
<a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</a>
<a class="brand" href="./"><span class=site-name>CatsAction's blog</span></a>
<div class="nav-collapse collapse">
<ul class="nav pull-right top-menu">
<li >
<a href=
.
>Home</a>
</li>
<li ><a href="./categories.html">Categories</a></li>
<li ><a href="./tags.html">Tags</a></li>
<li ><a href="./archives.html">Archives</a></li>
<li><form class="navbar-search" action="./search.html" onsubmit="return validateForm(this.elements['q'].value);"> <input type="text" class="search-query" placeholder="Search" name="q" id="tipue_search_input"></form></li>
</ul>
</div>
</div>
</div>
</div>
<div class="container-fluid">
<div class="row-fluid">
<div class="span1"></div>
<div class="span10">
<article itemscope>
<div class="row-fluid">
<header class="page-header span10 offset2">
<h1>
<a href="./huan-cun-zhi-shi-dian.html">
缓存知识点
</a>
</h1>
</header>
</div>
<div class="row-fluid">
<div class="span8 offset2 article-content">
<p>记录Redis和Memcached学习和使用的问题及思考,先简单记录,再抽时间详细完善。 </p>
<h5>缓存可能存在的问题</h5>
<h6>缓存雪崩</h6>
<p>定义:缓存同时过期失效。 <br>
解决方法:交错失效时间,或者限制访问后端db的并发量。</p>
<h6>缓存穿透</h6>
<p>定义:缓存没有,数据库也没有。 <br>
解决方法:可以通过布隆过滤器过滤恶意的请求key。或者缓存空值提高命中率。</p>
<h6>缓存击穿</h6>
<p>定义:热点key未命中。 <br>
解决方法:可以增加多级缓存解决。</p>
<h5>Memcached和Redis的区别</h5>
<ul>
<li>Memcached单进程多线程,而Redis单进程单线程。处理小数据时,Redis性能比Memcached高,而在100K以上的数据中,Memcached性能要高于Redis。</li>
<li>Memcached只支持key-value数据类型,而Redis支持丰富的数据类型。</li>
<li>Redis并不是将所有数据存储在内存中。当内存容量用完时,Redis会swap一部分数据到磁盘上,而且也支持数据持久化。</li>
<li>从内存利用率来讲,使用简单的key-value存储的话,Memcached的内存利用率更高。而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。</li>
<li>Memcached本身并不支持分布式,因此只能在客户端通过像一致性哈希这样的分布式算法来实现Memcached的分布式存储。相较于Memcached只能采用客户端实现分布式存储,Redis更偏向于在服务器端构建分布式存储。</li>
<li>Redis支持服务端的数据操作,而Memcached需要将数据拿到客户端修改再set回去,增加了io操作。</li>
</ul>
<p>关于Memcached和redis对比,可以参考<a href="http://www.360doc.com/content/18/0309/11/11935121_735604822.shtml">Memcached和Redis区别</a></p>
<h5>Redis主从复制的高可用解决方案</h5>
<p>Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,如果master宕机,Redis自身并不能实现自动进行主备切换,sentinel可以监控复制节点的状态,当主节点宕机后,它能根据选举方式选出后端的一个从节点作为新的master,sentinel还能监控多个master-slave集群,发现master宕机后能进行自动切换。</p>
<p>同时,sentinel本身也存在单点问题,通常sentinel也是一个集群,因此,redis的复制集群通常是下面的结构</p>
<h6>sentinel集群工作原理</h6>
<ul>
<li>
<p>sentinel集群通过给定的配置文件发现master,启动时会监控master。通过向master发送info信息获得该服务器下面的所有从服务器。</p>
</li>
<li>
<p>sentinel集群通过流言协议与其他sentinel通信,以此来发现监视同一个主服务器的其他sentinel;集群之间会互相创建命令连接用于通信。</p>
</li>
<li>
<p>sentinel集群使用ping命令来检测实例的状态,如果在指定的时间内(down-after-milliseconds)没有回复或则返回错误的回复,sentinel会认为主节点宕机,但是并不会立即提升一个从节点为新的master,因为会存在误判的情况,此时为主观宕机。此时当sentinel集群中有一半以上的节点通告master为宕机状态时,此时为客观宕机,sentinel基于选举协议选举提升从节点为新的master,从节点之间根据优先级来决策谁会成为新的master,修复的节点重新上线后作为从节点工作。</p>
</li>
</ul>
<p>更多Redis-sentinel,可以参考<a href="https://www.cnblogs.com/lizhaojun-ops/p/9447016.html">运维那些破事</a></p>
<hr />
<aside>
<nav>
<ul class="articles-timeline">
<li class="previous-article">« <a href="./chang-jian-wang-luo-an-quan-zhi.html"
title="Previous: 常见网络安全之 - Django支持">常见网络安全之 <small class="subtitle">Django支持</small></a></li>
<li class="next-article"><a href="./mysqlsuo-yin-zhi.html"
title="Next: MySQL索引之 - 数据结构">MySQL索引之 <small class="subtitle">数据结构</small></a> »</li>
</ul>
</nav>
</aside>
</div>
<section id="article-sidebar" class="span2">
<h4>Published</h4>
<time itemprop="dateCreated" datetime="2019-10-13T00:00:00+08:00">10
13, 2019</time>
<!---->
<h4>Category</h4>
<a class="category-link"
href="./categories.html#cached-ref">Cached</a>
<h4>Tags</h4>
<ul class="list-of-tags tags-in-article">
<li><a href="./tags.html#memcached-ref">Memcached
<span>1</span>
</a></li>
<li><a href="./tags.html#redis-ref">Redis
<span>2</span>
</a></li>
</ul>
<h4>Stay in Touch</h4>
<div id="sidebar-social-link">
<a href="mailto:[email protected]" title="My Email Address" target="_blank" rel="nofollow noopener noreferrer">
<svg xmlns="http://www.w3.org/2000/svg" aria-label="Mail" role="img" viewBox="0 0 512 512"><rect width="512" height="512" rx="15%" fill="#328cff"/><path d="m250 186c-46 0-69 35-69 74 0 44 29 72 68 72 43 0 73-32 73-75 0-44-34-71-72-71zm-1-37c30 0 57 13 77 33 0-22 35-22 35 1v150c-1 10 10 16 16 9 25-25 54-128-14-187-64-56-149-47-195-15-48 33-79 107-49 175 33 76 126 99 182 76 28-12 41 26 12 39-45 19-168 17-225-82-38-68-36-185 67-248 78-46 182-33 244 32 66 69 62 197-2 246-28 23-71 1-71-32v-11c-20 20-47 32-77 32-57 0-108-51-108-108 0-58 51-110 108-110" fill="#fff"/></svg>
</a>
<a href="https://github.com/boyaziqi" title="catsaction Github Repository" target="_blank" rel="nofollow noopener noreferrer">
<svg xmlns="http://www.w3.org/2000/svg" aria-label="GitHub" role="img" viewBox="0 0 512 512"><rect width="512" height="512" rx="15%" fill="#1B1817"/><path fill="#fff" d="M335 499c14 0 12 17 12 17H165s-2-17 12-17c13 0 16-6 16-12l-1-50c-71 16-86-28-86-28-12-30-28-37-28-37-24-16 1-16 1-16 26 2 40 26 40 26 22 39 59 28 74 22 2-17 9-28 16-35-57-6-116-28-116-126 0-28 10-51 26-69-3-6-11-32 3-67 0 0 21-7 70 26 42-12 86-12 128 0 49-33 70-26 70-26 14 35 6 61 3 67 16 18 26 41 26 69 0 98-60 120-117 126 10 8 18 24 18 48l-1 70c0 6 3 12 16 12z"/></svg>
</a>
<a href="https://www.linkedin.com/feed/" title="My LinkedIn" target="_blank" rel="nofollow noopener noreferrer">
<svg xmlns="http://www.w3.org/2000/svg" aria-label="LinkedIn" role="img" viewBox="0 0 512 512" fill="#fff"><rect width="512" height="512" rx="15%" fill="#0077b5"/><circle cx="142" cy="138" r="37"/><path stroke="#fff" stroke-width="66" d="M244 194v198M142 194v198"/><path d="M276 282c0-20 13-40 36-40 24 0 33 18 33 45v105h66V279c0-61-32-89-76-89-34 0-51 19-59 32"/></svg>
</a>
</div>
<h4>Friendship Links</h4>
<ul class="list-of-tags tags-in-article">
<li>
<a href="https://leetcode-cn.com/" title="力扣中国站点" target="_blank" rel="nofollow noopener noreferrer">
LeetCode
</a>
</li>
<li>
<a href="https://coolshell.cn/about" title="陈皓酷壳" target="_blank" rel="nofollow noopener noreferrer">
CoolShell
</a>
</li>
<li>
<a href="https://yikun.github.io/" title="姜毅坤博客" target="_blank" rel="nofollow noopener noreferrer">
Yikun
</a>
</li>
<li>
<a href="https://www.nowcoder.com/" title="牛客网" target="_blank" rel="nofollow noopener noreferrer">
牛客网
</a>
</li>
</ul>
</section>
</div>
</article>
</div>
<div class="span1"></div>
</div>
</div>
</div>
<footer>
<div>
<span class="site-name">CatsAction's blog</span> - It's a wonderful world
</div>
<div id="fpowered">
Powered by: <a href="http://getpelican.com/" title="Pelican Home Page" target="_blank" rel="nofollow noopener noreferrer">Pelican</a>
Theme: <a href="https://elegant.oncrashreboot.com/" title="Theme Elegant Home Page" target="_blank" rel="nofollow noopener noreferrer">Elegant</a>
</div>
</footer> <script src="//code.jquery.com/jquery.min.js"></script>
<script src="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
<script>
function validateForm(query)
{
return (query.length > 0);
}
</script>
<script>
(function () {
if (window.location.hash.match(/^#comment-\d+$/)) {
$('#comment_thread').collapse('show');
}
})();
window.onhashchange=function(){
if (window.location.hash.match(/^#comment-\d+$/))
window.location.reload(true);
}
$('#comment_thread').on('shown', function () {
var link = document.getElementById('comment-accordion-toggle');
var old_innerHTML = link.innerHTML;
$(link).fadeOut(200, function() {
$(this).text('Click here to hide comments').fadeIn(200);
});
$('#comment_thread').on('hidden', function () {
$(link).fadeOut(200, function() {
$(this).text(old_innerHTML).fadeIn(200);
});
})
})
</script>
</body>
<!-- Theme: Elegant built for Pelican
License : MIT -->
</html>