Linux下图形数据库Neo4j单机安装

简介: Neo4j数据库简介   Neo4j 是一个NoSQL的图形数据库(Graph Database)。Neo4j使用图(graph)相关的概念来描述数据模型,把数据保存为图中的节点以及节点之间的关系。

Neo4j数据库简介

 

Neo4j 是一个NoSQL的图形数据库(Graph Database)。Neo4j使用图(graph)相关的概念来描述数据模型,把数据保存为图中的节点以及节点之间的关系。很多应用中数据之间的关系,可以很直接地使用图中节点和关系的概念来建模。对于这样的应用,使用 Neo4j 来存储数据会非常的自然,要优于使用关系数据库。官方文档对Neo4j的介绍如下所示:

 

Neo4j is the world’s leading graph database. It is built from the ground up to be a graph database,

meaning that its architecture is designed for optimizing fast management, storage, and traversal of

nodes and relationships. Therefore, relationships are said to be first class citizens in Neo4j. An

operation known in the relational database world as a join exhibits performance which degrades

exponentially with the number of relationships. The corresponding action in Neo4j is performed as

navigation from one node to another; an operation whose performance is linear.

 

Neo4j分社区版(Community Edition)和企业版(Enterprise Edition),社区版本为免费版本。目前的最新版本为Neo4j 3.1。官方网址为https://neo4j.com/ Neo4j的相关文档URL地址如下

https://neo4j.com/docs/developer-manual/3.1/

https://neo4j.com/docs/operations-manual/3.1/

https://neo4j.com/docs/developer-manual/3.1/cypher/

 

System requirements

 

Neo4j的安装对硬件、系统等有一些要求,例如CPU、Memory、Disk、Filesystem、Software等

 

CPU

关于CPU,最低要求是Itel Core i3 推荐使用Intel Core i7 或 IBM POWER 8

 

Memory

关于Memory,最低要求是2GB, 推荐是16-32GB 或更多。 越大的内存允许处理越大的图,但必须正确配置,以免破垃圾收集坏性操作。

 

Disk

除了Disk的容量,Disk的性能对Neoj4的影响非常大,Neo4j的工作负载倾向于随机读。选择平均寻址时间低的存储,例如SSD

最低要求 10GB SATA

推荐配置 SSD w/SATA

 

FileSystem

最低要求 ext4(或类似的)

推荐配置 ext4、ZFS

 

Software

Java

必须安装OpenJDK 8 或 Oracle Java 8

 

Operation Sytem

Linux(Ubuntu, Debian) ,但是我的测试环境为Red Hat Enterprise Linux Server release 6.6,暂时还没有发现什么问题。

Architectures

X86 或 OpenPower(POWER8)

 

Neo4j安装步骤:

 

下面简单介绍Linux下Neo4j 3.1的安装步骤,安装测试环境为Red Hat Enterprise Linux Server release 6.6, Debian下安装具体参考文档,这里不做介绍。

1:下载Neo4j 3.1的安装包,去官方网址注册下载即可。选择特定的版本。下载地址 https://neo4j.com/download/

2:检查上面System Requirement,安装JDK 8

[root@gettestlnx03 ~]# rpm -qa | grep gcj
libgcj-devel-4.4.7-11.el6.x86_64
libgcj-4.4.7-11.el6.x86_64
java-1.5.0-gcj-1.5.0.0-29.1.el6.x86_64
[root@gettestlnx03 ~]# rpm -ivh /tmp/jdk-8u121-linux-x64.rpm 
Preparing...                ########################################### [100%]
   1:jdk1.8.0_121           ########################################### [100%]
Unpacking JAR files...
        tools.jar...
        plugin.jar...
        javaws.jar...
        deploy.jar...
        rt.jar...
        jsse.jar...
        charsets.jar...
        localedata.jar...
 
[root@gettestlnx03 ~]# java -version
java version "1.8.0_121"
Java(TM) SE Runtime Environment (build 1.8.0_121-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.121-b13, mixed mode)
[root@gettestlnx03 ~]# 

编辑/etc/profile文件,添加下面配置信息,然后执行source /etc/profile命令使之生效。

export JAVA_HOME=/usr/java/jdk1.8.0_121/
 
export CLASSPATH=/usr/java/jdk1.8.0_121/lib
 
export PATH=$AVA_HOME/bin:$PATH

 

3:创建一个用户neo4j,用来管理Neo4j 。当然这不是必须的。也可以是其它账号或root账号。

[root@gettestlnx03 ~]# /usr/sbin/groupadd nosql
 
[root@gettestlnx03 ~]# /usr/sbin/useradd -G nosql neo4j

 

4:然后切换到neo4j账户下,解压neo4j-community-3.1.1-unix.tar.gz包

[root@gettestlnx03 ~]# su - neo4j
 
[neo4j@gettestlnx03 ~]$ tar -zxvf /tmp/neo4j-community-3.1.1-unix.tar.gz -C /home/neo4j/

 

