Browse Source

move ua to n2o.dev

Namdak Tonpa 5 years ago
parent
commit
81f850e75b
8 changed files with 0 additions and 696 deletions
  1. 0 108
      man/ua/index.html
  2. 0 128
      man/ua/kvs.htm
  3. 0 211
      man/ua/kvs_annnounce.htm
  4. 0 25
      man/ua/kvs_fs.htm
  5. 0 27
      man/ua/kvs_mnesia.htm
  6. 0 29
      man/ua/kvs_rocks.htm
  7. 0 28
      man/ua/kvs_st.htm
  8. 0 140
      man/ua/kvs_stream.htm

+ 0 - 108
man/ua/index.html

@@ -1,108 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>KVS</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="#" style="background:#ededed;">KVS</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../../index.html">EN</a>
-</nav><header>
-    <a href="https://github.com/synrc/kvs"><img src="https://synrc.space/images/Synrc Neo.svg?v=1" /></a>
-    <h1>KVS</h1>
-</header><aside>
-    <article>
-        <section>
-            <h3>СИНОПИС</h3>
-            <p>KVS — це узагальнюючий інтерфейс над KV сховищами,
-               як зі спільним простором ключів так і з табличною моделлю
-               внутрішньої організації. Основна ідея — трактувати дані
-               не з точки зору таблиць, а з точки зору ланцюжків (послідовностей).
-               Також передбачена можливість зміни бекендів.</p>
-            <br />
-            <p>Застосовується, зокрема в банківському секторі, для систем повідомлень, простих блокчейнів, систем обробки та зберігання даних.
-               BPE та BANK додатки використовують KVS.</p>
-            <br />
-            <ul><li>Бекенди: MNESIA, FS, ROCKS</li><li>Надзвичайно компактний та перевірений код: 500 LOC</li></ul>
-            <br /><br />
-        </section>
-        <section>
-            <h3>МОДУЛІ</h3>
-            <div><ul><li><a href="kvs.htm">KVS</a></li>
-                 <li><a href="kvs_stream.htm">STREAM</a></li>
-                 <li><a href="kvs_fs.htm">FS</a></li>
-                 <li><a href="kvs_mnesia.htm">MNESIA</a></li>
-                 <li><a href="kvs_rocks.htm">ROCKS</a></li>
-                 <li><a href="kvs_st.htm">ST</a></li></ul></div>
-            <br />
-            <h3>СТАТТІ</h3>
-            <div><ul><li><a href="kvs_annnounce.htm">АНОНС 6.4</a></li></ul></div><br/>
-            <div>
-                APR 2019 © <a href="https://github.com/5HT">5HT</a> ISC<br />
-                VER 6.6 6.5 6.4
-            </div>
-        </section>
-        <section>
-        <figure>
-        <code>
- $ mad get kvs &#38;&#38; cd kvs
- $ mad com pla rep
- > kvs:join().
-        </code>
-        </figure>
-        </section>
-    </article>
-</aside><main>
-    <section>
-
-<h3>ПРИКЛАД ВИКОРИСТАННЯ</h3>
-
-<figure><code>
- > kvs:join().
- ok
-
- > kvs:check().
- ok
-
- > kvs:all(reader).
- [{reader,1555175169121817000,0,[],[],
-          {list,1555175169120161000},
-          0},
-  {reader,1555175169121249000,0,[],[],
-          {list,1555175169120161000},
-          0}]
-
- > rr(kvs).
- [emails,id_seq,iter,kvs,reader,schema,table,writer]
-
- > kvs:save(kvs:reader({list,1555175169120161000})).
- #reader{id = 1555175244188986000,pos = 0,
-         cache = {emails,1555175169122304000},
-         args = [],
-         feed = {list,1555175169120161000},
-         dir = 0}
-
- > kvs:take(kvs:bot((kvs:load_reader(1555175244188986000))#reader{args=-1})).
- #reader{id = 1555175244188986000,pos = 5,
-         cache = {emails,1555175169127279000},
-         args = [#emails{id = 1555175169127279000,next = [],
-                         prev = 1555175169126314000,email = []},
-                 #emails{id = 1555175169126314000,next = 1555175169127279000,
-                         prev = 1555175169125227000,email = []},
-                 #emails{id = 1555175169125227000,next = 1555175169126314000,
-                         prev = 1555175169123405000,email = []},
-                 #emails{id = 1555175169123405000,next = 1555175169125227000,
-                         prev = 1555175169122304000,email = []},
-                 #emails{id = 1555175169122304000,next = 1555175169123405000,
-                         prev = [],email = []}],
-         feed = {list,1555175169120161000},
-         dir = 0}
-
-</code></figure>
-    </section>
-
-    <section>
-        <a name="plugin"></a><h3>CONTRIBUTORS</h3>
-        <div>
-        <ul><li><a href="https://github.com/5HT">5HT</a> — Namdak Tonpa</li><li><a href="https://github.com/proger">proger</a> — Vlad Ki</li><li><a href="https://github.com/doxtop">doxtop</a> — Andrii Zadorozhnii</li><li><a href="https://github.com/cryoflamer">cryoflamer</a> — Yuri Maslovsky</li><li><a href="https://github.com/qomputer">qomputer</a> — Igor Kharin</li></ul></div>
-        <br /><br />
-    </section>
-</main><footer>
-    Made with <span class="heart">❤</span> to N2O
-</footer></body></html>

