图数据库-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/neo4j
  config:       /etc/neo4j
  logs:         /var/log/neo4j/
  plugins:      /var/lib/neo4j/plugins
  import:       /var/neo4j/import
  data:         /var/lib/neo4j/data
  certificates: /var/lib/neo4j/certificates
  run:          /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)

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值