图数据库-Neo4j(一):安装、启动

2024-09-02 03:32
文章标签 安装 启动 数据库 neo4j

本文主要是介绍图数据库-Neo4j(一):安装、启动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数 据 库 { 关 系 型 数 据 库 { M y s q l O r a c l e S Q L S e r v e r D B 2 非 关 系 型 数 据 库 { 键 值 存 储 型 { R e d i s M e m c a c h e d 文 档 存 储 型 : M o n g o D B 、 C o u c h D B 列 存 储 型 : H B a s e 、 C a s s a n d r a 图 形 数 据 库 : N e o 4 j 、 F l o c k D B \begin{aligned} 数据库 \begin{cases} 关系型数据库 \begin{cases} Mysql\\ Oracle\\ SQL Server\\ DB2 \end{cases} \\ 非关系型数据库 \begin{cases} 键值存储型 \begin{cases} Redis\\ Memcached \end{cases} \\ 文档存储型:MongoDB、CouchDB\\ 列存储型:HBase、Cassandra\\ 图形数据库:Neo4j、FlockDB \end{cases} \end{cases} \end{aligned} MysqlOracleSQLServerDB2{RedisMemcachedMongoDBCouchDBHBaseCassandraNeo4jFlockDB

一、Neo4j简介

在这里插入图片描述

neo4j是由Java实现的开源NoSQL图数据库.自从2003年开始研发, 到2007年发布第一版, 最新版本为3.3.5, neo4j现如今已经被各行各业的数十万家公司和组织采用.

neo4j实现了专业数据库级别的图数据模型的存储. 与普通的图处理或内存级数据库不同, neo4j提供了完整的数据库特性, 包括ACID事物的支持, 集群支持, 备份与故障转移等. 这使其适合于企业级生产环境下的各种应用.

案例展示:红楼梦人物关系图

在这里插入图片描述

Neo4j W3C教程:Neo4j–W3CSchool教程

neo4j的版本说明:

  • 企业版: 需要高额的付费获得授权, 提供高可用, 热备份等性能.
  • 社区开源版: 免费使用, 但只能单点运行.

neo4j图形数据库的有关概念:

在这里插入图片描述

节点

  • 节点是主要的数据元素, 节点通过关系连接到其他节点, 节点可以具有一个或多个属性
  • (即存储为键/值对的属性), 节点有一个或多个标签, 用于描述其在图表中的作用. 示例: Person>节点.
  • 可以将节点类比为关系型数据库中的表, 对应的标签可以类比为不同的表名, 属性就是表中的列.

关系

  • 关系连接两个节点, 关系是方向性的, 关系可以有一个或多个属性(即存储为键/值对的属性

属性

  • 属性是命名值, 其中名称(或键)是字符串, 属性可以被索引和约束, 可以从多个属性创
  • 建复合索引.

标签

  • 标签用于组节点到集, 节点可以具有多个标签, 对标签进行索引以加速在图中查找节点.

二、Neo4j安装:方式二(CentOS7)

1、下载安装包(社区版免费)

liunx环境Neo4j下载地址:https://neo4j.com/download/other-releases/#releases
在这里插入图片描述
或者直接在服务器上使用命令下载:

curl -O http://dist.neo4j.org/neo4j-community-3.4.5-unix.tar.gz

2、解压安装包

tar -axvf neo4j-community-3.4.5-unix.tar.gz
在这里插入图片描述
解压后要将解压后的目录文件的所有者改为 root,否则会报错。

3、修改配置

默认在/**/neo4j/neo4j.conf, 为了方便显示下面把一些修改显示在这里

  • 允许远程访问
    dbms.connectors.default_listen_address=0.0.0.0
  • 开启bolt服务,默认端口7687
    dbms.connector.bolt.listen_address=:7687
  • 开启http服务,默认端口7474
    dbms.connector.http.listen_address=:7474
  • 开启https服务,默认端口7473
    dbms.connector.https.listen_address=:7473
# With default configuration Neo4j only accepts local connections.
# To accept non-local connections, uncomment this line:
dbms.default_listen_address=0.0.0.0# Bolt connector
dbms.connector.bolt.enabled=true
dbms.connector.bolt.tls_level=OPTIONAL
dbms.connector.bolt.listen_address=:7687
dbms.connector.bolt.advertised_address=:7687# HTTP Connector. There can be zero or one HTTP connectors.
dbms.connector.http.enabled=true
dbms.connector.http.listen_address=:7474
#dbms.connector.http.advertised_address=:7474# HTTPS Connector. There can be zero or one HTTPS connectors.
dbms.connector.https.enabled=false
dbms.connector.https.listen_address=:7473
#dbms.connector.https.advertised_address=:7473

4、第五步:启动neo4j数据库

启动图数据库并查看状态
neo4j start
neo4j status

终端显示如下, 代表启动成功

[root@iZm5e9phbzdxx0lysrv9t2Z bin]# ./neo4j start
Directories in use:
home:         /usr/neo4j/neo4j-community-4.4.5
config:       /usr/neo4j/neo4j-community-4.4.5/conf
logs:         /usr/neo4j/neo4j-community-4.4.5/logs
plugins:      /usr/neo4j/neo4j-community-4.4.5/plugins
import:       /usr/neo4j/neo4j-community-4.4.5/import
data:         /usr/neo4j/neo4j-community-4.4.5/data
certificates: /usr/neo4j/neo4j-community-4.4.5/certificates
licenses:     /usr/neo4j/neo4j-community-4.4.5/licenses
run:          /usr/neo4j/neo4j-community-4.4.5/run
Starting Neo4j.
Started neo4j (pid:2447). It is available at http://0.0.0.0:7474
There may be a short delay until the server is ready.
[root@iZm5e9phbzdxx0lysrv9t2Z bin]# 

5、开放端口防火墙

neo4j.conf文件中:

dbms.connector.bolt.address=0.0.0.0:7687     
dbms.connector.http.address=0.0.0.0:7474   

开放防火墙相应的端口

firewall-cmd --zone=public --permanent --add-port=7474/tcp
firewall-cmd --zone=public --permanent --add-port=7687/tcp
firewall-cmd --reload #一定不要忘记这句话
firewall-cmd --list-ports # 查看端口是否打开成功
(base) [root@whx ~]# firewall-cmd --list-ports
20/tcp 21/tcp 22/tcp 80/tcp 8888/tcp 39000-40000/tcp 888/tcp 7474/tcp 7687/tcp
(base) [root@whx ~]# 

如果是部署在阿里云等服务器,需要开放相应安全组端口。
在这里插入图片描述

6、远程访问Neo4j的可视化界面x.x.x.x:7474/browser

在你的浏览器中地址栏输入:http://<服务器ip地址>:7474/browser/,即可看到
在这里插入图片描述

三、Neo4j安装:方式一(CentOS6.8)

neo4j图数据库依赖于Java,所以要先按照Jdk

neo4j图数据库的安装流程:

  • 第一步: 将neo4j安装信息载入到yum检索列表.
  • 第二步: 使用yum install命令安装.
  • 第三步: 修改配置文件内容 /etc/neo4j/neo4j.conf.
  • 第四步: 启动neo4j数据库.

1、第一步: 将neo4j安装信息载入到yum检索列表

对于CentOS系统(6.8)安装Neo4j,需要手动安装Yum源

(base) [root@whx ~]# cd /tmp
(base) [root@whx tmp]# wget http://debian.neo4j.org/neotechnology.gpg.key
(base) [root@whx tmp]# sudo rpm --import neotechnology.gpg.key
  • 其中cd /tmp 为导航到系统tmp目录下;
  • 然后使用wget命令将安装配置文件neotechnology.gpg.key下载到当前目录;、
  • 再使用sudo rpm --import neotechnology.gpg.key命令将安装配置文件导入到系统中。

2、第二步: 文本编辑器创建一个/etc/yum.repos.d/neo4j.repo内容:

(base) [root@whx ~]# vim /etc/yum.repos.d/neo4j.repo
[neo4j] 
name=Neo4j RPM Repository
baseurl=http://yum.neo4j.org/stable
enabled=1
gpgcheck=1

3、第三步: 我们就可以使用yum命令安装neo4j。

yum install neo4j-3.3.5

至此在CentOS系统下Neo4j已安装完毕。下面是安装后Neo4j的文件路径:

  1. Neo4j安装目录为:/usr/share/neo4j
  2. Neo4j的属性文件所在目录为: /etc/neo4j
  3. Neo4j默认的数据库文件保存目录为: /var/lib/neo4j

我们导航到/usr/share/neo4j/bin 运行目录下,运行:neo4j start命令就可以启动neo4j数据库了。

4、第四步:修改配置文件

默认在/etc/neo4j/neo4j.conf, 为了方便显示下面把一些修改显示在这里

# 数据库的存储库存储位置、日志位置等
dbms.directories.data=/var/lib/neo4j/data
dbms.directories.plugins=/var/lib/neo4j/plugins
dbms.directories.certificates=/var/lib/neo4j/certificates
dbms.directories.logs=/var/log/neo4j
dbms.directories.lib=/usr/share/neo4j/lib
dbms.directories.run=/var/run/neo4j# 导入的位置
dbms.directories.import=/var/lib/neo4j/import# 初始化内存大小
dbms.memory.heap.initial_size=512m# Bolt 连接地址
dbms.connector.bolt.enabled=true
dbms.connector.bolt.tls_level=OPTIONAL
dbms.connector.bolt.listen_address=0.0.0.0:7687

5、第五步:启动neo4j数据库

启动图数据库并查看状态
neo4j start
neo4j status

终端显示如下, 代表启动成功

(base) [root@whx ~]# neo4j start
Active database: graph.db
Directories in use:home:         /var/lib/neo4jconfig:       /etc/neo4jlogs:         /var/log/neo4j/plugins:      /var/lib/neo4j/pluginsimport:       /var/neo4j/importdata:         /var/lib/neo4j/datacertificates: /var/lib/neo4j/certificatesrun:          /var/run/neo4j
Starting Neo4j.
Started neo4j (pid 5246). It is available at http://0.0.0.0:7474/
There may be a short delay until the server is ready.
See /var/log/neo4j//neo4j.log for current status.
(base) [root@whx ~]# neo4j status
Neo4j is running at pid 5246
(base) [root@whx ~]# 

6、远程访问Neo4j的可视化界面x.x.x.x:7474/browser

neo4j.conf文件中:

dbms.connector.bolt.address=0.0.0.0:7687     
dbms.connector.http.address=0.0.0.0:7474   

开放防火墙相应的端口

firewall-cmd --zone=public --permanent --add-port=7474/tcp
firewall-cmd --zone=public --permanent --add-port=7687/tcp
firewall-cmd --reload #一定不要忘记这句话
firewall-cmd --list-ports # 查看端口是否打开成功
(base) [root@whx ~]# firewall-cmd --list-ports
20/tcp 21/tcp 22/tcp 80/tcp 8888/tcp 39000-40000/tcp 888/tcp 7474/tcp 7687/tcp
(base) [root@whx ~]# 

在你的浏览器中地址栏输入:http://<服务器ip地址>:7474/browser/,即可看到
在这里插入图片描述

7、第六步: neo4j的可视化管理后台登陆:

  • 访问地址: http://0.0.0.0:7474
  • ConnectURL: bolt://0.0.0.0:7687
  • Username: neo4j
  • Password: neo4j (默认)

在这里插入图片描述

四、常用命令

1、查看版本号

call dbms.components() yield name, versions, edition unwind versions as version return name, version, edition;

在这里插入图片描述

六、Neo4j常见问题

1、如果浏览器端已经打开了Neo4j可视化界面,则在服务器端启动Neo4j时报错

Store and its lock file has been locked by another process: /var/lib/neo4j/data/databases/graph.db/store_lock

Starting Neo4j failed: Component ‘org.neo4j.server.database.LifecycleManagingDatabase@1458ed9c’ was successfully initialized, but failed to start. Please see the attached cause exception “Externally locked: /var/lib/neo4j/data/databases/graph.db/neostore”.




参考资料:
【数据库】linux安装neo4j教程(neo4j 4.x)

这篇关于图数据库-Neo4j(一):安装、启动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128869

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优