1. 28 6月, 2012 1 次提交
  2. 21 6月, 2012 1 次提交
  3. 19 6月, 2012 2 次提交
  4. 16 6月, 2012 1 次提交
  5. 14 6月, 2012 1 次提交
  6. 02 6月, 2012 1 次提交
  7. 31 5月, 2012 1 次提交
  8. 30 5月, 2012 1 次提交
  9. 23 5月, 2012 1 次提交
  10. 19 5月, 2012 1 次提交
  11. 17 5月, 2012 1 次提交
  12. 16 5月, 2012 1 次提交
    • A
      SSE4 optimization · 95af1282
      Arun Sharma 提交于
      Summary:
      This speeds up CRC computation significantly on
      hardware that supports it. Enabled via -msse4.
      
      Note: the binary won't be usable on older CPUs
      that don't support the instruction.
      
      Test Plan: crc32c_test
      
      Reviewers: dhruba
      
      Reviewed By: dhruba
      
      Differential Revision: https://reviews.facebook.net/D3201
      95af1282
  13. 15 5月, 2012 2 次提交
  14. 12 5月, 2012 2 次提交
  15. 10 5月, 2012 1 次提交
  16. 17 4月, 2012 1 次提交
    • S
      Added bloom filter support. · 85584d49
      Sanjay Ghemawat 提交于
      In particular, we add a new FilterPolicy class.  An instance
      of this class can be supplied in Options when opening a
      database.  If supplied, the instance is used to generate
      summaries of keys (e.g., a bloom filter) which are placed in
      sstables.  These summaries are consulted by DB::Get() so we
      can avoid reading sstable blocks that are guaranteed to not
      contain the key we are looking for.
      
      This change provides one implementation of FilterPolicy
      based on bloom filters.
      
      Other changes:
      - Updated version number to 1.4.
      - Some build tweaks.
      - C binding for CompactRange.
      - A few more benchmarks: deleteseq, deleterandom, readmissing, seekrandom.
      - Minor .gitignore update.
      85584d49
  17. 31 3月, 2012 1 次提交
  18. 22 3月, 2012 1 次提交
    • S
      Build fixes and cleanups: · a1ad4d19
      Sanjay Ghemawat 提交于
      (1) Separate out C++ and CC flags (fixes c_test compilation)
      (2) Move snappy/perftools detection to script
      (3) Fix db_bench_sqlite3 and db_bench_tree_db build rules
      a1ad4d19
  19. 16 3月, 2012 1 次提交
  20. 09 3月, 2012 2 次提交
  21. 06 3月, 2012 1 次提交
  22. 03 2月, 2012 1 次提交
  23. 26 1月, 2012 1 次提交
  24. 30 11月, 2011 1 次提交
  25. 15 11月, 2011 1 次提交
  26. 01 11月, 2011 1 次提交
    • H
      A number of fixes: · 36a5f8ed
      Hans Wennborg 提交于
      - Replace raw slice comparison with a call to user comparator.
        Added test for custom comparators.
      
      - Fix end of namespace comments.
      
      - Fixed bug in picking inputs for a level-0 compaction.
      
        When finding overlapping files, the covered range may expand
        as files are added to the input set.  We now correctly expand
        the range when this happens instead of continuing to use the
        old range.  For example, suppose L0 contains files with the
        following ranges:
      
            F1: a .. d
            F2:    c .. g
            F3:       f .. j
      
        and the initial compaction target is F3.  We used to search
        for range f..j which yielded {F2,F3}.  However we now expand
        the range as soon as another file is added.  In this case,
        when F2 is added, we expand the range to c..j and restart the
        search.  That picks up file F1 as well.
      
        This change fixes a bug related to deleted keys showing up
        incorrectly after a compaction as described in Issue 44.
      
      (Sync with upstream @25072954)
      36a5f8ed
  27. 06 10月, 2011 1 次提交
    • G
      A number of bugfixes: · 299ccedf
      Gabor Cselle 提交于
      - Added DB::CompactRange() method.
      
        Changed manual compaction code so it breaks up compactions of
        big ranges into smaller compactions.
      
        Changed the code that pushes the output of memtable compactions
        to higher levels to obey the grandparent constraint: i.e., we
        must never have a single file in level L that overlaps too
        much data in level L+1 (to avoid very expensive L-1 compactions).
      
        Added code to pretty-print internal keys.
      
      - Fixed bug where we would not detect overlap with files in
        level-0 because we were incorrectly using binary search
        on an array of files with overlapping ranges.
      
        Added "leveldb.sstables" property that can be used to dump
        all of the sstables and ranges that make up the db state.
      
      - Removing post_write_snapshot support.  Email to leveldb mailing
        list brought up no users, just confusion from one person about
        what it meant.
      
      - Fixing static_cast char to unsigned on BIG_ENDIAN platforms.
      
        Fixes	Issue 35 and Issue 36.
      
      - Comment clarification to address leveldb Issue 37.
      
      - Change license in posix_logger.h to match other files.
      
      - A build problem where uint32 was used instead of uint32_t.
      
      Sync with upstream @24408625
      299ccedf
  28. 27 9月, 2011 1 次提交
  29. 12 9月, 2011 1 次提交
    • H
      Sync with upstream @23860137. · 213a68eb
      Hans Wennborg 提交于
      Fix GCC -Wshadow warnings in LevelDB's public header files,
      reported by Dustin.
      
      Add in-memory Env implementation (helpers/memenv/*).
      This enables users to create LevelDB databases in-memory.
      
      Initialize ShardedLRUCache::last_id_ to zero.
      This fixes a Valgrind warning.
      
      (Also delete port/sha1_* which were removed upstream some time ago.)
      213a68eb
  30. 02 9月, 2011 1 次提交
    • G
      Bugfixes: for Get(), don't hold mutex while writing log. · 72630236
      gabor@google.com 提交于
      - Fix bug in Get: when it triggers a compaction, it could sometimes
        mark the compaction with the wrong level (if there was a gap
        in the set of levels examined for the Get).
      
      - Do not hold mutex while writing to the log file or to the
        MANIFEST file.
      
        Added a new benchmark that runs a writer thread concurrently with
        reader threads.
      
        Percentiles
        ------------------------------
        micros/op: avg  median 99   99.9  99.99  99.999 max
        ------------------------------------------------------
        before:    42   38     110  225   32000  42000  48000
        after:     24   20     55   65    130    1100   7000
      
      - Fixed race in optimized Get.  It should have been using the
        pinned memtables, not the current memtables.
      
      
      
      git-svn-id: https://leveldb.googlecode.com/svn/trunk@50 62dab493-f737-651d-591e-8d6aee1b9529
      72630236
  31. 23 8月, 2011 1 次提交
    • G
      Bugfix for issue 33; reduce lock contention in Get(), parallel benchmarks. · e3584f9c
      gabor@google.com 提交于
      - Fix for issue 33 (non-null-terminated result from
        leveldb_property_value())
      
      - Support for running multiple instances of a benchmark in parallel.
      
      - Reduce lock contention on Get():
        (1) Do not hold the lock while searching memtables.
        (2) Shard block and table caches 16-ways.
      
        Benchmark for evaluating this change:
        $ db_bench --benchmarks=fillseq1,readrandom --threads=$n
        (fillseq1 is a small hack to make sure fillseq runs once regardless
        of number of threads specified on the command line).
      
      
      
      git-svn-id: https://leveldb.googlecode.com/svn/trunk@49 62dab493-f737-651d-591e-8d6aee1b9529
      e3584f9c
  32. 16 8月, 2011 1 次提交
    • G
      Bugfixes for iterator and documentation. · ab323f7e
      gabor@google.com 提交于
      - Fix bug in Iterator::Prev where it would return the wrong key.
        Fixes issues 29 and 30.
      
      - Added a tweak to testharness to allow running just some tests.
      
      - Fixing two minor documentation errors based on issues 28 and 25.
      
      - Cleanup; fix namespaces of export-to-C code.
        Also fix one "const char*" vs "char*" mismatch.
      
      
      
      git-svn-id: https://leveldb.googlecode.com/svn/trunk@48 62dab493-f737-651d-591e-8d6aee1b9529
      ab323f7e
  33. 06 8月, 2011 2 次提交
  34. 30 7月, 2011 1 次提交
    • G
      Improved benchmark, fixed bugs and SQLite parameters. · 1bfbe76b
      gabor@google.com 提交于
      - Based on suggestions on the sqlite-users mailing list,
        we removed the superfluous index on the primary key 
        for SQLite's benchmarks, and turned write-ahead logging 
        ("WAL") on. This led to performance improvements for SQLite.
      
      - Based on a suggestion by Florian Weimer on the leveldb
        mailing list, we disabled hard drive write-caching via
        hdparm when testing synchronous writes. This led to
        performance losses for LevelDB and Kyoto TreeDB.
      
      - Fixed a mistake in 2.A.->Random where the bar sizes
        were switched for Kyoto TreeDB and SQLite.
      
      
      
      git-svn-id: https://leveldb.googlecode.com/svn/trunk@45 62dab493-f737-651d-591e-8d6aee1b9529
      1bfbe76b
  35. 27 7月, 2011 1 次提交