圖形數據庫(Graph Database)是NoSQL數據庫家族中特殊的存在,用於存儲豐富的關係數據,Neo4j 是目前最流行的圖形數據庫,支持完整的事務,在屬性圖中,圖是由頂點(Vertex),邊(Edge)和屬性(Property)組成的,頂點和邊均可以設置屬性,頂點也稱做節點,邊也稱做關係,每一個節點和關係均可以由一個或多個屬性。Neo4j建立的圖是用頂點和邊構建一個有向圖,其查詢語言cypher已經成爲事實上的標準。html
關係型數據庫只對單個Join操做進行優化查詢,而多重Join操做查詢的性能顯著降低。圖形數據庫適合查詢關係數據,因爲圖形遍歷的局部性,無論圖形中由多少節點和關係,根據遍歷規則,Neo4j只訪問與遍歷相關的節點,不受到總數據集大小的影響,從而保持期待的性能;相應地,遍歷的節點越多,遍歷速度越慢,可是變慢是線性的,這使得圖形數據庫不適合作海量數據統計分析。對與存在大量豐富關係的數據,遍歷的性能不受圖形數據量大小的影響,這使得Neo4j成爲解決圖形問題的理想數據庫。java
一,下載和安裝Neo4jsql
1,安裝Java JDK數據庫
Neo4j是基於Java的圖形數據庫,運行Neo4j須要啓動JVM進程,所以必須安裝JAVA SE的JDK。從Oracle官方網站下載 Java SE JDK,當前的版本是JDK8。windows
2,下載Neo4j安裝文件瀏覽器
從Neo4j官網下載最新版本Neo4j 3.2 社區(Community)版本 「neo4j-community-3.2.0-windows。zip」,解壓到主目錄,「D:\Program Files\neo4j-community-3.2.」。安全
Neo4j應用程序有以下主要的目錄結構:服務器
3,建立系統環境變量網絡
建立主目錄環境變量NEO4J_HOME,並把主目錄設置爲變量值。oracle
二,Neo4j的配置
配置文檔存儲在conf目錄下,Neo4j經過配置文件neo4j.conf控制服務器的工做。默認狀況下,不須要進行任意配置,就能夠啓動服務器。
1,核心數據文件的位置
例如,核心數據文件存儲的位置,默認是在data/graph.db目錄中,要改變默認的存儲目錄,能夠更新配置選項:
# The name of the database to mount #dbms.active_database=graph.db # Paths of directories in the installation. #dbms.directories.data=data
2,安全驗證,默認是啓用的
# Whether requests to Neo4j are authenticated. # To disable authentication, uncomment this line #dbms.security.auth_enabled=false
3,配置JAVA 堆內存的大小
# Java Heap Size: by default the Java heap size is dynamically calculated based on available system resources. # Uncomment these lines to set specific initial and maximum heap size. #dbms.memory.heap.initial_size=512m #dbms.memory.heap.max_size=512m
三,網絡鏈接配置
1,Neo4j支持三種網絡協議(Protocol)
Neo4j支持三種網絡協議(Protocol),分別是Bolt,HTTP和HTTPS,默認的鏈接器配置有三種,爲了使用這三個端口,須要在Windows防火牆中建立Inbound Rules,容許經過端口7687,7474和7473訪問本機。
2,鏈接器的可選屬性
listen_address:設置Neo4j監聽的連接,由兩部分組成:IP地址和端口號(Port)組成,格式是:<ip-address>:<port-number>
3,設置默認的監聽地址
設置默認的網絡監聽的IP地址,該默認地址用於設置三個網絡協議(Bolt,HTTP和HTTPs)的監聽地址,即設置網絡協議的屬性:listen_address地址。在默認狀況下,Neo4j只容許本地主機(localhost)訪問,要想經過網絡遠程訪問Neo4j數據庫,須要修改監聽地址爲 0.0.0.0,這樣設置以後,就能容許遠程主機的訪問。
# With default configuration Neo4j only accepts local connections. # To accept non-local connections, uncomment this line: dbms.connectors.default_listen_address=0.0.0.0
4,分別設置各個網絡協議的監聽地址和端口
HTTP連接器默認的端口號是7474,Bolt連接器默認的端口號是7687,必須在Windows 防火牆中容許遠程主機訪問這些端口號。
# Bolt connector dbms.connector.bolt.enabled=true #dbms.connector.bolt.tls_level=OPTIONAL #dbms.connector.bolt.listen_address=0.0.0.0:7687 # HTTP Connector. There must be exactly one HTTP connector. dbms.connector.http.enabled=true #dbms.connector.http.listen_address=0.0.0.0:7474 # HTTPS Connector. There can be zero or one HTTPS connectors. #dbms.connector.https.enabled=true #dbms.connector.https.listen_address=0.0.0.0:7473
四,啓動Neo4j程序
1,經過控制檯啓動Neo4j程序
點擊組合鍵:Windows+R,輸入cmd,啓動DOS命令行窗口,切換到主目錄,以管理員身份運行命令:
neo4j.bat console
若是看到如下消息,說明neo4j已經開始運行:
2,把Neo4j安裝爲服務(Windows Services)
安裝和卸載服務:
bin\neo4j install-service bin\neo4j uninstall-service
啓動服務,中止服務,重啓服務和查詢服務的狀態:
bin\neo4j start bin\neo4j stop bin\neo4j restart bin\neo4j status
五,打開Neo4j集成的瀏覽器
1,Neo4j瀏覽器
Neo4j服務器具備一個集成的瀏覽器,在一個運行的服務器實例上訪問 「http://localhost:7474/」,打開瀏覽器,顯示啓動頁面
默認的host是bolt://localhost:7687,默認的用戶是neo4j,其默認的密碼是:neo4j,第一次成功登錄到Neo4j服務器以後,須要重置密碼。
訪問Graph Database須要輸入身份驗證,Host是Bolt協議標識的主機。
2,在Neo4j瀏覽器中建立節點和關係
示例,編寫Cypher命令,建立兩個節點和兩個關係:
CREATE (n:Person { name: 'Andres', title: 'Developer' }) return n; CREATE (n:Person { name: 'Vic', title: 'Developer' }) return n; match(n:Person{name:"Vic"}),(m:Person{name:"Andres"}) create (n)-[r:Friend]->(m) return r; match(n:Person{name:"Vic"}),(m:Person{name:"Andres"}) create (n)<-[r:Friend]-(m) return r;
在$ 命令行中,編寫Cypher腳本代碼,點擊Play按鈕,點擊建立第一個節點,
在第一個節點建立以後,在Graph模式下,可以看到建立的圖形,繼續編寫Cypher腳本,建立其餘節點和關係
在建立完兩個節點和關係以後,查看數據庫中的圖形:
後續,我會繼續分享我學習Neo4j圖形數據庫、Cypher腳本和相應的驅動程序的筆記,敬請期待。
推薦書籍:《Neo4j實戰》,原著是《Neo4j in Action》
官方手冊:
參考文檔: