public inbox for gentoo-user@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-user] Corrupt portage cache
@ 2006-11-26 11:56 Mick
  2006-11-26 12:20 ` Fabrice Delliaux
  0 siblings, 1 reply; 6+ messages in thread
From: Mick @ 2006-11-26 11:56 UTC (permalink / raw
  To: gentoo-user

Hi All,

I am trying to update/upgrade a box that has been standing for the
last year or so and this is what I have up to:
====================================
# emerge --metadata -v

>>> Updating Portage cache:      Traceback (most recent call last):
  File "/usr/bin/emerge", line 4049, in ?
    emerge_main()
  File "/usr/bin/emerge", line 4008, in emerge_main
    action_metadata(settings, portdb, myopts)
  File "/usr/bin/emerge", line 3019, in action_metadata
    eclass_cache=ec, verbose_instance=noise_maker)
  File "/usr/lib/portage/pym/cache/util.py", line 47, in mirror_cache
    if trg and not write_it:
  File "/usr/lib/python2.4/UserDict.py", line 170, in __len__
    return len(self.keys())
  File "/usr/lib/portage/pym/cache/mappings.py", line 54, in keys
    return list(self.__iter__())
  File "/usr/lib/portage/pym/cache/mappings.py", line 48, in __iter__
    for k in self.orig.iterkeys():
  File "/usr/lib/python2.4/UserDict.py", line 103, in iterkeys
    return self.__iter__()
  File "/usr/lib/portage/pym/cache/mappings.py", line 83, in __iter__
    return iter(self.keys())
  File "/usr/lib/portage/pym/cache/mappings.py", line 87, in keys
    self.d.update(self.pull())
  File "/usr/lib/portage/pym/cache/flat_hash.py", line 29, in callit
    return args[0](*args[1:]+args2)
  File "/usr/lib/portage/pym/cache/flat_hash.py", line 47, in _pull
    raise cache_errors.CacheCorruption(cpv, e)
cache.cache_errors.CacheCorruption:
app-accessibility/SphinxTrain-0.9.1-r1 is corrupt: dictionary update
sequence element #0 has length 1; 2 is required
====================================

Any idea how to fix it?
-- 
Regards,
Mick
-- 
gentoo-user@gentoo.org mailing list



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [gentoo-user] Corrupt portage cache
  2006-11-26 11:56 [gentoo-user] Corrupt portage cache Mick
@ 2006-11-26 12:20 ` Fabrice Delliaux
  2006-11-26 12:27   ` Mick
  2006-11-26 12:41   ` [gentoo-user] " Harm Geerts
  0 siblings, 2 replies; 6+ messages in thread
