图数据库-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

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

springboot3打包成war包,用tomcat8启动

1、在pom中,将打包类型改为war <packaging>war</packaging> 2、pom中排除SpringBoot内置的Tomcat容器并添加Tomcat依赖,用于编译和测试,         *依赖时一定设置 scope 为 provided (相当于 tomcat 依赖只在本地运行和测试的时候有效,         打包的时候会排除这个依赖)<scope>provided

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M