配置.bash_profile文件,增加下面一行,并使之生效。

[root@gettestlnx03 neo4j]# su - neo4j
 
[neo4j@gettestlnx03 ~]$ vi .bash_profile 
 
export PATH=/home/neo4j/neo4j-community-3.1.1/bin:$PATH #新增一行
 
[neo4j@gettestlnx03 ~]$ source .bash_profile 

另外,修改配置文件/etc/security/limits.conf ,增加下面配置。

 
neo4j  soft   nofile  40000
neo4j  hard   nofile  40000

The usual default of 1024 is often not enough. This is especially true when many indexes are used or a

server installation sees too many connections. Network sockets count against the limit as well. Users

are therefore encouraged to increase the limit to a healthy value of 40 000 or more, depending on

usage patterns. It is possible to set the limit with the ulimit command, but only for the root user, and

it only affects the current session. To set the value system wide, follow the instructions for your

platform.

编辑/etc/pam.d/su 在配置文件里面增加选项。

session optional pam_xauth.so

 

Neo4j服务关闭启动

 

Neo4j服务的启动、关闭如下所示

[neo4j@gettestlnx03 ~]$ neo4j  start
Starting Neo4j.
Started neo4j (pid 2605). By default, it is available at http://localhost:7474/
There may be a short delay until the server is ready.
See /home/neo4j/neo4j-community-3.1.1/logs/neo4j.log for current status.
[neo4j@gettestlnx03 ~]$ neo4j  status
Neo4j is running at pid 2605
[neo4j@gettestlnx03 ~]$ neo4j  stop
Stopping Neo4j.. stopped
[neo4j@gettestlnx03 ~]$ 

 

如果不设置Neo4j的配置文件,只能从本机访问Neo4J的web控制台(http://localhost:7474/) Neo4j的控制文件一般位于<neo4jhome>/conf/neo4j.conf,例如我测试环境为/home/neo4j/neo4j-community-3.1.1/conf

Neo4j的配置文件将单独再做详细介绍。如果我们需要远程访问Neo4j的Web控制台,我们需要修改neo4j.conf配置文件的参数,如下截图所示:

当然,还需要配置iptables,开放7474端口号,否则你还是无法远程访问Web控制台。

-A INPUT -p tcp -m state --state NEW -m tcp --dport 7474 -j ACCEPT

然后你就可以从远程http://xxx.xxx.xxx.xxx:7474 访问Neo4j的Web控制台了, 第一次登陆会提示你输入初始化密码并提醒你修改密码。默认的密码为neo4j. 如果允许远程访问,切记修改初始化密码。安全非常重要。

 

简单的测试案例

我们先创建一个简单的父子关系图。用来简单演示一下图形数据库的使用。如下所示。

[neo4j@gettestlnx03 bin]$ ./cypher-shell 
username: neo4j
password: **********
Connected to Neo4j 3.1.1 at bolt://localhost:7687 as user neo4j.
Type :help for a list of available commands or :exit to exit the shell.
Note that Cypher queries must end with a semicolon.
neo4j> CREATE (A {id:1,name:'张飞'}), (B {id:2,name:'张小二'}), (C {id:3,name:'张三'}), (D {id:4,name:'张凯'}),(E {id:5,name:'张雨'}),(A)-[:Son]->(B),(A)-[:Son]->(C),(B)-[:Son]->(D),(C)-[:Son]->(E); 
Added 5 nodes, Created 4 relationships, Set 10 properties
neo4j> START n=node(*) RETURN n;
n
({name: "张飞", id: 1})
({name: "张小二", id: 2})
({name: "张三", id: 3})
({name: "张凯", id: 4})
({name: "张雨", id: 5})
neo4j> 
image

 

如果你在Web控制台执行命令,就能得到如下一个图形关系。如下所示。

 

 

参考资料:

https://neo4j.com/docs/developer-manual/3.1/

相关文章
|
19小时前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
34 20
|
1天前
|
Unix Linux 编译器
UNIX/Linux 上的安装
UNIX/Linux 上的安装。
7 2
|
20天前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
27天前
|
NoSQL Linux PHP
如何在不同操作系统上安装 Redis 服务器,包括 Linux 和 Windows 的具体步骤
本文介绍了如何在不同操作系统上安装 Redis 服务器,包括 Linux 和 Windows 的具体步骤。接着,对比了两种常用的 PHP Redis 客户端扩展:PhpRedis 和 Predis,详细说明了它们的安装方法及优缺点。最后,提供了使用 PhpRedis 和 Predis 在 PHP 中连接 Redis 服务器及进行字符串、列表、集合和哈希等数据类型的基本操作示例。
52 4
|
1月前
|
存储 安全 数据管理
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
43 5
|
1月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
83 3
|
1月前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
40 3
|
1月前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
106 3
|
1月前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
68 2
|
1月前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
41 3