]> pere.pagekite.me Git - homepage.git/blob - blog/Circular_package_dependencies_harms_apt_recovery.html
Generated.
[homepage.git] / blog / Circular_package_dependencies_harms_apt_recovery.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: Circular package dependencies harms apt recovery</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">Circular package dependencies harms apt recovery</div>
24 <div class="date">27th July 2010</div>
25 <div class="body"><p>I discovered this while doing
26 <a href="http://people.skolelinux.org/pere/blog/Automatic_upgrade_testing_from_Lenny_to_Squeeze.html">automated
27 testing of upgrades from Debian Lenny to Squeeze</a>. A few packages
28 in Debian still got circular dependencies, and it is often claimed
29 that apt and aptitude should be able to handle this just fine, but
30 some times these dependency loops causes apt to fail.</p>
31
32 <p>An example is from todays
33 <a href="http://people.skolelinux.org/~pere/debian-upgrade-testing//test-20100727-lenny-squeeze-kde-aptitude.txt">upgrade
34 of KDE using aptitude</a>. In it, a bug in kdebase-workspace-data
35 causes perl-modules to fail to upgrade. The cause is simple. If a
36 package fail to unpack, then only part of packages with the circular
37 dependency might end up being unpacked when unpacking aborts, and the
38 ones already unpacked will fail to configure in the recovery phase
39 because its dependencies are unavailable.</p>
40
41 <p>In this log, the problem manifest itself with this error:</p>
42
43 <blockquote><pre>
44 dpkg: dependency problems prevent configuration of perl-modules:
45 perl-modules depends on perl (>= 5.10.1-1); however:
46 Version of perl on system is 5.10.0-19lenny2.
47 dpkg: error processing perl-modules (--configure):
48 dependency problems - leaving unconfigured
49 </pre></blockquote>
50
51 <p>The perl/perl-modules circular dependency is already
52 <a href="http://bugs.debian.org/527917">reported as a bug</a>, and will
53 hopefully be solved as soon as possible, but it is not the only one,
54 and each one of these loops in the dependency tree can cause similar
55 failures. Of course, they only occur when there are bugs in other
56 packages causing the unpacking to fail, but it is rather nasty when
57 the failure of one package causes the problem to become worse because
58 of dependency loops.</p>
59
60 <p>Thanks to
61 <a href="http://lists.debian.org/debian-devel/2010/06/msg00116.html">the
62 tireless effort by Bill Allombert</a>, the number of circular
63 dependencies
64 <a href="http://debian.semistable.com/debgraph.out.html">left in Debian
65 is dropping</a>, and perhaps it will reach zero one day. :)</p>
66
67 <p>Todays testing also exposed a bug in
68 <a href="http://bugs.debian.org/590605">update-notifier</a> and
69 <a href="http://bugs.debian.org/590604">different behaviour</a> between
70 apt-get and aptitude, the latter possibly caused by some circular
71 dependency. Reported both to BTS to try to get someone to look at
72 it.</p>
73 </div>
74
75 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug</a>.</div>
76
77
78 </div>
79
80
81
82
83 <div id="sidebar">
84
85
86
87 <h2>Archive</h2>
88 <ul>
89
90 <li>2013
91 <ul>
92
93 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
94
95 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
96
97 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
98
99 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
100
101 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
102
103 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
104
105 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
106
107 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
108
109 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
110
111 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/10/">October (7)</a></li>
112
113 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/11/">November (9)</a></li>
114
115 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/12/">December (2)</a></li>
116
117 </ul></li>
118
119 <li>2012
120 <ul>
121
122 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
123
124 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
125
126 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
127
128 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
129
130 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
131
132 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
133
134 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
135
136 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
137
138 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
139
140 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
141
142 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
143
144 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
145
146 </ul></li>
147
148 <li>2011
149 <ul>
150
151 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
152
153 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
154
155 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
156
157 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
158
159 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
160
161 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
162
163 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
164
165 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
166
167 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
168
169 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
170
171 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
172
173 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
174
175 </ul></li>
176
177 <li>2010
178 <ul>
179
180 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
181
182 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
183
184 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
185
186 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
187
188 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
189
190 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
191
192 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
193
194 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
195
196 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
197
198 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
199
200 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
201
202 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
203
204 </ul></li>
205
206 <li>2009
207 <ul>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
210
211 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
212
213 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
214
215 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
216
217 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
218
219 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
220
221 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
222
223 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
224
225 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
226
227 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
228
229 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
230
231 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
232
233 </ul></li>
234
235 <li>2008
236 <ul>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
239
240 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
241
242 </ul></li>
243
244 </ul>
245
246
247
248 <h2>Tags</h2>
249 <ul>
250
251 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
252
253 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
254
255 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
256
257 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
258
259 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (7)</a></li>
260
261 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (13)</a></li>
262
263 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
264
265 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (91)</a></li>
266
267 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (143)</a></li>
268
269 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (10)</a></li>
270
271 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (10)</a></li>
272
273 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
274
275 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (231)</a></li>
276
277 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (21)</a></li>
278
279 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
280
281 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (12)</a></li>
282
283 <li><a href="http://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (5)</a></li>
284
285 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (11)</a></li>
286
287 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (38)</a></li>
288
289 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (7)</a></li>
290
291 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (18)</a></li>
292
293 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (8)</a></li>
294
295 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (6)</a></li>
296
297 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
298
299 <li><a href="http://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (7)</a></li>
300
301 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (25)</a></li>
302
303 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (239)</a></li>
304
305 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (161)</a></li>
306
307 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (9)</a></li>
308
309 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
310
311 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (45)</a></li>
312
313 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (67)</a></li>
314
315 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
316
317 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
318
319 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (2)</a></li>
320
321 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (9)</a></li>
322
323 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
324
325 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
326
327 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
328
329 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (33)</a></li>
330
331 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
332
333 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
334
335 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (44)</a></li>
336
337 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
338
339 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (9)</a></li>
340
341 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (21)</a></li>
342
343 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (1)</a></li>
344
345 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (8)</a></li>
346
347 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (39)</a></li>
348
349 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
350
351 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (28)</a></li>
352
353 </ul>
354
355
356 </div>
357 <p style="text-align: right">
358 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
359 </p>
360
361 </body>
362 </html>