【云原生专题】基于Docker+Neo4j图数据库搭建企业级分布式应用拓扑图_neo4j分布式(1)

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

系统名称类型首次部署时间系统负责人
订单系统Java2020-1-1jack
商品系统Python2021-5-1mason
淘宝商城APP2021-6-1peter
闲鱼小程序(MinPro)2021-8-1steve
商家管理平台Web2021-9-1lisa
中台MQMQ2020-9-1jane
每日精选公众号(Public)2021-4-25lucy

这些系统中,订单系统和商品系统属于中台后端应用,淘宝、咸鱼、每日精选都是前端面向客户的应用,它们都调用中台的后端应用,商家管理平台是内网供作业人员使用的Web应用,也是调用的中台数据,中台每隔5分钟会推送热点商品数据通过MQ给到每日精选。

上面的关系描述不够直观,系统一旦多了,就可能乱的不行,所以我们需要通过图数据库来描述相互之间的关系。

下面,我们就可以基于如上梳理的关系,进行节点和关系的操作了。在操作之前,我们需要清理一下数据库中的内容,防止产生干扰。

MATCH (n) DETACH DELETE n;

3.2 系统节点的CRUD
  • 增加节点
CREATE (n:Java {name:'订单系统',firstDeploy:'2020-1-1',leader:'jack'});
CREATE (n:Java {name:'商品系统',firstDeploy:'2021-5-1',leader:'mason'});
CREATE (n:App {name:'淘宝商城',firstDeploy:'2021-6-1',leader:'peter'});
CREATE (n:MinPro {name:'闲鱼',firstDeploy:'2021-8-1',leader:'steve'});
CREATE (n:Web {name:'商家管理平台',firstDeploy:'2021-9-1',leader:'lisa'});
CREATE (n:MQ {name:'中台MQ',firstDeploy:'2020-9-1',leader:'jane'});
CREATE (n:Public {name:'每日精选',firstDeploy:'2021-4-25',leader:'lucy'});

执行后,我们执行查询语句:

MATCH (n) RETURN n

得到的图如下:

img

创建系统节点

  • 删除节点
MATCH (n) WHERE n.name='闲鱼' DELETE n;
// 等价于
MATCH (n:MinPro{name:'闲鱼'}) DELETE n;

  • 删除节点的属性
MATCH (n) WHERE n.name='闲鱼' REMOVE n.leader;
// 等价于
MATCH (n:MinPro{name:'闲鱼'}) REMOVE n.leader;

  • 查询节点
// 根据节点的属性进行查询(更接近SQL语法,推荐)
MATCH (n) WHERE n.name='闲鱼' RETURN n;
// 等价查询语句如下,增加了节点的类型MinPro,查询结果更加准确
MATCH (n:MinPro{name:'闲鱼'}) RETURN n;

  • 修改/新增节点属性
MATCH (n) WHERE n.name='闲鱼' SET n.leader='steve';

3.3 系统关系的CRUD
  • 新增/修改关系(属性)
MATCH (a),(b) where a.name='闲鱼' AND b.name='商品系统' MERGE (a)-[:invoke]->(b) RETURN a,b;
MATCH (a:MinPro{name:'闲鱼'}),(b:Java{name:'订单系统'}) MERGE (a)-[:invoke]->(b) RETURN a,b;
MATCH (a),(b) where a.name='淘宝商城' AND b.name='商品系统' CREATE (a)-[:invoke]->(b) RETURN a,b; 
MATCH (a),(b) where a.name='淘宝商城' AND b.name='订单系统' CREATE (a)-[:invoke]->(b) RETURN a,b;   
MATCH (a),(b) where a.name='商品系统' AND b.name='中台MQ' CREATE (a)-[:produce]->(b) RETURN a,b; 
MATCH (a),(b) where a.name='每日精选' AND b.name='中台MQ' CREATE (a)-[:consume]->(b) RETURN a,b; 
// 也可以对关系增加属性
// MERGE语句会覆盖现有的关系,达到更新关系及其属性的目的
MATCH (a),(b) where a.name='商家管理平台' AND b.name='订单系统' MERGE (a)-[:invoke{since:2021-1-1}]->(b) RETURN a,b; 

然后执行查询语句:

MATCH (n) RETURN n

得到的图如下:

img

增加系统间的关系

  • 删除关系
MATCH (a)-[r:consume]->(b) WHERE a.name='每日精选' AND b.name='中台MQ' DELETE r;

  • 删除关系属性
MATCH (a)-[r:invoke]->(b) WHERE a.name='商家管理平台' AND b.name='订单系统' REMOVE r.since;

  • 增加/更新关系属性

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

😕/bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值