Main Page: Difference between revisions

From MemCP
Jump to navigation Jump to search
Line 34: Line 34:
* [[Introduction to Scheme]]
* [[Introduction to Scheme]]


==== SQL Frontend ====
==== Frontends ====
 
===== SQL Frontend =====
* [[Replace MySQL with MemCP]]
* [[Replace MySQL with MemCP]]
* [[SQL over REST]]
* [[SQL over REST]]
Line 40: Line 42:
* [[How SQL Operators are implemented on MemCP]]
* [[How SQL Operators are implemented on MemCP]]


==== RDF Frontend ====
===== RDF Frontend =====
* [[Introduction to RDF]]
* [[Introduction to RDF]]
* [[RDF templating and model driven development]]
* [[RDF templating and model driven development]]
===== Custom Frontends =====
* [[In-Database WebApps]]
==== Administration ====
*[[Settings]]
* [[Process Hibernation]]
* [[Performance Measurement]]


==== Internals ====
==== Internals ====
Line 52: Line 64:
* [[Columnar Storage]]
* [[Columnar Storage]]
* [[Transactions]]
* [[Transactions]]
===== Advanced Topics =====
* [[Settings]]
* [[Process Hibernation]]
* [[In-Database WebApps]]


===== Optimizations =====
===== Optimizations =====

Revision as of 09:02, 19 May 2024

What is memcp?

memcp is an open-source, high-performance, columnar in-memory database that can handle both OLAP and OLTP workloads. It provides an alternative to proprietary analytical databases and aims to bring the benefits of columnar storage to the open-source world.

memcp is written in Golang and is designed to be portable and extensible, allowing developers to embed the database into their applications with ease. It is also designed with a focus on scalability and performance, making it a suitable choice for distributed applications.

Features

  • fast: MemCP is built with parallelization in mind. The parallelization pattern is made for minimal overhead.
  • efficient: The average compression ratio is 1:5 (80% memory saving) compared to MySQL/MariaDB
  • modern: MemCP is built for modern hardware with caches, NUMA memory, multicore CPUs, NVMe SSDs
  • versatile: Use it in big mainframes to gain analytical performance, use it in embedded systems to conserve flash lifetime
  • Columnar storage: Stores data column-wise instead of row-wise, which allows for better compression, faster query execution, and more efficient use of memory.
  • In-memory database: Stores all data in memory, which allows for extremely fast query execution.
  • Build fast REST APIs directly in the database (they are faster because there is no network connection / SQL layer in between)
  • OLAP and OLTP support: Can handle both online analytical processing (OLAP) and online transaction processing (OLTP) workloads.
  • Compression: Lots of compression formats are supported like bit-packing and dictionary encoding
  • Scalability: Designed to scale on a single node with huge NUMA memory
  • Adjustable persistency: Decide whether you want to persist a table or not or to just keep snapshots of a period of time

Navigation

Introduction

Getting Started

Frontends

SQL Frontend
RDF Frontend
Custom Frontends

Administration

Internals

How things work in MemCP
Optimizations


Screenshot from htop.png


Further Reading

MemCP on Github

Scientific

How MemCP was built