On 2/28/07, Florent Solt <florent at solt.biz>
wrote:>
>   Hello Dave, Hello all,
>
> Some weeks ago, Maz submit a patch to quickly dump or load a ferret
> database in an other format to prevent index rebuilding (due to changes
> in the format) or to simplify backup/replication tasks.
>
> I re-paste this patch (it was against the 0.10.14) here :
>   http://pastie.caboo.se/43603
>
> Do you think it''s intresting for ferret ?
Yes, I remember this patch. The problem I have with it is that it will
only back up stored fields, so it won''t work if you have unstored
fields. This might confuse people. As far as index rebuilding goes
when the format changes, this shouldn''t happen in future. I actually
store a version number in the segments files so in future I will make
Ferret automatically update the index when it is updated. I could have
done it this time except that it would have been more work than I was
willing to do given that I''d already created a 5000 line patch just to
implement lockless commits.  Given that Ferret was still in beta I
decided not to bother. It also would have added a lot of complexity
that I didn''t think was necessary. Once Ferret hits 1.0 however I will
make sure it remains backwards compatible.
As for backing up and replication, you can actually do this by copying
the whole index. You can either copy the index directly if it isn''t
being written to, or alternatively you can open it in another process
and add it to a new index. Something like;
    backup_writer = IndexWriter.new(:path =>
''path/to/backup_index'')
    reader = IndexReader.new(''path/to/index'')
    backup_writer.add_readers([reader])
    reader.close
    backup_writer.close
> Do you have any plan for this patch ?
If you still think this is useful and you are willing to submit some
unit tests with it I would be happy to commit it.
> PS: Thanks a lot for the 0.11.2
Your welcome,
Dave
-- 
Dave Balmain
http://www.davebalmain.com/