本文主要是介绍图数据库-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非关系型数据库⎩⎪⎪⎪⎪⎪⎪⎨⎪⎪⎪⎪⎪⎪⎧键值存储型{RedisMemcached文档存储型:MongoDB、CouchDB列存储型:HBase、Cassandra图形数据库:Neo4j、FlockDB
一、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的文件路径:
- Neo4j安装目录为:/usr/share/neo4j
- Neo4j的属性文件所在目录为: /etc/neo4j
- 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(一):安装、启动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!