Commit Graph

36 Commits

Author SHA1 Message Date
Josipmrden
082f9a7d9b
Add behaviour of no updates if vertex is updated with same value () 2024-03-15 14:45:21 +01:00
andrejtonev
6a4ef55e90
Better auth user/role handling ()
* Stop auth module from creating users
* Explicit about auth policy (check if no users defined OR auth module used)
* Role supports database access definition
* Authenticate() returns user or role
* AuthChecker generates QueryUserOrRole (can be empty)
* QueryUserOrRole actually authorizes
* Add auth cache invalidation
* Better database access queries (GRANT, DENY, REVOKE DATABASE)
2024-02-22 14:00:39 +00:00
Andi
7ec648b4ce
Add --experimental-enabled=high-availability () 2024-02-19 16:28:15 +00:00
Antonio Filipovic
bfc756c092
HA: Polish flow for replicas from coordinator () 2024-02-16 10:58:01 +01:00
Andi
fb281459b9
Add support for unregistering replication instances () 2024-02-14 14:24:59 +00:00
Gareth Andrew Lloyd
f48151576b
System replication experimental flag ()
- Remove the compile time control
- Introduce the runtime control flag

New flag `--experimental-enabled=system-replication`
2024-02-13 12:57:18 +00:00
Andi
cf80687d1d
HA: Organize Raft coordinator group () 2024-02-08 09:11:33 +00:00
Andi
38ade99652
HA: Add coordinator to replication cluster () 2024-01-24 13:07:51 +01:00
andrejtonev
071df2f439
Replication refactor part 7 ()
* Split queries into system and data queries
* System queries are sequentially executed and generate separate transaction deltas
* System transaction try locks for 100ms
* last_commited_system_ts saved to DBMS durability
* Replicating CREATE/DROP DATABASE
* Sending a system snapshot if REPLICA behind
* Passing a copy of the gatekeeper::access as std::any to all functions that could call an async execution
* Removed delete_on_drop flag (we now always delete on drop)
* Using UUID as the directory name for databases
* DBMS durability update (added versioning and salient information)
* Automatic migration from previous version
* Interpreter can run some queries without a target database
* SHOW REPLICA returns the status of the currently active DB
* Returning UUID instead of db name in the RPC responses
* Using UUIDs for database specification in RPC (not name)
* FrequentCheck forces update on reconnect
* TimestampRpc will detect if a replica is behind, and will update client's state
* Safer SLK reads
* Split SHOW DATABASES in two SHOW DATABASES (list of current databases) and SHOW DATABASE a single string naming the current database

---------

Co-authored-by: Gareth Lloyd <gareth.lloyd@memgraph.io>
2024-01-23 12:06:10 +01:00
Ivan Milinović
686fadf072
Fix slow python QM (Python GC changes) () 2023-12-27 11:51:10 +01:00
Antonio Filipovic
74fa6d21f6
Implement parallel constraints recovery () 2023-12-04 21:56:05 +01:00
gvolfing
1527bdf435 Make metadata collection setable with flag
There might be a performance impect of updating the metadata store on
bulk operations. Hence this flag which is disabling the collection by
default. If the queries to obtain the information are called with this
flag disabled, the database will throw an exception.
2023-11-14 13:10:08 +01:00
DavIvek
ece4b0dba8
Fix cached plan not getting invalidated () 2023-11-07 13:34:03 +01:00
Antonio Filipovic
1ab7f6ac78
Add notification for user on max map count () 2023-11-06 15:44:26 +01:00
Antonio Filipovic
48631d1e37
Rename memory usage and memory allocated () 2023-11-03 14:40:45 +01:00
Josipmrden
be16ca7362
Add cartesian and hash join operators () 2023-10-24 21:54:42 +02:00
andrejtonev
26e31ca06f
Fix SHOW CONFIG to show the run-time flag status () 2023-10-23 10:18:07 +02:00
Andi
61ac7e1b11
Add --storage-mode flag ()
* Add --storage-mode flag
2023-09-26 14:47:30 +02:00
andrejtonev
5e5f4ffc5d
Add more runtime configurable settings ()
server name, query timeout settings, log.level, log.to_stderr
2023-09-11 11:30:54 -04:00
andrejtonev
28dbcd1545
Add disk storage to e2e tests ()
* Add disk storage to e2e tests

---------

Co-authored-by: Andi Skrgat <andi8647@gmail.com>
2023-08-30 13:42:11 +02:00
Gareth Andrew Lloyd
97183fb9da
Fix FLAGS_delta_chain_cache_threshold typo () 2023-08-21 13:16:02 +02:00
Gareth Andrew Lloyd
2e51e703c3
Add supernode vertex cache ()
Add supernode vertex cache to account for long delta chains and modifications in the same module being independent of scanning of the nodes in the next iteration of the pulling mechanism.
2023-08-11 10:18:28 +02:00
andrejtonev
e8850549d2
Add multi-tenancy v1 ()
* Decouple BoltSession and communication::bolt::Session
* Add CREATE/USE/DROP DATABASE
* Add SHOW DATABASES
* Cover WebSocket session
* Simple session safety implemented via RWLock
* Storage symlinks for backward. compatibility
* Extend the audit log with the DB info
* Add auth part
* Add tenant recovery
2023-08-01 18:49:11 +02:00
gvolfing
210bea83d4
Add GraphQL transpilation compatibility ()
* Add callable mappings feature
* Implement mgps.validate (void procedure)
* Make '_' a valid variable name
2023-07-31 14:48:12 +02:00
Marko Budiselić
3b9133fd5a
Improve e2e and replication testing setup ()
* Add `--replication-restore-state-on-startup` with `false` as default

Co-authored-by: Aidar Samerkhanov <aidar.samerkhanov@memgraph.io>
Co-authored-by: Andi Skrgat <andi8647@gmail.com>
2023-07-19 21:18:43 +02:00
Josipmrden
651b6f3a5a Expose system metrics over HTTP Endpoint () 2023-05-18 05:10:57 +00:00
gvolfing
c3e4f81026
Include additional info inside storage mode info query () 2023-05-16 14:25:41 +02:00
gvolfing
00f8d54249
Parallelize index creation () 2023-04-26 16:28:02 +02:00
János Benjamin Antal
6c947947eb Parallelize recovery ()
* Parallelize edge recovery

* Load vertex labels and properties parallel

* Add parallel connectivity loading

* Add batches information to snapshot

* Introduce `items_per_batch` and `recovery_thread_count` flags

* Make possible to load snapshots with old version

* Add vertex batches to `RecoveryInfo`

* Extend durability integration tests with v15 test cases

* Add `std::vector` based `InitProperties`

* Use `InitProperties` in snapshot loading
2023-04-25 16:25:25 +02:00
Josipmrden
128771a6ec
Add SHA-256 password encryption () 2023-04-03 16:29:21 +02:00
Andi
310e305cfb
Fix python module reloading () 2022-12-12 21:11:13 +01:00
Marko Budiselić
9d6a23b6bd
Add init-file and init-data-file capabilities () 2022-12-09 18:50:33 +01:00
Andi
f2d5ab61c4
Fix Python submodules reloading () 2022-12-09 14:30:41 +01:00
Tyler Neely
7d6a5e5b9c
Add support for -h to show help in addition to --help () 2022-12-07 16:51:32 +01:00
Jeremy B
d4f0bb0e38
Correct inconsistencies w.r.t. sync replication ()
Add a report for the case where a sync replica does not confirm within a timeout:
-Add a new exception: ReplicationException to be returned when one sync replica does not confirm the reception of messages (new data, new constraint/index, or for triggers)
-Update the logic to throw the ReplicationException when needed for insertion of new data, triggers, or creation of new constraint/index
-Add end-to-end tests to cover the loss of connection with sync/async replicas when adding new data, adding new constraint/indexes, and triggers

Add end-to-end tests to cover the creation and drop of indexes, existence constraints, and uniqueness constraints

Improved tooling function mg_sleep_and_assert to also show the last result when duration is exceeded
2022-08-09 11:29:55 +02:00
gvolfing
bbfef45b37
Add command to return startup config ()
Add a new command that is able to return the set of configurations that that the
given instance of memgraph was started up with. The returned information
currently consists of the name, the default and the current value of each flag.
The hidden property of three flags were removed, namely --query-cost-planner,
--query-vertex-count-to-expand-existing and --query-max-plans. The flag
--log-link-basename was completely removed since it is not used.
2022-08-03 18:08:44 +02:00