+ 0 - 128
man/ua/kvs.htm

@@ -1,128 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>KVS</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">KVS</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../kvs.htm">EN</a>
-</nav><header>
-    <a href="index.html"><img src="https://n2o.space/img/Synrc Neo.svg" /></a>
-    <h1>KVS</h1>
-</header><main>
-    <section>
-
-<h3>ВСТУП</h3>
-
-   <p>Модуль KVS надає інтерфейс користувача для команд консолі.
-      Він має функції відкриття, маніпулювання даними та відновлення даних.
-      Під капотом він обробляє налаштовувані під час виконання бекенди для кожної підтримуваної бази даних.</p>
-
-        <p></p><blockquote><p></p><ul><li><b><a href="#dir">dir/0</a></b> — повертає перелік таблиць.</li><li><b><a href="#ver">ver/0</a></b> — повертає версію KVS.</li><li><b><a href="#seq">seq/2</a></b> — генерує новий ідентифікатор послідовностей таблиці.</li><li><b><a href="#count">count/1</a></b> — повертає кількість записів в таблиці.</li><li><b><a href="#put">put/1</a></b> — зберігає запис, використовуючи id як ключ.</li><li><b><a href="#get">get/2</a></b> — повертає запис по його ключу.</li><li><b><a href="#delete">delete/1</a></b> — видаляє запис з таблиці.</li><li><b><a href="#index">index/3</a></b> — виконує пошук записів по назві поля та його значенню.</li></ul></blockquote>
-
- <p>Ви можете поміняти бекенд, використовуючи змінні оточення env в налаштуваннях додатку.
-    Це добре працює навіть під великим навантаженням.</p>
-
-    </section>
-    <section>
-
-<h3>ВСТАНОВЛЕННЯ</h3>
-
-<p>В sys.config ви вказуєте kvs бекенд та список модулів, які містять експорт
-   функції <b>metainfo/0</b>.</p>
-
-<figure><code>
-  [{kvs, [{dba,store_mnesia},
-          {schema,[kvs,kvs_stream]}]}].
-
-</code></figure>
-
-<h4>dir() -> list({'table',atom()}).</h4>
-
-<p>Повертає актуальні таблиці.</p>
-
-<h4>ver() -> {'version',string()}.</h4>
-
-<p>Повертає версію бекенда.</p>
-
-<h4>dump() -> ok.</h4>
-
-<p>Повертає інформацію про базу даних.</p>
-
-<figure><code>
- > kvs:dump().
-                NAME                     STORAGE TYPE    MEMORY (MB)   ELEMENTS
-
-              id_seq                      disc_copies           0.00          0
-              writer                      disc_copies           0.00          0
-              emails                      disc_copies           0.00          0
-              reader                      disc_copies           0.00          0
-
- Snapshot taken: {{2018,11,10},{5,2,38}}
- ok
-
-</code></figure>
-
-
-    </section>
-    <section>
-
-<h3>SEQ</h3>
-
-<p>Таблиця послідовностей id_seq зберігає лічильники для записів.
-   Лічильники є глобальними та атомарними для кожної підтримуваної бази даних.
-   Послідовності використовуються для генерації унікальних імен записам в розподіленій таблиці.
-   Якщо імена в таблиці не є унікальними,
-   то функція count може повернути значення, що відрізняється від поточної послідовності.
-   </p>
-
-<figure><code>
-  -record(id_seq, { thing = atom(),
-                    id    = 0 :: integer() } ).
-
-</code></figure>
-
-<h4>seq(atom(), integer()) -> integer().</h4>
-
-<p>Збільшує на 1 та повертає id лічильника для конкретної таблиці.</p>
-
-<h4>count(atom()) -> integer().</h4>
-
-<p>Повертає кількість записів в таблиці.</p>
-
-    </section>
-    <section>
-
-<h3>BACKEND</h3>
-
-<p>Функції операцій з даними.
-   </p>
-
-<h4>put(tuple()) -> ok | {error,any()}.</h4>
-
-<p>Зберігає запис.</p>
-
-<h4>get(atom(),any()) -> {ok,any()} | {error, not_found | duplicated }.</h4>
-
-<p>Виконує пошук запису.</p>
-
-<h4>delete(atom(),any()) -> ok | {error,any()}.</h4>
-
-<p>Видаляє запис.</p>
-
-<h4>index(atom(),any(),any()) -> list(tuple()).</h4>
-
-<p>Виконує пошук запису за індексованим полем та заданим значенням.</p>
-
-    </section>
-    <section>
-
-<p>Цей модуль може бути пов'язаним з:
-<a href="kvs_fs.htm"><b>kvs_fs</b></a>,
-<a href="kvs_mnesia.htm"><b>kvs_mnesia</b></a>,
-<a href="kvs_rocks.htm"><b>kvs_rocks</b></a>,
-<a href="kvs_st.htm"><b>kvs_st</b></a>,
-<a href="kvs_stream.htm"><b>kvs_stream</b></a>.
-</p>
-    </section>
-</main><footer>
-    2005—2019 © Synrc Research Center
-</footer></body></html>

