diff options
Diffstat (limited to 'po/eo/LC_MESSAGES/_articles/2020-08-31-the-database-i-wish-i-had.po')
-rw-r--r-- | po/eo/LC_MESSAGES/_articles/2020-08-31-the-database-i-wish-i-had.po | 409 |
1 files changed, 0 insertions, 409 deletions
diff --git a/po/eo/LC_MESSAGES/_articles/2020-08-31-the-database-i-wish-i-had.po b/po/eo/LC_MESSAGES/_articles/2020-08-31-the-database-i-wish-i-had.po deleted file mode 100644 index 753c699..0000000 --- a/po/eo/LC_MESSAGES/_articles/2020-08-31-the-database-i-wish-i-had.po +++ /dev/null @@ -1,409 +0,0 @@ -# -msgid "" -msgstr "" - -msgid "" -"I watched the talk \"[Platform as a Reflection of Values: Joyent, Node.js " -"and beyond](https://vimeo.com/230142234)\" by Bryan Cantrill, and I think he" -" was able to put into words something I already felt for some time: if " -"there's no piece of software out there that reflects your values, it's time " -"for you to build that software[^talk-time]." -msgstr "" - -msgid "" -"[^talk-time]: At the very end, at time 29:49. When talking about the draft " -"of this article with a friend, he noted that Bryan O'Sullivan (a different " -"Bryan) says a similar thing on his talk \"[Running a startup on " -"Haskell](https://www.youtube.com/watch?v=ZR3Jirqk6W8)\", at time 4:15." -msgstr "" - -msgid "" -"I kind of agree with what he said, because this is already happening to me. " -"I long for a database with a certain set of values, and for a few years I " -"was just waiting for someone to finally write it. After watching his talk, " -"Bryan is saying to me: \"time to stop waiting, and start writing it " -"yourself\"." -msgstr "" - -msgid "" -"So let me try to give an overview of such database, and go over its values." -msgstr "" - -msgid "Overview" -msgstr "" - -msgid "" -"I want a database that allows me to create decentralized client-side " -"applications that can sync data." -msgstr "" - -msgid "The best one-line description I can give right now is:" -msgstr "" - -msgid "It's sort of like PouchDB, Git, Datomic, SQLite and Mentat." -msgstr "" - -msgid "A more descriptive version could be:" -msgstr "" - -msgid "An embedded, immutable, syncable relational database." -msgstr "" - -msgid "Let's go over what I mean by each of those aspects one by one." -msgstr "" - -msgid "Embedded" -msgstr "" - -msgid "" -"I think the server-side database landscape is diverse and mature enough for " -"my needs (even though I end up choosing SQLite most of the time), and what " -"I'm after is a database to be embedded on client-side applications itself, " -"be it desktop, browser, mobile, *etc.*" -msgstr "" - -msgid "" -"The purpose of such database is not to keep some local cache of data in case" -" of lost connectivity: we have good solutions for that already. It should " -"serve as the source of truth, and allow the application to work on top of " -"it." -msgstr "" - -msgid "" -"[**SQLite**](https://sqlite.org/index.html) is a great example of that: it " -"is a very powerful relational database that runs [almost " -"anywhere](https://sqlite.org/whentouse.html). What I miss from it that " -"SQLite doesn't provide is the ability to run it on the browser: even though " -"you could compile it to WebAssembly, ~~it assumes a POSIX filesystem that " -"would have to be emulated~~[^posix-sqlite]." -msgstr "" - -msgid "" -"[^posix-sqlite]: It was [pointed out to " -"me](https://news.ycombinator.com/item?id=24338881) that SQLite doesn't " -"assume the existence of a POSIX filesystem, as I wrongly stated. Thanks for " -"the correction." -msgstr "" - -msgid "" -"[**PouchDB**](https://pouchdb.com/) is another great example: it's a full " -"reimplementation of [CouchDB](https://couchdb.apache.org/) that targets " -"JavaScript environments, mainly the browser and Node.js. However I want a " -"tool that can be deployed anywhere, and not limit its applications to places" -" that already have a JavaScript runtime environment, or force the developer " -"to bundle a JavaScript runtime environment with their application. This is " -"true for GTK+ applications, command line programs, Android apps, *etc.*" -msgstr "" - -msgid "" -"[**Mentat**](https://github.com/mozilla/mentat) was an interesting project, " -"but its reliance on SQLite makes it inherit most of the downsides (and " -"benefits too) of SQLite itself." -msgstr "" - -msgid "" -"Having such a requirement imposes a different approach to storage: we have " -"to decouple the knowledge about the intricacies of storage from the usage of" -" storage itself, so that a module (say query processing) can access storage " -"through an API without needing to know about its implementation. This allows" -" the database to target a POSIX filesystems storage API and an IndexedDB " -"storage API, and make the rest of the code agnostic about storage. PouchDB " -"has such mechanism (called [adapters](https://pouchdb.com/adapters.html)) " -"and Datomic has them too (called [storage " -"services](https://docs.datomic.com/on-prem/storage.html))." -msgstr "" - -msgid "" -"This would allow the database to adapt to where it is embedded: when " -"targeting the browser the IndexedDB storage API would provide the " -"persistence layer that the database requires, and similarly the POSIX " -"filesystem storage API would provide the persistence layer when targeting " -"POSIX systems (like desktops, mobile, *etc.*)." -msgstr "" - -msgid "" -"But there's also an extra restriction that comes from by being embedded: it " -"needs to provide and embeddable artifact, most likely a binary library " -"object that exposes a C compatible FFI, similar to [how SQLite " -"does](https://www.sqlite.org/amalgamation.html). Bundling a full runtime " -"environment is possible, but doesn't make it a compelling solution for " -"embedding. This rules out most languages, and leaves us with C, Rust, Zig, " -"and similar options that can target POSIX systems and WebAssembly." -msgstr "" - -msgid "Immutable" -msgstr "" - -msgid "" -"Being immutable means that only new information is added, no in-place update" -" ever happens, and nothing is ever deleted." -msgstr "" - -msgid "" -"Having an immutable database presents us with similar trade-offs found in " -"persistent data structures, like lack of coordination when doing reads, " -"caches being always coherent, and more usage of space." -msgstr "" - -msgid "" -"[**Datomic**](https://www.datomic.com/) is the go to database example of " -"this: it will only add information (datoms) and allows you to query them in " -"a multitude of ways. Stuart Halloway calls it \"accumulate-only\" over " -"\"append-only\"[^accumulate-only](Video \"[Day of Datomic Part " -"2](https://vimeo.com/116315075)\"):" -msgstr "" - -msgid "" -"It's accumulate-only, it is not append-only. So append-only, most people " -"when they say that they're implying something physical about what happens." -msgstr "" - -msgid "on Datomic's information model, at time 12:28." -msgstr "" - -msgid "" -"Also a database can be append-only and overwrite existing information with " -"new information, by doing clean-ups of \"stale\" data. I prefer to adopt the" -" \"accumulate-only\" naming and approach." -msgstr "" - -msgid "" -"[**Git**](https://git-scm.com/) is another example of this: new commits are " -"always added on top of the previous data, and it grows by adding commits " -"instead of replacing existing ones." -msgstr "" - -msgid "" -"Git repositories can only grow in size, and that is not only an acceptable " -"condition, but also one of the reasons to use it." -msgstr "" - -msgid "" -"All this means that no in-place updates happens on data, and the database " -"will be much more concerned about how compact and efficiently it stores data" -" than how fast it does writes to disk. Being embedded, the storage " -"limitation is either a) how much storage the device has or b) how much " -"storage was designed for the application to consume. So even though the " -"database could theoretically operate with hundreds of TBs, a browser page or" -" mobile application wouldn't have access to this amount of storage. SQLite " -"even [says](https://sqlite.org/limits.html) that it does support " -"approximately 280 TBs of data, but those limits are untested." -msgstr "" - -msgid "" -"The upside of keeping everything is that you can have historical views of " -"your data, which is very powerful. This also means that applications should " -"turn this off when not relevant[^no-history]." -msgstr "" - -msgid "" -"[^no-history]: Similar to [Datomic's " -"`:db/noHistory`](https://docs.datomic.com/cloud/best.html#nohistory-for-" -"high-churn)." -msgstr "" - -msgid "Syncable" -msgstr "" - -msgid "" -"This is a frequent topic when talking about offline-first solutions. When " -"building applications that:" -msgstr "" - -msgid "can fully work offline," -msgstr "" - -msgid "stores data," -msgstr "" - -msgid "propagates that data to other application instances," -msgstr "" - -msgid "" -"then you'll need a conflict resolution strategy to handle all the situations" -" where different application instances disagree. Those application instances" -" could be a desktop and a browser version of the same application, or the " -"same mobile app in different devices." -msgstr "" - -msgid "" -"A three-way merge seems to be the best approach, on top of which you could " -"add application specific conflict resolution functions, like:" -msgstr "" - -msgid "pick the change with higher timestamp;" -msgstr "" - -msgid "if one change is a delete, pick it;" -msgstr "" - -msgid "present the diff on the screen and allow the user to merge them." -msgstr "" - -msgid "" -"Some databases try to make this \"easy\", by choosing a strategy for you, " -"but I've found that different applications require different conflict " -"resolution strategies. Instead, the database should leave this up to the " -"user to decide, and provide tools for them to do it." -msgstr "" - -msgid "" -"[**Three-way merges in version " -"control**](https://en.wikipedia.org/wiki/Merge_(version_control)) are the " -"best example, performing automatic merges when possible and asking the user " -"to resolve conflicts when they appear." -msgstr "" - -msgid "" -"The unit of conflict for a version control system is a line of text. The " -"database equivalent would probably be a single attribute, not a full entity " -"or a full row." -msgstr "" - -msgid "" -"Making all the conflict resolution logic be local should allow the database " -"to have encrypted remotes similar to how [git-remote-" -"gcrypt](https://spwhitton.name/tech/code/git-remote-gcrypt/) adds this " -"functionality to Git. This would enable users to sync the application data " -"across devices using an untrusted intermediary." -msgstr "" - -msgid "Relational" -msgstr "" - -msgid "I want the power of relational queries on the client applications." -msgstr "" - -msgid "" -"Most of the arguments against traditional table-oriented relational " -"databases are related to write performance, but those don't apply here. The " -"bottlenecks for client applications usually aren't write throughput. Nobody " -"is interested in differentiating between 1 MB/s or 10 MB/s when you're " -"limited to 500 MB total." -msgstr "" - -msgid "" -"The relational model of the database could either be based on SQL and tables" -" like in SQLite, or maybe [datalog](https://docs.datomic.com/on-" -"prem/query.html) and [datoms](https://docs.datomic.com/cloud/whatis/data-" -"model.html#datoms) like in Datomic." -msgstr "" - -msgid "From aspects to values" -msgstr "" - -msgid "" -"Now let's try to translate the aspects above into values, as suggested by " -"Bryan Cantrill." -msgstr "" - -msgid "Portability" -msgstr "" - -msgid "" -"Being able to target so many different platforms is a bold goal, and the " -"embedded nature of the database demands portability to be a core value." -msgstr "" - -msgid "Integrity" -msgstr "" - -msgid "" -"When the local database becomes the source of truth of the application, it " -"must provide consistency guarantees that enables applications to rely on it." -msgstr "" - -msgid "Expressiveness" -msgstr "" - -msgid "" -"The database should empower applications to slice and dice the data in any " -"way it wants to." -msgstr "" - -msgid "Next steps" -msgstr "" - -msgid "" -"Since I can't find any database that fits these requirements, I've finally " -"come to terms with doing it myself." -msgstr "" - -msgid "" -"It's probably going to take me a few years to do it, and making it portable " -"between POSIX and IndexedDB will probably be the biggest challenge. I got " -"myself a few books on databases to start." -msgstr "" - -msgid "I wonder if I'll ever be able to get this done." -msgstr "" - -msgid "External links" -msgstr "" - -msgid "" -"See discussions on " -"[Reddit](https://www.reddit.com/r/programming/comments/ijwz5b/the_database_i_wish_i_had/)," -" [lobsters](https://lobste.rs/s/m9vkg4/database_i_wish_i_had), " -"[HN](https://news.ycombinator.com/item?id=24337244) and [a lengthy email " -"exchange](https://lists.sr.ht/~euandreh/public-" -"inbox/%3C010101744a592b75-1dce9281-f0b8-4226-9d50-fd2c7901fa72-000000%40us-" -"west-2.amazonses.com%3E)." -msgstr "" - -msgid "" -"This makes me consider it as a storage backend all by itself. I\n" -"initially considered having an SQLite storage backend as one implementation\n" -"of the POSIX filesystem storage API that I mentioned. My goal was to rely on\n" -"it so I could validate the correctness of the actual implementation, given\n" -"SQLite's robustness.\n" -"\n" -"However it may even better to just use SQLite, and get an ACID backend\n" -"without recreating a big part of SQLite from scratch. In fact, both Datomic\n" -"and PouchDB didn't create an storage backend for themselves, they just\n" -"plugged on what already existed and already worked. I'm beginning to think\n" -"that it would be wiser to just do the same, and drop entirely the from\n" -"scratch implementation that I mentioned.\n" -"\n" -"That's not to say that adding an IndexedDB compatibility layer to SQLite\n" -"would be enough to make it fit the other requirements I mention on this\n" -"page. SQLite still is an implementation of a update-in-place, SQL,\n" -"table-oriented database. It is probably true that cherry-picking the\n" -"relevant parts of SQLite (like storage access, consistency, crash recovery,\n" -"parser generator, *etc.*) and leaving out the unwanted parts (SQL, tables,\n" -"threading, *etc.*) would be better than including the full SQLite stack, but\n" -"that's simply an optimization. Both could even coexist, if desired.\n" -"\n" -"SQLite would have to be treated similarly to how Datomic treats SQL\n" -"databases: instead of having a table for each entities, spread attributes\n" -"over the tables, *etc.*, it treats SQL databases as a key-value storage so it\n" -"doesn't have to re-implement interacting with the disk that other databases\n" -"do well.\n" -"\n" -"The tables would contain blocks of binary data, so there isn't a difference\n" -"on how the SQLite storage backend behaves and how the IndexedDB storage\n" -"backend behaves, much like how Datomic works the same regardless of the\n" -"storage backend, same for PouchDB.\n" -"\n" -"I welcome corrections on what I said above, too.\n" -msgstr "" - -msgid "" -"title: The database I wish I had\n" -"date: 2020-08-31\n" -"updated_at: 2020-09-03\n" -"layout: post\n" -"lang: en\n" -"ref: the-database-i-wish-i-had\n" -"eu_categories: mediator" -msgstr "" - -#~ msgid "" -#~ "title: The database I wish I had\n" -#~ "date: 2020-08-31\n" -#~ "updated_at: 2020-09-03\n" -#~ "layout: post\n" -#~ "lang: en\n" -#~ "ref: the-database-i-wish-i-had\n" -#~ "category: mediator" -#~ msgstr "" |