Skip to content
Snippets Groups Projects
  1. Nov 06, 2017
  2. Nov 04, 2017
  3. Nov 03, 2017
    • Vladimir Davydov's avatar
      vinyl: cleanup global statistics · 64a4b538
      Vladimir Davydov authored
       - Remove vy_stat::rmean statistics, which were left from Sophia, as now
         we have per index statistics which are much more verbose than those.
      
       - Move vy_stat::dump_bw to vy_env and remove struct vy_stat as there's
         nothing left in it.
      
       - Move quota statistics from box.info.vinyl().performance.memory to
         box.info.vinyl().quota. Remove 'ratio', which equals used / limit, as
         this kind of calculations should be done by a script aggregating
         statistics. Report 'use_rate' and 'dump_bandwidth' there.
      
       - Report 'limit' in cache statistics to make them consistent with
         'quota' statistics, where 'limit' is reported. Rename 'cache.count'
         to 'cache.tuples'. Remove vy_cache_env::cache_count, use mempool
         stats instead.
      
       - Move 'tx_allocated', 'txv_allocated', 'read_interval', 'read_view'
         from box.info.vinyl().performance to box.info.vinyl().tx and name
         them 'transactions', 'statements', 'gap_locks', and 'read_views',
         respectively. Remove vy_tx_stat::active and 'tx.active' as the same
         value is shown by 'tx.transactions', extracted from the mempool.
      
       - Zap box.info.vinyl().performance - there's nothing left there.
      
      Now global statistics look like:
      
        tarantool> box.info.vinyl()
        ---
        - cache:
            limit: 134217728
            tuples: 32344
            used: 34898794
          tx:
            conflict: 1
            commit: 324
            rollback: 13
            statements: 10
            transactions: 3
            gap_locks: 4
            read_views: 1
          quota:
            dump_bandwidth: 10000000
            watermark: 119488351
            use_rate: 1232703
            limit: 134217728
            used: 34014634
        ...
      
      Closes #2861
      64a4b538
    • Roman Tsisyk's avatar
      box: add box.NULL alias for msgpack.NULL · 043ba278
      Roman Tsisyk authored
      Follow up #1557
      043ba278
  4. Nov 02, 2017
    • Alexandr Lyapunov's avatar
      Reject attempts to create non-string index part with collation · 4c10b711
      Alexandr Lyapunov authored
      Collation was simply ignored for non-string parts, that could
      confuse potential user.
      
      Generate a readable error in this case.
      
      Fix #2862 part 2
      4c10b711
    • Alexandr Lyapunov's avatar
      Make collation work with scalar fields · 2601fcd3
      Alexandr Lyapunov authored
      Now collation is silently ignored for type='scalar' parts.
      
      Use collation for string scalar fields.
      
      Fix #2862 part 1
      2601fcd3
    • Alexandr Lyapunov's avatar
      Show collation in lua index object · 76b6e110
      Alexandr Lyapunov authored
      Show collation name (if present) in space.index.name.parts[no].
      
      Fix #2862 part 4
      76b6e110
    • Alexandr Lyapunov's avatar
      Make collation by name lookup case insensitive · 3f9a73a7
      Alexandr Lyapunov authored
      test:create_index('unicode_s1', {parts = {{1, 'STR', collation =
      'UNICODE'}}}) will work now.
      
      Fix #2862 part 3
      3f9a73a7
    • Vladislav Shpilevoy's avatar
      schema: allow to store smaller field count that specified in format · 2f53308e
      Vladislav Shpilevoy authored
      If a field is not indexed and no more indexed or not nullable
      fields after that, than allow to skip it in insertion. Such field
      value looks like MP_NIL, but MP_NIL is not explicitly stored.
      Named access to this field in lua returns nil.
      
      Example:
      format =
      {{'field1'},
       {'field2'},
       {'field3', is_nullable = true},
       {'field4', is_nullable = true}}
      
      t = space:insert{1, 2} -- ok.
      
      t.field1 == 1, t.field2 == 2, t.field3 == nil, t.field4 == nil
      
      Closes #2880
      2f53308e
    • Vladislav Shpilevoy's avatar
      schema: allow to store custom fields in format's field definition · f688ef36
      Vladislav Shpilevoy authored
      Some users store in format fields their custom keys. But current
      opts parser does not allow to store any unknown keys. Lets allow it.
      
      Example:
      format = {}
      format[1] = {name = 'field1', type = 'unsigned', custom_field = 'custom_value'}
      s = box.schema.create_space('test', {format = format})
      s:format()[1].custom_field == 'custom_value'
      
      Closes #2839
      f688ef36
    • Vladimir Davydov's avatar
      vinyl: forbid DDL/DML if wal is disabled · b75ab0e0
      Vladimir Davydov authored
      Using DML/DDL on a Vinyl index with wal_mode = 'none' is likely to
      result in unrecoverable errors like:
      
        F> can't initialize storage: Invalid VYLOG file: Index 512/0 created twice
      
      To avoid data corruption in case the user tries to use an existing Vinyl
      database in conjunction with wal_mode = 'none', let's explicitly forbid
      it until we figure out how to fix it.
      
      Workaround #2278
      b75ab0e0
    • Vladimir Davydov's avatar
      vinyl: ignore quota timeout during bootstrap from master · 19ac10c9
      Vladimir Davydov authored
      During initial join, a replica receives all data accumulated on the
      master for its whole lifetime, which may be quota a lot. If the network
      connection is fast enough, the replica might fail to keep up with dumps,
      in which case replication fails with ER_VY_QUOTA_TIMEOUT. To avoid that,
      let's ignore quota timeout until bootstrap is complete.
      
      Note, replication may still fail during the 'subscribe' stage for the
      same reason, but it's unlikely, because the rate at which the master
      sends data is limited by the number of requests served by the master per
      a unit of time, and it should become nearly impossible once throttling
      is introduced (See #1862).
      
      Closes #2873
      19ac10c9
    • Vladimir Davydov's avatar
      vinyl: abort bootstrap if vinyl directory is not empty · 4d796a8c
      Vladimir Davydov authored
      If the user sets snap_dir to an empty directory by mistake while leaving
      vinyl_dir the same, tarantool will still bootstrap, but there is likely
      to be errors like:
      
        vinyl.c:835 E> 512/0: dump failed: file './512/0/00000000000000000001.run' already exists
        vy_log.c:1095 E> failed to rotate metadata log: file './00000000000000000005.vylog' already exists
      
      Even worse, it may eventually fail to restart with:
      
        vy_log.c:886 E> ER_MISSING_SNAPSHOT: Can't find snapshot
      
      To avoid that, let's check the vinyl_dir on bootstrap and abort if it
      contains vylog files left from previous setups.
      
      Closes #2872
      4d796a8c
  5. Nov 01, 2017
  6. Oct 31, 2017
  7. Oct 27, 2017
  8. Oct 26, 2017
  9. Oct 25, 2017
  10. Oct 24, 2017
  11. Oct 19, 2017
    • Vladimir Davydov's avatar
      Fix compilation on Mac OS · 39276fe1
      Vladimir Davydov authored
      > src/box/txn.c:454:40: error: '_Alignof' applied to an expression is a GNU extension [-Werror,-Wgnu-alignof-expression]
      >                 diag_set(OutOfMemory, sizeof(*svp) + alignof(*svp) - 1,
      >                                                      ^
      
      Do not try to be smart and guess allocation size using alignof.
      
      > src/box/memtx_tree.c:391:11: error: comparison of unsigned enum expression < 0 is always false [-Werror,-Wtautological-compare]
      >         if (type < 0 || type > ITER_GT) { /* Unsupported type */
      >             ~~~~ ^ ~
      
      > src/box/vinyl_index.c:184:29: error: comparison of unsigned enum expression < 0 is always false [-Werror,-Wtautological-compare]
      >         if (type > ITER_GT || type < 0) {
      >                               ~~~~ ^ ~
      
      Move the check for illegal params (i.e. 'type < 0') to the box API.
      In index callbacks, only check that the iterator type is supported
      by the index.
      39276fe1
    • Vladimir Davydov's avatar
      index: implement generic versions of min(), max(), and count() · 4e3bb53e
      Vladimir Davydov authored
      The primary reason for these methods to be implemented differently
      for memtx and vinyl was the 'position' optimization exploited by
      the memtx engine: since selects from memtx do not yield, we could
      use a preallocated iterator there.
      
      Now, as the 'position' optimization became redundant and was
      removed due to the switch to memory pools for iterator allocations,
      the only idiosyncrasy left in the memtx implementation is the count()
      optimization: count() falls back on size() for ITER_ALL. Since this
      optimization consists of just a few lines of code, we don't really
      need memtx_index_count() co-used by all memtx index implementations:
      we can implement it in each memtx index separately.
      
      That being said, let us:
       - implement generic versions of min(), max(), and count();
       - make vinyl, memtx, and sysview engines use generic versions of
         the above-mentioned methods if appropriate;
       - Remove memtx_index.[hc]
      
      As a side-effect, this patch enables min(), max(), and count() in
      the sysview engine, but that is not bad considering that this engine
      implements general-purpose iterator for its indexes.
      4e3bb53e
  12. Oct 18, 2017
  13. Oct 15, 2017
  14. Oct 14, 2017
Loading