+ 0 - 211
man/ua/kvs_annnounce.htm

@@ -1,211 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>Нова версія KVS</title><link rel="stylesheet" href="https://forms.n2o.space/priv/static/css/forms.css?v=1" /><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">АНОНС</a>
-    
-</nav><main>
-    <section>
-        <h3>Нова версія KVS 6.4</h3>
-        <p>KVS — слой абстракції, який складається з двох частин: базового API та API керування стрімами,
-           тейк, дроп, фолд, катаморфізм, як ви любите. Головний API в модулі kvs,
-           а стрімовий — в kvs_stream. Користуючись нагодою, хочу пропіарити схожі рішення
-           в області зберігання даних на erlang: <a href="https://github.com/fogfish/datum">datum</a> та серія бібліотек
-           від Дмитра Колесникова, <a href="https://github.com/emqx/replayq">replayq</a> від Фенга Лі,
-           а також небагатьох інших, хто намагався абстрактно вирішити проблему.</p>
-
-         <h3>Чому KVS?</h3>
-
-         <p>Призначення KVS:</p>
-         <p>— надання інтерфейсу абстрагування широкого спектра сховищ;<br />
-            — надання зручного Erlang REPL інтерфейсу для роботи з записами (records);<br />
-            — розділення на базовий (get put) інтерфейс, та стрім інтерфейс ітераторів (next prev);<br />
-            — набір драйверів (внутрішня база, зовнішня база і файлова система);<br />
-            — шари даних: файлова система, ланцюжки повідомлень, банківські транзакції, дерева
-              підписів, трейси бізнес-процесів, блокчейни, системи черг,
-              тайм серіес, ось це все.<br />
-        </p>
-         <p>Розпочинаючи з незначної модифікації KVS поміняла назву, тепер це "Абстрактна База Ланцюжків",
-            а не "Абстрактна База Термів", оскільки відділився окремий стрім API.</p>
-
-         <p>— <a href="https://github.com/synrc/kvs">synrc/kvs</a> — 6.4<br /></p>
-
-        <p> Розповімо трохи про теоретичні основи KVS. Ця бібліотека дозволяє або повинна
-            дозволяти зберігати та діставати структури будь-якого виду, надаючи семантику управління
-            курсорами next prev, якою володіють дерева. Тому можна сказати, що це інтерфейс
-            оператора до деревоподібних сховищ та сховищ ланцюжків. У своїй основі KVS підтримує три
-            механізми зберігання ланцюжків:</p>
-         <p>1) перший, очевидний — двонаправлені списки, де вказівники next та prev
-               безпосереднім чином присутні в даних. Спосіб підходить
-               навіть для керування деревами;</p>
-         <p>2) другий, очевидний — однонаправлені списки, де наявний тільки вказівник next. Цей спосіб підходить для списків.
-               Багато людей запитують про цей спосіб, але ми його ніколи не використовували,
-               тому немає імплементації;</p>
-         <p>3) третій, неочевидний спосіб — пряме вбудовувавання записів в BTree index,
-               zero-overhead.</p>
-
-         <p>В якомусь сенсі перший та другий способи реалізують певний шар поверх KVS,
-            оскільки kvs_stream працює з будь-якими стораджами поліморфно, а ось kvs_st драйвер
-            стрімів зроблений спеціально для rocksdb.</p>
-
-        <h3>Дерева</h3>
-
-        <p>Двонаправлені списки або дерева, перша модель, яка лягає прямо з С++ класів, при вивченні програмування —
-           це зберігати в базі прямі вказівники, така система зберігання може використовуватися навіть,
-           якщо integer поміняти на pid, тоді можна буде точково відновлювати історію виклику.</p>
-
-        <figure>
-        <code>
-  -record(iter, { id    = [] :: [] | integer(),
-                  next  = [] :: [] | integer(),
-                  prev  = [] :: [] | integer() } ).
-        </code>
-        </figure>
-
-        <p>Перше поле будь-якої таблиці — це її ім'я, друге — id, третє та
-            четверте — next і prev (сигнатура бінарного розгалуження).
-           Поліморфно за цими зміщеннями ми очікуємо наявність цих полів
-           для лінковки даних в ланцюжки.
-           Базова частина разом називається #iter.</p>
-
-        <h4>kvs_stream — <b>#iter{}</b></h4>
-
-        <p> За поліморфое явне управління application level полями next prev рекорда #iter
-            відповідає модуль kvs_stream. Наприклад, файловая система не надає управління
-            своїми курсорами, тому імплементація fs вимагає наявності полів лінковки.</p>
-
-        <h3>Списки</h3>
-        <p>Однонаправлені списки, чи просто списки, це друга модель. Все таке ж, тільки без повернення назад.
-           Не підтримується пока жодною версією KVS.</p>
-        <figure>
-        <code>
-  -record(ite, { id    = [] :: [] | integer(),
-                 next  = [] :: [] | integer() } ).
-        </code>
-        </figure>
-
-        <h4>kvs_stre — <b>#ite{}</b></h4>
-
-        <p>Цей модуль не реалізовано, і запис не специфікований.</p>
-
-        <h3>Вбудовування в індекс</h3>
-
-        <p>Третя модель представляє собою прямий, більш ефективний спосіб вбудовування простору бізнес-об'єктів
-           в простір ключів розташованої нижче таблиці, і передача управління курсорами BTree таблиці
-           відразу в драйвер, а не в ручний link walking, як це було в riak.
-           Базова частина поліморфних записів складається тільки з імені таблиці
-           та id, і має назву #it. Ця модель використовується в rocksdb бекенді, який з'явився у 6.4.</p>
-
-        <figure>
-        <code>
-  -record(it, { id = [] :: [] | integer() } ).
-        </code>
-        </figure>
-
-        <p>Таким чином, ми можемо емулювати таблиці, в рамках єдиного простору ключів,
-           додаючи їх як префікси до ключа (little endian), який буде автоматично
-           відображатись в головному BTree дереві, також в цьому просторі ви можете
-           зберігати і фіди (стріми), наприклад, топіки: <b>/p2p/maxim/doxtop</b>.
-           Це вимагає спеціальної модифікації kvs_st для работи з записом #it,
-           на відміну від двонаправленого #iter, який працює з драйвером kvs_stream.</p>
-
-        <h4>kvs_st — <b>#it{}</b></h4>
-
-        <p>За керування курсорами по ітератору бази даних відповідає модуль kvs_st.</p>
-
-        <h3>На прикладі</h3>
-
-        <p>Код, який показує головну ідею, на прикладі драйвера rocksdb:</p>
-
-        <figure>
-        <code>
-1> {ok,Ref} = rocksdb:open("hey",[{create_if_missing,true}]).
-2> rocksdb:put(Ref, &lt;&lt;"/users/1">>,&lt;&lt;"maxim">>,[{sync,true}]).
-3> rocksdb:put(Ref, &lt;&lt;"/users/2">>,&lt;&lt;"doxtop">>,[{sync,true}]).
-4> rocksdb:put(Ref, &lt;&lt;"/users/3">>,&lt;&lt;"vlad">>,[{sync,true}]).
-5> rocksdb:put(Ref, &lt;&lt;"/staff/1">>,&lt;&lt;"vlad">>,[{sync,true}]).
-6> rocksdb:put(Ref, &lt;&lt;"/staff/2">>,&lt;&lt;"maxim">>,[{sync,true}]).
-7> rocksdb:put(Ref, &lt;&lt;"/staff/3">>,&lt;&lt;"doxtop">>,[{sync,true}]).
-8> {ok,I} = rocksdb:iterator(Ref,[]).
-9> rocksdb:iterator_move(I,{seek,&lt;&lt;"/staff/">>}).
-10> rocksdb:iterator_move(I,next).
-11> rocksdb:iterator_move(I,next).
-12> rocksdb:iterator_move(I,next).
-13> rocksdb:iterator_move(I,{seek,&lt;&lt;"/users/">>}).
-14> rocksdb:iterator_move(I,next).
-15> rocksdb:iterator_move(I,next).
-16> rocksdb:iterator_move(I,next).
-        </code>
-        </figure>
-
-      <h3>KVS REPL</h3>
-        <p>Тепер, щоб зробити те ж саме на KVS, ви можете зробити просто:</p>
-
-        <figure>
-        <code>
-1> kvs:ver().
-{version,"KVS ROCKSDB"}
-2> rr(kvs).
-[emails,id_seq,it,iter,kvs,reader,schema,table,writer]
-3> kvs:join().
-ok
-4> kvs:put(#emails{id=1,email="maxim"}).
-5> kvs:put(#emails{id=2,email="doxtop"}).
-6> kvs:put(#writer{id=2}).
-7> kvs:put(#writer{id=1}).
-8> kvs:all(writer).
-[#writer{id = 1,count = 0,cache = [],args = [],first = []},
- #writer{id = 2,count = 0,cache = [],args = [],first = []}]
-9> kvs:all(emails).
-[#emails{id = 1,next = [],prev = [],email = "maxim"},
- #emails{id = 2,next = [],prev = [],email = "doxtop"}]
-
-10> kvs:add(#writer{id=chain,args=#emails{email="maxim@synrc.com"}}).
-11> kvs:add(#writer{id=chain,args=#emails{email="vlad@synrc.com"}}).
-12> kvs:add(#writer{id=chain,args=#emails{email="doxtop@synrc.com"}}).
-13> kvs:all(chain).
-[#emails{id = 1555244691729330000,next = [],prev = [],
-         email = "maxim@synrc.com"},
- #emails{id = 1555244699905648000,next = [],prev = [],
-         email = "doxtop@synrc.com"},
- #emails{id = 1555244696660271000,next = [],prev = [],
-         email = "vlad@synrc.com"}]
-        </code>
-        </figure>
-
-        <p>Єдиний тест на стріми, який проходить:</p>
-
-        <figure>
-        <code>
-> kvs:check().
-ok
-        </code>
-        </figure>
-
-      <h3>Документація</h3>
-
-       <p>Надіюсь зробити цю рубрику в release notes офіційною та регулярною,
-          на жаль, якщо не брать до уваги man сторінки для модулій драйверів,
-          то залишається лише два модулі, для яких потрібна документація — це <a href="https://kvs.n2o.space/man/kvs.htm">kvs</a> та <a href="https://kvs.n2o.space/man/kvs_stream.htm">kvs_stream</a>.
-          Я, звичайно, формально додав сторінки для всіх модулів, і в майбутньому хочеться,
-          щоб штучний інтелект генерував документацію. Також я зрозумів, що
-          ченджлог та реліз замітки у власному блозі є чудовим способом авторського анонсування!
-          Зробив історію таких сторінок в README.md.</p>
-
-      <h3>На закінчення</h3>
-
-      <p>Репозиторій (що депендить <a href="https://gitlab.com/barrel-db/erlang-rocksdb">rocksdb NIF драйвер</a>, який повільно компілюється,
-         від Бенуа Кісенау, <a href="https://github.com/Vonmo/rocker">Rust-версію Rocker</a> від Максима Молчанова вирішив відкласти,
-         надто часто раст оновлюється, неможливо зафрізити)
-         одразу включає файл конфігурації для rocksdb:</p>
-
-         <p>— <a href="https://github.com/voxoz/kv">voxoz/kv</a></p>
-
-      <p>P.S. Вбудовування в BTree можна застосовувати не лише в таких базах, як rocksdb,
-         але й для mnesia, і для будь-яких баз взагалі.</p>
-
-      <p>P.P.S. Також можна використовувати rocksdb у якості драйвера для mnesia (написаний
-         Ульфом Вігером для проекта Аетерніті), або скоріше різновид таблиці rocksdb_copies —
-         <a href="https://github.com/aeternity/mnesia_rocksdb">mnesia_rocksdb</a>.</p>
-
-    </section>
-</main><footer>Namdak Tonpa <span class="heart">&#160;❤&#160;</span> 2009—2019</footer></body></html>

+ 0 - 25
man/ua/kvs_fs.htm

@@ -1,25 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>FS</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">FS</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../kvs_fs.htm">EN</a>
-</nav><header>
-    <a href="index.html"><img src="https://n2o.space/img/Synrc Neo.svg" /></a>
-    <h1>FS</h1>
-</header><main>
-   <section>
-   <h3>ВСТУП</h3>
-   <p>FS — це імплементація <b>filesystem</b> бекенду для KVS.
-      Помістіть властивість {dba,kvs_fs} для додатку kvs у ваш sys.config.</p>
-   <br />
-   </section>
-    <section>
-<p>Цей модуль може бути пов'язаним з:
-<a href="kvs.htm"><b>kvs</b></a>.
-</p>
-
-    </section>
-</main><footer>
-    2005—2019 © Synrc Research Center
-</footer></body></html>

+ 0 - 27
man/ua/kvs_mnesia.htm

@@ -1,27 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>MNESIA</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">MNESIA</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../kvs_mnesia.htm">EN</a>
-</nav><header>
-    <a href="index.html"><img src="https://n2o.space/img/Synrc Neo.svg" /></a>
-    <h1>MNESIA</h1>
-</header><main>
-   <article>
-   <section>
-   <h3>ВСТУП</h3>
-   <p>MNESIA — це реалізація бекенду <b>mnesia</b> для KVS.
-      Помістіть властивість {dba,kvs_mnesia} для додатку kvs у ваш sys.config.</p>
-   <br />
-   </section>
-    <section>
-<p>Цей модуль може бути пов'язаним з:
-<a href="kvs.htm"><b>kvs</b></a>.
-</p>
-
-    </section>
-   </article>
-</main><footer>
-    2005—2019 © Synrc Research Center
-</footer></body></html>

+ 0 - 29
man/ua/kvs_rocks.htm

@@ -1,29 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>ROCKS</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">ROCKS</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../kvs_rocks.htm">EN</a>
-</nav><header>
-    <a href="index.html"><img src="https://n2o.space/img/Synrc Neo.svg" /></a>
-    <h1>ROCKS</h1>
-</header><main>
-   <article>
-   <section>
-   <h3>ВСТУП</h3>
-   <p>ROCKS — це реалізація бекенду <b>RocksDB</b> для KVS.
-      Помістіть властивості {dba,kvs_rocks} та, опціонально, {dba_st,kvs_st} для додатку kvs у ваш sys.config.</p>
-   <br />
-   </section>
-    <section>
-<p>Цей модуль може бути пов'язаним з:
-<a href="kvs_st.htm"><b>kvs_st</b></a>,
-<a href="kvs_stream.htm"><b>kvs_stream</b></a>,
-<a href="kvs.htm"><b>kvs</b></a>.
-</p>
-
-    </section>
-   </article>
-</main><footer>
-    2005—2019 © Synrc Research Center
-</footer></body></html>

+ 0 - 28
man/ua/kvs_st.htm

@@ -1,28 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>ST</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">ST</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../kvs_st.htm">EN</a>
-</nav><header>
-    <a href="index.html"><img src="https://n2o.space/img/Synrc Neo.svg" /></a>
-    <h1>ST</h1>
-</header><main>
-    <section>
-
-<h3>ВСТУП</h3>
-
-<p>Модуль ST надає STREAM інтерфейс для бекенду ROCKS.
-   Щоб використовувати модуль ST для потокових операцій,
-   помістіть властивості {dba,kvs_rocks} та {dba_st,kvs_st} для додатку kvs у ваш sys.config.</p>
-    </section>
-    <section>
-<p>Цей модуль може бути пов'язаним з:
-<a href="kvs_stream.htm"><b>kvs_stream</b></a>,
-<a href="kvs_rocks.htm"><b>kvs_rocks</b></a>,
-<a href="kvs.htm"><b>kvs</b></a>.
-</p>
-    </section>
-</main><footer>
-    2005—2019 © Synrc Research Center
-</footer></body></html>

+ 0 - 140
man/ua/kvs_stream.htm

@@ -1,140 +0,0 @@
-<!DOCTYPE html><html><head><meta charset="utf-8" /><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="" /><meta name="author" content="Maxim Sokhatsky" /><title>STREAM</title><link rel="stylesheet" href="https://tonpa.guru/blank.css?v=2" /></head><body><nav>
-    <a href="https://n2o.dev/ua/">DEV</a>
-    <a href="index.html">KVS</a>
-    <a href="#" style="background:#ededed;">STREAM</a>
-    <a href="#" style="background:#ededed;">UA</a>
-    <a href="../kvs_stream.htm">EN</a>
-</nav><header>
-    <a href="index.html"><img src="https://n2o.space/img/Synrc Neo.svg" /></a>
-    <h1>STREAM</h1>
-</header><main>
-    <section>
-
-<h3>ВСТУП</h3>
-
-<p>Модуль STREAM пропонує інтерфейс фолдів, акумуляторів за персистентного зберігання ланцюжків даних.
-   </p>
-
-        <p></p><blockquote><p></p><ul><li><b><a href="#writer">writer/1</a></b> — створює та повертає курсор запису до бази даних.</li><li><b><a href="#reader">reader/1</a></b> — створює та повертає курсор зчитування до бази даних.</li><li><b><a href="#save">save/1</a></b> — зберігає курсор до бази даних.</li><li><b><a href="#load">load_reader/1</a></b> — підзавантажує збережений курсор зчитування.</li><li><b><a href="#load">load_writer/1</a></b> — підзавантажує збережений курсор запису.</li><li><b><a href="#top">top/1</a></b> — повертає початок (вершину) ланцюжка.</li><li><b><a href="#bot">bot/1</a></b> — повертає закінчення (основу) ланцюжка.</li><li><b><a href="#next">next/1</a></b> — переміщає курсор зчитування на наступний елемент.</li><li><b><a href="#prev">prev/1</a></b> — переміщає курсор зчитування на попередній елемент.</li><li><b><a href="#take">take/1</a></b> — повертає N елементів з курсору зчитування.</li><li><b><a href="#drop">drop/1</a></b> — пропускає N елементів з курсору зчитування.</li><li><b><a href="#add">add/1</a></b> — додає елемент до списку.</li><li><b><a href="#append">append/2</a></b> — додає елемент в канал.</li><li><b><a href="#append">cut/2</a></b> — очищає канал до заданої мітки timestamp.</li></ul></blockquote>
-
-    <p>
-      Ви може взяти <a style="margin-bottom:30px;" href="https://raw.githubusercontent.com/synrc/kvs/master/src/kvs_stream.erl">kvs_stream</a>
-      і використовувати у своїх додатках без імпортування залежності <b>synrc/kvs</b>,
-      оскільки даний модуль є самодостатнім.
-      Додатками можуть бути: публічні та приватні канали/стрічки новин, FIFO черги,
-   непрочитані повідомлення, чат, блокчейн etc.<br /><br />
-    </p></section>
-    <section>
-
-<h3>WRITER</h3>
-
-<p>Курсор запису передставляє собою додавання деяких кешованих значень до списку-ланцюжка.
-   Наприклад, розмір ланцюжка, перший елемент ланцюжка, кешоване значення
-   попереднього записаного повідомлення, та поле для передачі аргументів stream функціям, таким, як add.</p>
-
-<figure><code>
-  -record(writer, { id    = [] :: term(),
-                    count =  0 :: integer(),
-                    cache = [] :: [] | tuple(),
-                    args  = [] :: term(),
-                    first = [] :: [] | tuple() } ).
-
-</code></figure>
-
-<p>Щоб додати дані до бази даних, спочатку потрібно створити курсор запису,
-   встановити запис з мета-інформацією в поле аргументів, та викликати функцію save.</p>
-
-<h4>writer(term()) -> #writer{}.</h4>
-
-<p>Створює курсор запису.</p>
-
-<h4>add(#writer{}) -> #writer{}.</h4>
-
-<p>Додає елемент до списку, на який вказує курсор запису.</p>
-
-<h4>load_writer(#writer{}) -> #writer{}.</h4>
-
-<p>Підзавантажує курсор запису.</p>
-
-<h4>save(#writer{}) -> #writer{}.</h4>
-
-<p>Переміщує курсор запису до бази даних.</p>
-
-    </section>
-    <section>
-
-<h3>READER</h3>
-
-<figure><figcaption>Курсор зчитування</figcaption><code>
-  -record(reader, { id    = [] :: integer(),
-                    pos   =  0 :: [] | integer(),
-                    cache = [] :: [] | integer(),
-                    args  = [] :: term(),
-                    feed  = [] :: term(),
-                    dir   =  0 :: 0 | 1 } ).
-
-</code></figure>
-
-<h4>reader(integer()) -> #reader{}.</h4>
-
-<p>Створює курсор зчитування.</p>
-
-<h4>load_reader(#reader{}) -> #reader{}.</h4>
-
-<p>Підзавантажує курсор зчитування з бази даних.</p>
-
-<h4>save(#reader{}) -> #reader{}.</h4>
-
-<p>Переміщує курсор зчитування до бази даних.</p>
-
-<h4>top(#reader{}) -> #reader{}.</h4>
-
-<p>Переміщає курсор в початок (вершину) списку.</p>
-
-<h4>bot(#reader{}) -> #reader{}.</h4>
-
-<p>Переміщає курсор в закінчення (основу) списку.</p>
-
-    </section>
-    <section>
-
-<h3>ITER</h3>
-
-<figure><figcaption>KVS Stream Iterator</figcaption><code>
-  -record(iter,   { id    = [] :: [] | integer(),
-                    next  = [] :: [] | integer(),
-                    prev  = [] :: [] | integer() } ).
-
-</code></figure>
-
-<h4>next(#reader{}) -> #reader{}.</h4>
-
-<p>Переміщає курсор на наступний елемент. Споживає дані з вершини.
-   Повертає помилку, якщо список є пустим, в іншому випадку — наступний чи останній елемент.</p>
-
-<h4>prev(#reader{}) -> #reader{}.</h4>
-
-<p>Переміщає курсор на попередній елемент. Споживає дані з основи.
-   Повертає помилку, якщо список є пустим, в іншому випадку — наступний чи останній елемент.</p>
-
-<h4>drop(#reader{}) -> #reader{}.</h4>
-
-<p>Пропускає N елементів, розпочинаючи з курсора.</p>
-
-<h4>take(#reader{}) -> #reader{}.</h4>
-
-<p>Пробує споживати N записів зі stream, використовуючи його поточне значення та напрям.
-   Повертає споживані дані. Зазвичай ви шукаєте певну позицію, і далі споживаєте деякі дані.</p>
-
-    </section>
-    <section>
-
-<p>Цей модуль може бути пов'язаним з:
-<a href="kvs.htm"><b>kvs</b></a>,
-<a href="kvs_st.htm"><b>kvs_st</b></a>.
-</p>
-
-    </section>
-</main><footer>
-    2005—2019 © Synrc Research Center
-</footer></body></html>