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

相关文章

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

LinuxMint怎么安装? Linux Mint22下载安装图文教程

《LinuxMint怎么安装?LinuxMint22下载安装图文教程》LinuxMint22发布以后,有很多新功能,很多朋友想要下载并安装,该怎么操作呢?下面我们就来看看详细安装指南... linux Mint 是一款基于 Ubuntu 的流行发行版,凭借其现代、精致、易于使用的特性,深受小伙伴们所喜爱。对