From: Fabrice Delliaux @ 2006-11-26 12:20 UTC (permalink / raw
  To: gentoo-user

Le Sun, 26 Nov 2006 11:56:43 +0000,
Mick a écrit :

> Hi All,

Hi,

> I am trying to update/upgrade a box that has been standing for the
> last year or so and this is what I have up to:
> ====================================
> # emerge --metadata -v

[...]

> 
> Any idea how to fix it?

Try :

  # rm -rf /usr/portage/metadata/cache/* && emerge --sync

Assumed that /usr/portage is the current location of your portage tree.

-- 
gentoo-user@gentoo.org mailing list



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [gentoo-user] Corrupt portage cache
  2006-11-26 12:20 ` Fabrice Delliaux
@ 2006-11-26 12:27   ` Mick
  2006-11-26 12:41   ` [gentoo-user] " Harm Geerts
  1 sibling, 0 replies; 6+ messages in thread
From: Mick @ 2006-11-26 12:27 UTC (permalink / raw
  To: gentoo-user

[-- Attachment #1: Type: text/plain, Size: 486 bytes --]

On Sunday 26 November 2006 12:20, Fabrice Delliaux wrote:
> Le Sun, 26 Nov 2006 11:56:43 +0000,
>
> Mick a écrit :

> > I am trying to update/upgrade a box that has been standing for the
> > last year or so and this is what I have up to:
> > ====================================
> > # emerge --metadata -v
>
> [...]
>
> > Any idea how to fix it?
>
> Try :
>
>   # rm -rf /usr/portage/metadata/cache/* && emerge --sync

Thanks!  That fixed it.

-- 
Regards,
Mick

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

* [gentoo-user] Re: Corrupt portage cache
  2006-11-26 12:20 ` Fabrice Delliaux
  2006-11-26 12:27   ` Mick
@ 2006-11-26 12:41   ` Harm Geerts
  2006-11-26 13:33     ` Fabrice Delliaux
  1 sibling, 1 reply; 6+ messages in thread
From: Harm Geerts @ 2006-11-26 12:41 UTC (permalink / raw
  To: gentoo-user

On Sunday 26 November 2006 13:20, Fabrice Delliaux wrote:
> Le Sun, 26 Nov 2006 11:56:43 +0000,
> > Any idea how to fix it?
>
> Try :
>
>   # rm -rf /usr/portage/metadata/cache/* && emerge --sync
>
> Assumed that /usr/portage is the current location of your portage tree.

This is not the way to fix it.
This only forces portage to retrieve *all* of portage's metadata from the 
server *again*. If the corruption is local, a normal rsync will fix this. If 
the corruption is on the upstream rsync mirror, you will retrieve the same 
corrupt metadata again.

removing the metadata from the portage tree only results in more data 
transfers from the rsync mirror.

This error will resolve itself when the corruption is synced out, upstream or 
local. To speed that process up, you can switch to a different rsync mirror 
and sync against that. That will eliminate both possible corruptions.
-- 
gentoo-user@gentoo.org mailing list



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [gentoo-user] Re: Corrupt portage cache
  2006-11-26 12:41   ` [gentoo-user] " Harm Geerts
@ 2006-11-26 13:33     ` Fabrice Delliaux
  2006-11-29 23:02       ` Mick
  0 siblings, 1 reply; 6+ messages in thread
From: Fabrice Delliaux @ 2006-11-26 13:33 UTC (permalink / raw
  To: gentoo-user

Le Sun, 26 Nov 2006 13:41:56 +0100,
Harm Geerts a écrit :
> This only forces portage to retrieve *all* of portage's metadata from
> the server *again*.

Yes.

> If the corruption is local, a normal rsync will fix this.

Not necessarily. See bug #145482.
Synchronization again and again (on several days) didn't resolve this.
I removed the entire cache, as suggested, and it magically worked.
And I discovered later that the filesystem was corrupted.

> If the corruption is on the upstream rsync mirror, you will retrieve
> the same corrupt metadata again.

I've never seen that case.

> removing the metadata from the portage tree only results in more data 
> transfers from the rsync mirror.

Yes, but obviously, you must not do it every day.

@Mick : I suggest that you run a fsck on your filesystem.

-- 
gentoo-user@gentoo.org mailing list



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [gentoo-user] Re: Corrupt portage cache
  2006-11-26 13:33     ` Fabrice Delliaux
@ 2006-11-29 23:02       ` Mick
  0 siblings, 0 replies; 6+ messages in thread
From: Mick @ 2006-11-29 23:02 UTC (permalink / raw
  To: gentoo-user

[-- Attachment #1: Type: text/plain, Size: 1265 bytes --]

On Sunday 26 November 2006 13:33, Fabrice Delliaux wrote:
> Le Sun, 26 Nov 2006 13:41:56 +0100,
>
> Harm Geerts a écrit :
> > This only forces portage to retrieve *all* of portage's metadata from
> > the server *again*.
>
> Yes.
>
> > If the corruption is local, a normal rsync will fix this.
>
> Not necessarily. See bug #145482.
> Synchronization again and again (on several days) didn't resolve this.
> I removed the entire cache, as suggested, and it magically worked.
> And I discovered later that the filesystem was corrupted.
>
> > If the corruption is on the upstream rsync mirror, you will retrieve
> > the same corrupt metadata again.
>
> I've never seen that case.
>
> > removing the metadata from the portage tree only results in more data
> > transfers from the rsync mirror.
>
> Yes, but obviously, you must not do it every day.
>
> @Mick : I suggest that you run a fsck on your filesystem.

Thanks.  I did run fsck and everything seems fine.  However, although 
emerge --metadata worked, the following emerge --sync failed with the same 
old error.

So, this time I did emerge --regen and when it finished the emerge --sync 
worked without any more problems.

Thanks for all the suggestions.
-- 
Regards,
Mick

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2006-11-29 23:15 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-11-26 11:56 [gentoo-user] Corrupt portage cache Mick
2006-11-26 12:20 ` Fabrice Delliaux
2006-11-26 12:27   ` Mick
2006-11-26 12:41   ` [gentoo-user] " Harm Geerts
2006-11-26 13:33     ` Fabrice Delliaux
2006-11-29 23:02       ` Mick

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox