แฒกแแแแแ แงแแแแแก. แฉแแแ แแแแฃแจแแแแแ แแ แแแฃแฅแขแก แแคแแแแ แขแ แแคแแแแก แแแแแแแแกแแแแก. แแ แแแฅแขแก แแฅแแก แแแแชแแแ, แ แแแแแแช แแแแแแจแแ แแแฃแแแ แ แแแแแแแแจแ แแแแแขแแ แแ แแแ แจแ แฃแขแแแแก แกแขแแขแแกแขแแแฃแ แแแแแแแแแ.
แ แแแแ แช แแ แแแแชแแแแก แแแฌแแแ, แแแแฎแแแ แแแแแแก แจแแฃแซแแแแ แแแฃแกแแแ แกแแกแขแแแแก แแแแฎแแแแแแ แจแแแแแแ แขแแแแก:
- แ แแแแแแ แแแแแขแแ แ แแแแแแ "A" แแแแแแแ "B" แแแแแจแ;
- แ แแแแแแ แแแแแขแแ แ แแแแแแ "A" แแแแแแแ "B" แแแแแจแ "C" แแ แจแแแแแ "D" แแแแแก แแแแแแ;
- แ แแแแแแ แแ แ แแแกแญแแ แแ แแแ แแแแฃแแ แขแแแแก แแแแแขแแ แก แแแแแแฃแ แแแแกแแแแก "A" แแแแแแแ "B"-แแแ.
แแ แ แแแ แแกแแแแกแ แแแแแแขแแแฃแ แ แแแแฎแแแแแแ.
แแแแแขแแ แแก แแแซแ แแแแ แแแแแแจแ แแ แแก แแแแแ แแฃแแ แแ แแคแแแ. แแแขแแ แแแขแแก แฌแแแแแฎแแแก แจแแแแแ แแฆแแแแแฉแแแ, แ แแ แแ แแคแแแฃแแ DBMS แแกแแแ แแแแแแงแแแแแ แแแแแแขแแแฃแ แ แแแแแ แแจแแแแกแแแแก. แแแแแแแ แแแแแฎแ, แ แแแแ แแแฃแแแแแแแแแ แแ แแคแแแฃแแ DBMS แแกแแ แจแแแแแฎแแแแก (TL; DR; แชแฃแแแ).
แแ แแแแ แฉแแ DBMS-แแก แแแแแงแแแแแ
- BerkeleyDB แจแแแแฎแแแก backend, Apache Cassandra, Scylla;
- แ แแฃแแ แแแแแฅแกแแแแก แจแแแแฎแแ แจแแกแแซแแแแแแแ Lucene, Elasticsearch, Solr.
JanusGraph-แแก แแแขแแ แแแ แฌแแ แแ, แ แแ แแก แจแแกแแคแแ แแกแแ แ แแแแ แช OLTP-แกแแแแก, แแกแแแ OLAP-แแกแแแแก.
แแ แแแฃแจแแแแแ BerkeleyDB-แแแ, Apache Cassandra-แกแแแ, Scylla-แกแแแ แแ ES-แแแ แแ แแก แแ แแแฃแฅแขแแแ แฎแจแแ แแ แแแแแแงแแแแแ แฉแแแแก แกแแกแขแแแแแจแ, แแแแขแแ แแแขแแแแกแขแฃแ แแ แแแงแแแ แแแแฌแงแแแแแ แแ แแ แแคแแแแก DBMS-แแก แแแแแชแแแแ. แแ แฃแชแแแฃแ แแ แแแแแฉแแแ, แ แแ แแแแ แฉแแ BerkeleyDB RocksDB-แแ, แแแแ แแ แแก แแแแแ แขแ แแแแแฅแชแแแก แแแแฎแแแแแแแก แแแแแ. แแแแแกแแแแ แจแแแแฎแแแแแจแ, แแแกแจแขแแแฃแ แ, แแ แแแฃแฅแขแแก แแแแแงแแแแแแกแแแแก, แ แแแแแแแแแแฃแแแ แแแกแแแแ แแแ แแ แกแแแแแแ แแแฅแแแแแก แแแแแงแแแแแ.
แแ แแ แแแแแแฎแแแ Neo4j, แ แแแแแ แแแแกแขแแ แแ แแแ แแแแแฎแแแก แแแแแ แชแแฃแ แแแ แกแแแก, แแแฃ แแ แแแฃแฅแขแ แแ แแ แแก แฆแแ แฌแงแแ แ.
แแ แแคแแแฃแแ DBMS แแแแแแก: โแแฃ แแก แแ แแคแแแแก แฐแแแแก, แแแแฅแแชแแ แแแก แ แแแแ แช แแ แแคแแแก!โ - แกแแแแแแแ!
แฏแแ แแแแฎแแขแ แแ แแคแแแ, แ แแแแแแช แแฃแกแขแแ แจแแแแแแแแแ แแ แแคแแแแก DBMS-แแก แแแแแแแแแก แแแฎแแแแแ:
แแ แแก แแ แกแ Zone
, แแแกแฃแฎแแกแแแแแแแ แขแแ แแขแแ แแ. แแฃ ZoneStep
แแแฃแแแแแก แแแแก Zone
, แจแแแแแ แแก แแแฃแแแแแแก แแแก. แแ แกแแ Area
, ZoneTrack
, Person
แงแฃแ แแแฆแแแแก แแฃ แแแแฅแชแแแ, แแกแแแ แแแฃแแแแแก แแแแแแก แแ แแ แแแแแฎแแแแแ แขแแกแขแแก แแแฌแแแแ. แกแแแ แแ แฏแแแจแ, แแกแแแ แแแแแ แแแแก แกแขแ แฃแฅแขแฃแ แแก แฏแแญแแแก แกแแซแแแแ แแแแฎแแแแ แแกแ แแแแแแงแฃแ แแแ:
g.V().hasLabel('Zone').has('id',0).in_()
.repeat(__.out()).until(__.out().hasLabel('Zone').has('id',19)).count().next()
แ แ แ แฃแกแฃแแแ แแ แแก แแกแแแ: แแแแแแแ แแแแ ID=0-แแ, แแแฆแแ แงแแแแ แฌแแแ แ, แกแแแแแแแช แแแแ แแแแแก แแแกแแ (ZoneStep), แแแแ แขแงแแ แฃแแแ แแแแ แฃแแแแแก แแแ แแจแ, แกแแแแ แแ แแแแแแ แแ ZoneSteps-แก, แกแแแแแแแช แแ แแก แแฆแแแ แ แแแแแจแ. ID=19, แแแแแแแแแ แแกแแแ แฏแแญแแแแแก แ แแแแแแแแ.
แแ แแ แแแขแงแแ, แ แแ แแแชแ แแ แแคแแแแแแ แซแแแแแก แงแแแแ แกแแ แแฃแแ, แแแแ แแ แแก แจแแแแแฎแแ แจแแแฅแแแ แแ แฌแแแแแก แกแแคแฃแซแแแแแ (
แแ แฉแแแขแแแ แแ 50 แแแแกแ แขแ แแแ, แกแแแ แซแแ 3-แแแ 20 แฅแฃแแแแแ JanusGraph แแ แแคแแแแก แแแแแชแแแแ แแแแแจแ BerkeleyDB backend-แแก แแแแแงแแแแแแ, แจแแแฅแแแแ แแแแแฅแกแแแ แแแฎแแแแแ
แแแแแแแก แฉแแแแขแแแ แแแแก แกแแ แแแขแ:
from random import random
from time import time
from init import g, graph
if __name__ == '__main__':
points = []
max_zones = 19
zcache = dict()
for i in range(0, max_zones + 1):
zcache[i] = g.addV('Zone').property('id', i).next()
startZ = zcache[0]
endZ = zcache[max_zones]
for i in range(0, 10000):
if not i % 100:
print(i)
start = g.addV('ZoneStep').property('time', int(time())).next()
g.V(start).addE('belongs').to(startZ).iterate()
while True:
pt = g.addV('ZoneStep').property('time', int(time())).next()
end_chain = random()
if end_chain < 0.3:
g.V(pt).addE('belongs').to(endZ).iterate()
g.V(start).addE('goes').to(pt).iterate()
break
else:
zone_id = int(random() * max_zones)
g.V(pt).addE('belongs').to(zcache[zone_id]).iterate()
g.V(start).addE('goes').to(pt).iterate()
start = pt
count = g.V().count().next()
print(count)
SSD-แแ แแแแแแแงแแแแ VM 4 แแแ แแแแ แแ 16 GB แแแแ แแขแแฃแแ แแแฎแกแแแ แแแแ. JanusGraph แแแแแแแแ แแ แแ แซแแแแแแก แแแแแงแแแแแแ:
docker run --name janusgraph -p8182:8182 janusgraph/janusgraph:latest
แแ แจแแแแฎแแแแแจแ, แแแแแชแแแแแ แแ แแแแแฅแกแแแ, แ แแแแแแแช แแแแแแงแแแแแ แแฃแกแขแ แแแแฎแแแแ แแก แกแแซแแแแแแ, แแแแฎแแแ BerkeleyDB-แจแ. แแแ แ แแแชแแแฃแแ แแฎแแแแแก แจแแกแ แฃแแแแแก แจแแแแแ แแแแแฆแ แแ แ, แ แแแแแแช แขแแแแ แ แแแแแแแแ แแแแฃแ แฌแแแก.
แแแแแแฆแแแจแแฃแแ 4 แกแแ แแแขแแก แแแ แแแแแฃแ แแ แแแจแแแแแ, แแ แแแแแฎแแ แฎแ DBMS-แแก แแแแ แแ แแแแแฅแชแแแ Java stacktraces-แแก แแฎแแแ แฃแแ แแแแแแแ (แแ แฉแแแ แงแแแแแก แแแแงแแแ แก Java stacktraces-แแก แแแแฎแแ) Docker-แแก แแฃแ แแแแแแจแ.
แแแ แแแแฃแแ แคแแฅแ แแก แจแแแแแ แแแแแแฌแงแแแขแ แแ แแคแแแแก แแแแแ แแแ แแแแแแแ แขแแแแแแแ แจแแแแแแแแแ แแ:
แแแแแฌแงแแแขแแแแแแก แแแฆแแแ, แ แแ แแ แแแฃแแแก แแขแ แแแฃแขแแแแก แแแฎแแแแแ แซแแแแ แฃแคแ แ แกแฌแ แแคแ แแฅแแแแ, แแแแ แ แแแแแแแแก แแแฎแแแแแ. แจแแแแแแ, แฉแแแ แแแแฎแแแแ แแแแแแแแ แแ แจแแแแแแจแ:
g.V().hasLabel('ZoneStep').has('id',0).repeat(__.out().simplePath()).until(__.hasLabel('ZoneStep').has('id',19)).count().next()
แ แ แ แฃแกแฃแแแ แแ แแก แแแแฎแแแแแแ แแกแแแ: แแแแแแ ZoneStep ID=0-แแ, แแแแ แขแงแแ แฃแแแ แแแแ แฃแแแแแก แแแ แแจแ, แกแแแแ แแ แแแแแแ ZoneStep ID=19-แแ, แแแแแแแแ แแกแแแ แฏแแญแแแแแก แ แแแแแแแแ.
แแ แแกแแแ แแแแแแแ แขแแแ แแแแแ แแแชแแแฃแแ แฉแแขแแแ แแแแก แกแแ แแแขแ, แ แแแ แแ แจแแแแฅแแแ แแแแแแขแ แแแแจแแ แแแ, แจแแแแแแคแแ แแแ แแขแ แแแฃแขแแแแ.
แแแแฎแแแแแก แฏแแ แแแแแ แ แแแแแแแแ แฌแแแ แแแกแญแแ แแ, แ แแช แกแ แฃแแแแ แแแฃแฆแแแแแ แแงแ แฉแแแแ แแแแชแแแแกแแแแก, แ แแแแแ แแก แกแแแ แแแ แแ แแงแ แจแแกแแคแแ แแกแ แ แแแแ แกแแฎแแก AdHoc แแแแฎแแแแแแแก แแแแแแแแกแแแแก.
แแ แแชแแแ JanusGraph-แแก แแแแแ แแแ Scylla-แก แแแแแงแแแแแแ, แ แแแแ แช แงแแแแแแ แกแฌแ แแคแ Cassandra แแแแฎแแ แชแแแแแแแก, แแแแ แแ แแแแ แแกแแแ แแ แแแแแแฌแแแ แ แแแแ แแแแจแแแแแแแแแ แจแแกแ แฃแแแแแก แชแแแแแแแแแ.
แแกแ แ แแ, แแแฃแฎแแแแแแ แแแแกแ, แ แแ "แแก แฐแแแแก แแ แแคแแแก", แแ แแแ แแแแแฆแ แแ แแคแแแแก DBMS แแแกแ แกแฌแ แแคแแ แแแกแแแฃแจแแแแแแแ. แแ แกแ แฃแแแ แแแแ แแฃแแแ, แ แแ แแ แแก แ แแฆแแช, แ แแช แแ แแแชแ แแ แ แแ JanusGraph-แก แจแแฃแซแแแ แจแแแกแ แฃแแแก แแก แซแแแแ แฌแแแแก แแแฌแแแจแ, แแฃแแชแ แแ แแก แแแ แจแแแซแแแ.
แแแแก แแแแ, แ แแ แแ แแแแแแ แฏแแ แแแแแ แแแกแแแแแ แแแแแ แแงแ, แแแแแฌแงแ แคแแฅแ แ แชแฎแ แแแแแแก JOIN-แกแ แแ Pivots-แแ, แ แแแแแแแช แแ แจแแแแแแแแแแแแ แแแแแแแขแฃแ แแแแก แแฃแแฎแแ แแแขแแแแแแก, แแแแ แแ แแ แแฅแขแแแแจแ แจแแแซแแแแ แแงแแก แกแ แฃแแแแ แแแแแกแแแแแ แแแ แแแแขแ.
แฉแแแแ แแ แแแฅแขแ แฃแแแ แแงแแแแแก Apache ClickHouse-แก, แแแแขแแ แแแแแแฌแงแแแขแ แฉแแแ แแแแแแ แแ แแแแแแขแแแฃแ DBMS-แแ แแแแแแแชแแแ.
แแแแแแแแกแ ClickHouse แแแ แขแแแ แ แแชแแแขแแก แแแแแงแแแแแแ:
sudo docker run -d --name clickhouse_1
--ulimit nofile=262144:262144
-v /opt/clickhouse/log:/var/log/clickhouse-server
-v /opt/clickhouse/data:/var/lib/clickhouse
yandex/clickhouse-server
แแ แจแแแฅแแแแ แแแแแชแแแแ แแแแ แแ แชแฎแ แแแ แแแกแจแ แแกแ:
CREATE TABLE
db.steps (`area` Int64, `when` DateTime64(1, 'Europe/Moscow') DEFAULT now64(), `zone` Int64, `person` Int64)
ENGINE = MergeTree() ORDER BY (area, zone, person) SETTINGS index_granularity = 8192
แแ แจแแแแแกแ แแแ แแแแแชแแแแแแ แจแแแแแแ แกแแ แแแขแแก แแแแแงแแแแแแ:
from time import time
from clickhouse_driver import Client
from random import random
client = Client('vm-12c2c34c-df68-4a98-b1e5-a4d1cef1acff.domain',
database='db',
password='secret')
max = 20
for r in range(0, 100000):
if r % 1000 == 0:
print("CNT: {}, TS: {}".format(r, time()))
data = [{
'area': 0,
'zone': 0,
'person': r
}]
while True:
if random() < 0.3:
break
data.append({
'area': 0,
'zone': int(random() * (max - 2)) + 1,
'person': r
})
data.append({
'area': 0,
'zone': max - 1,
'person': r
})
client.execute(
'INSERT INTO steps (area, zone, person) VALUES',
data
)
แแแก แจแแแแแ, แ แแช แฉแแแแ แแแแ แแแแแก แแแ แขแแแจแ, แจแแแกแแแ แแแแ แแ แฃแคแ แ แกแฌแ แแคแ แแงแ, แแแแ แ JanusGraph-แแกแแแแก.
แจแแแแแแแ แแ แ แแแแฎแแแแ JOIN-แแก แแแแแงแแแแแแ. A แฌแแ แขแแแแแแ B แฌแแ แขแแแจแ แแแแแกแแกแแแแแแ:
SELECT s1.person AS person,
s1.zone,
s1.when,
s2.zone,
s2.when
FROM
(SELECT *
FROM steps
WHERE (area = 0)
AND (zone = 0)) AS s1 ANY INNER JOIN
(SELECT *
FROM steps AS s2
WHERE (area = 0)
AND (zone = 19)) AS s2 USING person
WHERE s1.when <= s2.when
3 แฅแฃแแแก แแแกแแแแแแแ:
SELECT s3.person,
s1z,
s1w,
s2z,
s2w,
s3.zone,
s3.when
FROM
(SELECT s1.person AS person,
s1.zone AS s1z,
s1.when AS s1w,
s2.zone AS s2z,
s2.when AS s2w
FROM
(SELECT *
FROM steps
WHERE (area = 0)
AND (zone = 0)) AS s1 ANY INNER JOIN
(SELECT *
FROM steps AS s2
WHERE (area = 0)
AND (zone = 3)) AS s2 USING person
WHERE s1.when <= s2.when) p ANY INNER JOIN
(SELECT *
FROM steps
WHERE (area = 0)
AND (zone = 19)) AS s3 USING person
WHERE p.s2w <= s3.when
แแแแฎแแแแแแ, แ แ แแฅแแ แฃแแแ, แกแแแแแแ แกแแจแแแแแ แแแแแแงแฃแ แแแ; แ แแแแฃแ แ แแแแแงแแแแแแกแแแแก, แแฅแแแ แฃแแแ แจแแฅแแแแ แแ แแแ แแแฃแแ แแแแแ แแขแแ แแก แแฆแแแแแฃแแแแ. แแฃแแชแ, แแกแแแ แแฃแจแแแแแ แแ แกแฌแ แแคแแ แแฃแจแแแแแ. แแแ แแแแ แแ แแแแ แ แแแแฎแแแแ แกแ แฃแแแแแ 0.1 แฌแแแแ แแแแแแ แแ แแจแ. แแฅ แแ แแก แแแแฎแแแแแก แจแแกแ แฃแแแแแก แแ แแแก แแแแแแแแ count(*)-แแกแแแแก, แ แแแแแแช แแแแแก 3 แฅแฃแแแก:
SELECT count(*)
FROM
(
SELECT
s1.person AS person,
s1.zone AS s1z,
s1.when AS s1w,
s2.zone AS s2z,
s2.when AS s2w
FROM
(
SELECT *
FROM steps
WHERE (area = 0) AND (zone = 0)
) AS s1
ANY INNER JOIN
(
SELECT *
FROM steps AS s2
WHERE (area = 0) AND (zone = 3)
) AS s2 USING (person)
WHERE s1.when <= s2.when
) AS p
ANY INNER JOIN
(
SELECT *
FROM steps
WHERE (area = 0) AND (zone = 19)
) AS s3 USING (person)
WHERE p.s2w <= s3.when
โโcount()โโ
โ 11592 โ
โโโโโโโโโโโ
1 rows in set. Elapsed: 0.068 sec. Processed 250.03 thousand rows, 8.00 MB (3.69 million rows/s., 117.98 MB/s.)
แจแแแแจแแแ IOPS-แแก แจแแกแแฎแแ. แแแแแชแแแแแแก แแแกแแฎแแแแแกแแก, JanusGraph-แแ แจแแฅแแแ IOPS-แแก แกแแแแแแ แแแฆแแแ แ แแแแแแแแ (1000-1300 แแแแแชแแแแ แแแแฃแแแชแแแก แแแฎแ แซแแคแแกแแแแก) แแ IOWAIT แกแแแแแแ แแแฆแแแ แแงแ. แแแแแแ แแฃแแแ, ClickHouse-แแ แฌแแ แแแฅแแแ แแแแแแแแฃแ แ แแแขแแแ แแแ แแแกแแแก แฅแแแกแแกแขแแแแแ.
แแแกแแแแ
แฉแแแ แแแแแแฌแงแแแขแแ แแแแแแแงแแแแ ClickHouse แแ แขแแแแก แแแแฎแแแแแก แแแกแแแกแแฎแฃแ แแแแแ. แฉแแแ แงแแแแแแแแก แจแแแแแซแแแ แแแแฎแแแแแแแก แจแแแแแแแ แแแขแแแแแแชแแ แแแขแแ แแแแแแแแฃแแ แฎแแแแแแกแ แแ แแแ แแแแแแแแแแก แแแแแงแแแแแแ แฆแแแแกแซแแแแแก แแแแแแแก แฌแแแแกแฌแแ แ แแแแฃแจแแแแแแ Apache Flink-แแก แแแแแงแแแแแแ, แกแแแแ แแแ ClickHouse-แจแ แฉแแขแแแ แแแแ.
แจแแกแ แฃแแแแ แแแแแแแ แแแ แแแ, แ แแ แชแฎแ แแแแแแก แแ แแแ แแแฃแแแ แแแแแฎแแแแแแ แคแแฅแ แแช แแ แแแแแแฌแแแก. แแแ แ แฉแแแ แฃแแแ แแแแแแแแแแแแแ แแแ แขแแแแแแ แแแแฆแแแฃแแ แแแแแชแแแแแแก แแ แแแฃแแ Apache Parket-แแ แแขแแแ แแแแก แแแแ.
แกแแแฌแฃแฎแแ แแ, แแ แแคแแแแก DBMS-แแก แแแแแงแแแแแแก แแแแแ แแ แแ แแชแแแแแแ แฌแแ แฃแแแขแแแแแ แแฆแแแฉแแแ. แแ แแแ แแแแแแ JanusGraph-แก แแกแแแ แแแแแแ แฃแแ แแแแกแแกแขแแแ, แ แแแแแแช แแแแ แขแแแแแก แแ แแแฃแฅแขแแก แกแแกแฌแ แแคแแก. แแแแแแ แแฃแแแ, แกแแ แแแ แแก แแแแคแแแฃแ แแชแแแกแแแแก แแแแแแงแแแแแ แฏแแแแก แขแ แแแแชแแฃแแ แแแ, แ แแแแแแช แแแซแฃแแแแก แฎแแแฎแก, แแแแช แฏแแแแก แแ แแชแแแแก, แกแแกแฎแแแก แชแ แแแแแแแ แแขแแ แแแก:
host: 0.0.0.0
port: 8182
threadPoolWorker: 1
gremlinPool: 8
scriptEvaluationTimeout: 30000
channelizer: org.janusgraph.channelizers.JanusGraphWsAndHttpChannelizer
graphManager: org.janusgraph.graphdb.management.JanusGraphManager
graphs: {
ConfigurationManagementGraph: conf/janusgraph-cql-configurationgraph.properties,
airlines: conf/airlines.properties
}
scriptEngines: {
gremlin-groovy: {
plugins: { org.janusgraph.graphdb.tinkerpop.plugin.JanusGraphGremlinPlugin: {},
org.apache.tinkerpop.gremlin.server.jsr223.GremlinServerGremlinPlugin: {},
org.apache.tinkerpop.gremlin.tinkergraph.jsr223.TinkerGraphGremlinPlugin: {},
org.apache.tinkerpop.gremlin.jsr223.ImportGremlinPlugin: {classImports: [java.lang.Math], methodImports: [java.lang.Math#*]},
org.apache.tinkerpop.gremlin.jsr223.ScriptFileGremlinPlugin: {files: [scripts/airline-sample.groovy]}}}}
serializers:
# GraphBinary is here to replace Gryo and Graphson
- { className: org.apache.tinkerpop.gremlin.driver.ser.GraphBinaryMessageSerializerV1, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistry] }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GraphBinaryMessageSerializerV1, config: { serializeResultToString: true }}
# Gryo and Graphson, latest versions
- { className: org.apache.tinkerpop.gremlin.driver.ser.GryoMessageSerializerV3d0, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistry] }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GryoMessageSerializerV3d0, config: { serializeResultToString: true }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GraphSONMessageSerializerV3d0, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistry] }}
# Older serialization versions for backwards compatibility:
- { className: org.apache.tinkerpop.gremlin.driver.ser.GryoMessageSerializerV1d0, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistry] }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GryoMessageSerializerV1d0, config: { serializeResultToString: true }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GryoLiteMessageSerializerV1d0, config: {ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistry] }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GraphSONMessageSerializerGremlinV2d0, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistry] }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GraphSONMessageSerializerGremlinV1d0, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistryV1d0] }}
- { className: org.apache.tinkerpop.gremlin.driver.ser.GraphSONMessageSerializerV1d0, config: { ioRegistries: [org.janusgraph.graphdb.tinkerpop.JanusGraphIoRegistryV1d0] }}
processors:
- { className: org.apache.tinkerpop.gremlin.server.op.session.SessionOpProcessor, config: { sessionTimeout: 28800000 }}
- { className: org.apache.tinkerpop.gremlin.server.op.traversal.TraversalOpProcessor, config: { cacheExpirationTime: 600000, cacheMaxSize: 1000 }}
metrics: {
consoleReporter: {enabled: false, interval: 180000},
csvReporter: {enabled: false, interval: 180000, fileName: /tmp/gremlin-server-metrics.csv},
jmxReporter: {enabled: false},
slf4jReporter: {enabled: true, interval: 180000},
gangliaReporter: {enabled: false, interval: 180000, addressingMode: MULTICAST},
graphiteReporter: {enabled: false, interval: 180000}}
threadPoolBoss: 1
maxInitialLineLength: 4096
maxHeaderSize: 8192
maxChunkSize: 8192
maxContentLength: 65536
maxAccumulationBufferComponents: 1024
resultIterationBatchSize: 64
writeBufferHighWaterMark: 32768
writeBufferHighWaterMark: 65536
ssl: {
enabled: false}
แจแแแแฎแแแแแ แแแแแฎแแ แฎแ JanusGraph-แแก BerkeleyDB แแแ แกแแแก โแแแแแแโ.
แแแแฃแแแแขแแชแแ แแแแแฅแกแแแแก แแแแแกแแแ แแกแแ แกแแแแแแ แแ แฃแแแ, แ แแแแแ แแแแแฅแกแแแแก แแแ แแแ แแแแแฎแแแก แแฅแแแแแแ แจแแแกแ แฃแแแ แกแแแแแแ แฃแชแแแฃแ แ แจแแแแแแแแ Groovy-แจแ. แแแแแแแแแ, แแแแแฅแกแแก แจแแฅแแแ แฃแแแ แแแฎแแแก Gremlin-แแก แแแแกแแแจแ แแแแแก แฉแแฌแแ แแ (แ แแช, แกแฎแแแแ แจแแ แแก, แแ แแแแแแแแแ). JanusGraph-แแก แแคแแชแแแแฃแ แ แแแแฃแแแแขแแชแแแแแ:
graph.tx().rollback() //Never create new indexes while a transaction is active
mgmt = graph.openManagement()
name = mgmt.getPropertyKey('name')
age = mgmt.getPropertyKey('age')
mgmt.buildIndex('byNameComposite', Vertex.class).addKey(name).buildCompositeIndex()
mgmt.buildIndex('byNameAndAgeComposite', Vertex.class).addKey(name).addKey(age).buildCompositeIndex()
mgmt.commit()
//Wait for the index to become available
ManagementSystem.awaitGraphIndexStatus(graph, 'byNameComposite').call()
ManagementSystem.awaitGraphIndexStatus(graph, 'byNameAndAgeComposite').call()
//Reindex the existing data
mgmt = graph.openManagement()
mgmt.updateIndex(mgmt.getGraphIndex("byNameComposite"), SchemaAction.REINDEX).get()
mgmt.updateIndex(mgmt.getGraphIndex("byNameAndAgeComposite"), SchemaAction.REINDEX).get()
mgmt.commit()
Afterword
แแแ แแแแฃแแ แแแแแแแ, แแแแแแฆแแแจแแฃแแ แแฅแกแแแ แแแแแขแ แแ แแก แจแแแแ แแแ แแแแแกแ แแ แ แแแแก แจแแ แแก. แแฃ แแแแแ แคแแฅแ แแแ, แแ แแคแแแฃแแ DBMS แแกแ แฃแแแแก แกแฎแแ แแแแ แแชแแแแก แแแแแ แจแแแแแแแแก แแแกแแฆแแแแ. แแฃแแชแ, แ แแแแ แช แขแแกแขแแแแก แแแฌแแแ, แแ แแกแแแ แฉแแแแขแแ แ แแฅแกแแแ แแแแแขแ แแฎแแแแแ, แ แแแแ แแชแแ:
g.V().hasLabel('ZoneStep').has('id',0)
.repeat(__.out().simplePath()).until(__.hasLabel('ZoneStep').has('id',1)).count().next()
แ แแแแแแช แแกแแฎแแแก แคแแฎแแ แแแกแแแ แฃแแ แแแแซแแแก. แแฃแแชแ, แแกแแ แแแแแชแแแแแแแช แแ, แแ แแคแแแแ DBMS แแฉแแแแ แจแแแแแแแ, แ แแแแแแแช แ แแแแแแแแ แฌแแแก แกแชแแแแแแ... แแก, แ แ แแฅแแ แฃแแแ, แแแแแแ แแแแแฃแแแ แแแแ, แ แแ แแงแ แแแแแแแแ, แ แแแแ แแชแแ 0 -> X -> Y ... -> 1
, แ แแแแแแช แแ แแคแแแแก แซแ แแแแแช แจแแแแแฌแแ.
แแฃแแแแช แแกแแแ แจแแแแแฎแแแกแแแแก, แ แแแแ แแชแแ:
g.V().hasLabel('ZoneStep').has('id',0).out().has('id',1)).count().next()
แแ แแแ แแแแแฆแ แแ แแแฃแฅแขแแฃแแ แแแกแฃแฎแ แฌแแแแ แแแแแแแ แแแแฃแจแแแแแแก แแ แแแ.
แกแแฃแแแขแแก แแแ แแแ แแก แแ แแก, แ แแ แแแแแแ แแแแ แแ แแแ แแแแแแแขแฃแ แ แแแแแแแ แแแ แแ แแฌแแแแก แกแแกแฃแ แแแ แจแแแแแก, แ แแช แแแชแแแแแแ แแแฆแแแ แแคแแฅแขแฃแ แแแแ แแ แแก แแแฉแแแแแแ ClickHouse-แแก แแแแแแแแแ. แแ แกแขแแขแแแจแ แฌแแ แแแแแแแแแ แแแแแงแแแแแแก แจแแแแฎแแแแ แแจแแแ แ แแแขแ-แแแแฃแจแแ แแ แแคแแแฃแแ DBMS-แแแแกแแแแก, แแฃแแชแ, แ แแแแ แช แฉแแแก, แจแแกแแคแแ แแกแแ แแแแ แแแ แแแแแแแก แแแแแแแ แแแแกแแแแก.
แฌแงแแ แ: www.habr.com