If you are interested in MatrixOne project, please kindly give MatrixOne a triple `Star`, `Fork` and `Watch`, Thanks!
MatrixOne is a future-oriented hyper-converged cloud and edge native DBMS that supports transactional, analytical, and streaming workloads with a simplified and distributed database engine, across multiple data centers, clouds, edges and other heterogeneous infrastructures.
Monolithic Engine
A monolithic database engine is designed to support hybrid workloads: transactional, analytical, streaming, time-series, machine learning, etc.Built-in Streaming Engine
With the built-in streaming engine, MatrixOne supports in-database streaming processing by groundbreaking incremental materialized view maintenance.Real Infrastructure Agnostic
MatrixOne supports seemless workload migration and bursting among different locations and infrastructures.Multi-site Active/Active
MatrixOne provides industry-leading latency control with optimized consistency protocol.High Performance
Accelerated queries supported by patented vectorized execution as well as optimal computation push down strategies through factorization techniques.Strong Consistency
MatrixOne introduces a global, high-performance distributed transaction protocol across storage engines.High Scalability
Seamless and non-disruptive scaling by disaggregated storage and compute.Simplify Database Management and Maintenance
To solve the problem of high and unpredictable cost of database selection process, management and maintenance due to database overabundance, MatrixOne all-in-one architecture will significantly simplify database management and maintenance, single database can serve multiple data applications.Reduce Data Fragmentation and Inconsistency
Data flow and copy between different databases makes data sync and consistency increasingly difficult. The unified incrementally materialized view of MatrixOne makes the downstream can support real-time upstream update, achieve the end-to-end data processing without redundant ETL process.Decoupling Data Architecture From Infrastructure
Currently the architecture design across different infrastructures is complicated, causes new data silos between cloud and edge, cloud and on-premise. MatrixOne is designed with unified architecture to support simplified data management and operations across different type of infrastructures.Extremely Fast Complex Query Performance
Poor business agility as a result of slow complex queries and redundant intermediate tables in current data warehousing solutions. MatrixOne supports blazing fast experience even for star and snowflake schema queries, improving business agility by real-time analytics.A Solid OLTP-like OLAP Experience
Current data warehousing solutions have the following problems such as high latency and absence of immediate visibility for data updates. MatrixOne brings OLTP (Online Transactional Processing) level consistency and high availability to CRUD operations in OLAP (Online Analytical Processing).Seamless and Non-disruptive Scalability
It is difficult to balance performance and scalability to achieve optimum price-performance ratio in current data warehousing solutions. MatrixOne's disaggregated storage and compute architecture makes it fully automated and efficient scale in/out and up/down without disrupting applications.MatrixOne's architecture is as below:
For more details, you can checkout MatrixOne Architecture.
⚡️ Quick start
MatrixOne supports Linux and MacOS. You can install MatrixOne either by building from source or using docker. For other installation types, please refer to MatrixOne installation for more details.
-
Install Go (version 1.18 is required).
-
Get the MatrixOne code: Depending on your needs, choose whether you want to keep your code up to date, or if you want to get the latest stable version of the code.
- Option 1: Get the MatrixOne(Preview Version) code
The main branch is the default branch, the code on the main branch is always up-to-date but not stable enough.
$ git clone https://github.com/matrixorigin/matrixone.git
$ cd matrixone
- Option 2: Get the MatrixOne(Stable Version) code
If you want to get the latest stable version code released by MatrixOne, please switch to the branch of version 0.5.0 first.
$ git clone https://github.com/matrixorigin/matrixone.git
$ git checkout 0.5.0
$ cd matrixone
- Run make:
You can run make debug
, make clean
, or anything else our Makefile offers.
$ make config
$ make build
- Boot MatrixOne server:
$ ./mo-server system_vars_config.toml
- Make sure Docker is installed, verify Docker daemon is running in the background:
$ docker --version
- Create and run the container for the latest release of MatrixOne. It will pull the image from Docker Hub if not exists.
It will pull the image from Docker Hub if not exists. You can choose to pull the latest image or a stable version.
- Latest Image
$ docker run -d -p 6001:6001 --name matrixone matrixorigin/matrixone:latest
- 0.5.0 Version Image
$ docker run -d -p 6001:6001 --name matrixone matrixorigin/matrixone:0.5.0
-
Install MySQL client.
MatrixOne supports the MySQL wire protocol, so you can use MySQL client drivers to connect from various languages. Currently, MatrixOne is only compatible with Oracle MySQL client. This means that some features might not work with MariaDB client.
-
Connect to MatrixOne server:
$ mysql -h IP -P PORT -uUsername -p
The connection string is the same format as MySQL accepts. You need to provide a user name and a password.
Use the built-in test account for example:
- user: dump
- password: 111
$ mysql -h 127.0.0.1 -P 6001 -udump -p
Enter password:
Now, MatrixOne only supports the TCP listener.
Contributions to MatrixOne are welcome from everyone.
See Contribution Guide for details on submitting patches and the contribution workflow.
MatrixOne is licensed under the Apache License, Version 2.0.