]> pere.pagekite.me Git - homepage.git/blob - blog/Why_the_KDE_menu_is_slow_when__usr__is_NFS_mounted___and_a_workaround.html
Generated.
[homepage.git] / blog / Why_the_KDE_menu_is_slow_when__usr__is_NFS_mounted___and_a_workaround.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr">
4 <head>
5 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen: Why the KDE menu is slow when /usr/ is NFS mounted - and a workaround</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9
10
11 </head>
12 <body>
13 <div class="title">
14 <h1>
15 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
16
17 </h1>
18
19 </div>
20
21
22 <div class="entry">
23 <div class="title">Why the KDE menu is slow when /usr/ is NFS mounted - and a workaround</div>
24 <div class="date"> 6th April 2012</div>
25 <div class="body"><p>Recently I have spent time with
26 <a href="http://www.slxdrift.no/">Skolelinux Drift AS</a> on speeding
27 up a <a href="http://www.skolelinux.org/">Debian Edu / Skolelinux</a>
28 Lenny installation using LTSP diskless workstations, and in the
29 process I discovered something very surprising. The reason the KDE
30 menu was responding slow when using it for the first time, was mostly
31 due to the way KDE find application icons. I discovered that showing
32 the Multimedia menu would cause more than 20 000 IP packages to be
33 passed between the LTSP client and the NFS server. Most of these were
34
35 NFS LOOKUP calls, resulting in a NFS3ERR_NOENT response. Because the
36 ping times between the client and the server were in the range 2-20
37 ms, the menus would be very slow. Looking at the strace of kicker in
38 Lenny (or plasma-desktop i Squeeze - same problem there), I see that
39 the source of these NFS calls are access(2) system calls for
40 non-existing files. KDE can do hundreds of access(2) calls to find
41 one icon file. In my example, just finding the mplayer icon required
42 around 230 access(2) calls.</p>
43
44 <p>The KDE code seem to search for icons using a list of icon
45 directories, and the list of possible directories is large. In
46 (almost) each directory, it look for files ending in .png, .svgz, .svg
47 and .xpm. The result is a very slow KDE menu when /usr/ is NFS
48 mounted. Showing a single sub menu may result in thousands of NFS
49 requests. I am not the first one to discover this. I found a
50 <a href="https://bugs.kde.org/show_bug.cgi?id=211416">KDE bug report
51 from 2009</a> about this problem, and it is still unsolved.</p>
52
53 <p>My solution to speed up the KDE menu was to create a package
54 kde-icon-cache that upon installation will look at all .desktop files
55 used to generate the KDE menu, find their icons, search the icon paths
56 for the file that KDE will end up finding at run time, and copying the
57 icon file to /var/lib/kde-icon-cache/. Finally, I add symlinks to
58 these icon files in one of the first directories where KDE will look
59 for them. This cut down the number of file accesses required to find
60 one icon from several hundred to less than 5, and make the KDE menu
61 almost instantaneous. I'm not quite sure where to make the package
62 publicly available, so for now it is only available on request.</p>
63
64 <p>The bug report mention that this do not only affect the KDE menu
65 and icon handling, but also the login process. Not quite sure how to
66 speed up that part without replacing NFS with for example NBD, and
67 that is not really an option at the moment.</p>
68
69 <p>If you got feedback on this issue, please let us know on debian-edu
70 (at) lists.debian.org.</p>
71 </div>
72
73 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>.</div>
74
75
76 </div>
77
78
79
80
81 <div id="sidebar">
82
83
84
85 <h2>Archive</h2>
86 <ul>
87
88 <li>2015
89 <ul>
90
91 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/01/">January (7)</a></li>
92
93 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/02/">February (6)</a></li>
94
95 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/03/">March (1)</a></li>
96
97 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/04/">April (4)</a></li>
98
99 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/05/">May (3)</a></li>
100
101 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/06/">June (4)</a></li>
102
103 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/07/">July (1)</a></li>
104
105 </ul></li>
106
107 <li>2014
108 <ul>
109
110 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/01/">January (2)</a></li>
111
112 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/02/">February (3)</a></li>
113
114 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/03/">March (8)</a></li>
115
116 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/04/">April (7)</a></li>
117
118 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/05/">May (1)</a></li>
119
120 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/06/">June (2)</a></li>
121
122 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/07/">July (2)</a></li>
123
124 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/08/">August (2)</a></li>
125
126 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/09/">September (5)</a></li>
127
128 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/10/">October (6)</a></li>
129
130 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/11/">November (3)</a></li>
131
132 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/12/">December (5)</a></li>
133
134 </ul></li>
135
136 <li>2013
137 <ul>
138
139 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
140
141 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
142
143 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
144
145 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
146
147 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
148
149 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
150
151 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
152
153 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
154
155 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
156
157 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/10/">October (7)</a></li>
158
159 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/11/">November (9)</a></li>
160
161 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/12/">December (3)</a></li>
162
163 </ul></li>
164
165 <li>2012
166 <ul>
167
168 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
169
170 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
171
172 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
173
174 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
175
176 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
177
178 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
179
180 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
181
182 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
183
184 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
185
186 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
187
188 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
189
190 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
191
192 </ul></li>
193
194 <li>2011
195 <ul>
196
197 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
198
199 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
200
201 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
202
203 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
204
205 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
206
207 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
210
211 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
212
213 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
214
215 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
216
217 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
218
219 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
220
221 </ul></li>
222
223 <li>2010
224 <ul>
225
226 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
227
228 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
229
230 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
231
232 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
233
234 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
239
240 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
241
242 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
243
244 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
245
246 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
247
248 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
249
250 </ul></li>
251
252 <li>2009
253 <ul>
254
255 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
256
257 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
258
259 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
260
261 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
262
263 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
264
265 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
266
267 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
268
269 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
270
271 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
272
273 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
274
275 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
276
277 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
278
279 </ul></li>
280
281 <li>2008
282 <ul>
283
284 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
285
286 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
287
288 </ul></li>
289
290 </ul>
291
292
293
294 <h2>Tags</h2>
295 <ul>
296
297 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
298
299 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
300
301 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
302
303 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
304
305 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (8)</a></li>
306
307 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (15)</a></li>
308
309 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
310
311 <li><a href="http://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (2)</a></li>
312
313 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (109)</a></li>
314
315 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (153)</a></li>
316
317 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (10)</a></li>
318
319 <li><a href="http://people.skolelinux.org/pere/blog/tags/dld">dld (15)</a></li>
320
321 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (13)</a></li>
322
323 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
324
325 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (280)</a></li>
326
327 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (23)</a></li>
328
329 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
330
331 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (15)</a></li>
332
333 <li><a href="http://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (9)</a></li>
334
335 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (16)</a></li>
336
337 <li><a href="http://people.skolelinux.org/pere/blog/tags/h264">h264 (19)</a></li>
338
339 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (42)</a></li>
340
341 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (10)</a></li>
342
343 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (19)</a></li>
344
345 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (9)</a></li>
346
347 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (8)</a></li>
348
349 <li><a href="http://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (2)</a></li>
350
351 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
352
353 <li><a href="http://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (8)</a></li>
354
355 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (35)</a></li>
356
357 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (263)</a></li>
358
359 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (176)</a></li>
360
361 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (18)</a></li>
362
363 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
364
365 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (52)</a></li>
366
367 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (86)</a></li>
368
369 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
370
371 <li><a href="http://people.skolelinux.org/pere/blog/tags/reactos">reactos (1)</a></li>
372
373 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
374
375 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (3)</a></li>
376
377 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (9)</a></li>
378
379 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
380
381 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
382
383 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
384
385 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (41)</a></li>
386
387 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
388
389 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
390
391 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (47)</a></li>
392
393 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
394
395 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (9)</a></li>
396
397 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (33)</a></li>
398
399 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (2)</a></li>
400
401 <li><a href="http://people.skolelinux.org/pere/blog/tags/usenix">usenix (2)</a></li>
402
403 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (8)</a></li>
404
405 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (53)</a></li>
406
407 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
408
409 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (36)</a></li>
410
411 </ul>
412
413
414 </div>
415 <p style="text-align: right">
416 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
417 </p>
418
419 </body>
420 </html>