{"id":20310231,"url":"https://github.com/bloq/memds","last_synced_at":"2025-04-11T15:42:10.635Z","repository":{"id":93947391,"uuid":"244035635","full_name":"bloq/memds","owner":"bloq","description":"Memory database","archived":false,"fork":false,"pushed_at":"2024-03-29T21:44:31.000Z","size":146,"stargazers_count":55,"open_issues_count":0,"forks_count":0,"subscribers_count":6,"default_branch":"master","last_synced_at":"2025-03-25T11:52:15.518Z","etag":null,"topics":["client-server","memory-database","rust","rust-lang"],"latest_commit_sha":null,"homepage":null,"language":"Rust","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/bloq.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-02-29T20:20:30.000Z","updated_at":"2025-01-02T02:54:31.000Z","dependencies_parsed_at":"2024-11-14T17:43:00.135Z","dependency_job_id":null,"html_url":"https://github.com/bloq/memds","commit_stats":null,"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bloq%2Fmemds","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bloq%2Fmemds/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bloq%2Fmemds/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bloq%2Fmemds/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/bloq","download_url":"https://codeload.github.com/bloq/memds/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":248433168,"owners_count":21102520,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["client-server","memory-database","rust","rust-lang"],"created_at":"2024-11-14T17:30:42.039Z","updated_at":"2025-04-11T15:42:10.616Z","avatar_url":"https://github.com/bloq.png","language":"Rust","readme":"# memds\nMemory database - \"redis v3, in Rust\"\n\n## Goals and Journey\n\nmemds intends to be \"the next thing after redis\"\n\nLooking through software history, we can consider [memcached](https://memcached.org/) as Version 1:  memcached provides a single key/value namespace for string values, plus some small mods for atomic numbers.   [redis](https://redis.io/) is Version 2:  Differences between abstract data types (ADTs) are made explicit with strings, sets, lists, hash [tables], streams and more.\n\nmemds is Version 3:  Formally model the network protocol and database namespace.  Represent abstract data types as CLASS.METHOD internal Remote Procedure Calls (RPCs), batched together as a bytecode-like stream of database mutation operations.\n\n## Status\n\nThis project is alpha status; brand new; wet cement.  Proceed with with that caveat in mind.\n\nContributors via Pull Request are welcome.\n\n## Model \u0026 design comparisons\n\n### Model caveats\n\nThe current code is still a work in progress, in terms of implementing the models described below.   See the following markdown docs for more detailed information:\n* [TODO](TODO.md)\n* [Detailed redis feature comparison](compare.md)\n* [Other project notes](notes.md)\n\n### Old-vs-New\n\nOld redis model:\n```\n     [database number] [key] [abstract data type]\n```\nNew memds model:\n```\n     [database key] [key] [abstract data type, possibly with its own hierarchy]\n```\n\n* Old redis protocol hierarchy:  All ADTs overloaded in a single command namespace (\"HLEN\",\"LLEN\").\n* New memds protocol hierarchy:  Each ADT in its own class-specific namespace.  (like \"HASH.LEN\",\"LIST.LEN\", but with integer identifiers).\n\n* Old redis network protocol:  Custom protocol, requiring custom clients across N programming languages.\n* New memds network protocol:  Protobuf schema, automatically generating correct, compliant, fast client codecs for many languages.\n\n## Components\n\n* `memds-cli`: Command line client\n* `memds-proto`: wire protocol library\n* `memds-server`: Database server\n\n## Installation\n\nAll building is done via the standard [Rust](https://www.rust-lang.org/) tool [Cargo](https://doc.rust-lang.org/cargo/).\n\n```\n$ cargo build --release\n$ cargo test --release\n```\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbloq%2Fmemds","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fbloq%2Fmemds","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbloq%2Fmemds/lists"}