.. -*- rst -*- .. highlightlang:: none Sharding ======== .. note:: This command is an experimental feature. .. versionadded:: 5.0.0 Groonga has :doc:`/limitations` against table size. You can't add 268,435,455 more records in one table. Groonga supports time based sharding to resolve the limitation. It works in the same database. It doesn't work with multiple databases. It means that this sharding feature isn't for distributing large data to multiple hosts. If you want distributed sharding feature, use `Mroonga `_ or `PGroonga `_. You can use sharding feature by MySQL or PostgreSQL. You'll be able to use `Droonga `_ for distributed sharding feature soon. Summary ------- Sharding is implemented in ``sharding`` plugin. The plugin is written in mruby. You need to enable mruby when you build Groonga. You can confirm whether your Groonga supports mruby or not by ``--version`` command line argument of :doc:`/reference/executables/groonga`:: % groonga --version groonga 5.0.5 [...,mruby,...] configure options: <...> If you find ``mruby``, your Groonga supports mruby. ``sharding`` plugin provides only search commands. They have ``logical_`` prefix in their command names such as :doc:`/reference/commands/logical_select` and :doc:`/reference/commands/logical_range_filter`. ``sharding`` plugin doesn't provide schema define commands and data load commands yet. You need to use existing commands such as :doc:`/reference/commands/table_create`, :doc:`/reference/commands/column_create` and :doc:`/reference/commands/load`. ``sharding`` plugin requires some rules against table and column. You need to follow these rules. They are described later. .. _sharding-glossary: Glossary -------- .. list-table:: :header-rows: 1 * - Name - Description * - Logical table - It's a table that consists of shards. It doesn't exist in Groonga database. It just exists in our minds. * - Logical table name - The name of logical table. It's prefix of shard names. For example, ``Logs`` is a logical table name and ``Logs_20150814`` and ``Logs_20150815`` are shard names. * - Shard - It's a table that has records in a day or month. One shard has only partial records. Shard name (= table name) must follow ``${LOGICAL_TABLE_NAME}_${YYYYMMDD}`` format or ``${LOGICAL_TABLE_NAME}_${YYYYMM}`` format. ``${LOGICAL_TABLE_NAME}`` is expanded to logical table name. ``${YYYYMMDD}`` is expanded to day. ``${YYYYMM}`` is expanded to month. For example, ``Logs_20150814`` is consists of ``Logs`` logical name and ``20150814`` day. .. _sharding-rules: Rules ----- TODO .. _sharding-commands: Commands -------- .. toctree:: :maxdepth: 1 :glob: commands/logical_*