Linux executable (.tar)
Before you install Neo4j on Linux from a tarball and run it as a console application or a service, check System Requirements to see if your setup is suitable. . If it is not already installed, get OpenJDK 21 or Oracle Java 21. Starting with Neo4j 2025.10, Java 25 is also supported.
Install Neo4j from a tarball
- 
Download the latest Neo4j tarball from Neo4j Deployment Center and unpack it: tar zxf neo4j-enterprise-2025.10.0-unix.tar.gz
- 
Move the extracted files to your server’s /opt directory and create a symlink to it: mv neo4j-enterprise-2025.10.0 /opt/ ln -s /opt/neo4j-enterprise-2025.10.0 /opt/neo4j
- 
Create a neo4juser and group:groupadd neo4j useradd -g neo4j neo4j -s /bin/bash
- 
Give the directory the correct ownership using one of the options: - 
Ubuntu chown -R neo4j:adm /opt/neo4j-enterprise-2025.10.0
- 
RedHat chown -R neo4j /opt/neo4j-enterprise-2025.10.0
 
- 
- 
(Recommended) Change the default locations of the data, conf, certificates, licenses, and plugins (if you plan to use custom plugins) directories by setting the environment variable NEO4J_CONFand the respectiveserver.directories.*settings to point to the desired locations.Storing your Neo4j files outside NEO4J_HOMEwill simplify the upgrade process later because you will be able to replace the DBMS binaries without affecting the configuration and state. Otherwise, these Neo4j files will remain in the old installation folder and may be accidentally overwritten during an upgrade or deleted during a subsequent uninstall.
- 
Enterprise Edition Accept either the commercial or the evaluation license agreement. If you are using Community Edition, you can skip this step. - 
Use one of the following options to accept the commercial license agreement. See the Neo4j licensing page for details on the available agreements. - 
Set the environment variable NEO4J_ACCEPT_LICENSE_AGREEMENT=yes.
- 
Run <NEO4J_HOME>/bin/neo4j-admin server license --accept-commercial
 
- 
- 
Use one of the following options to accept the Neo4j Evaluation Agreement for Neo4j Software. - 
Set the environment variable NEO4J_ACCEPT_LICENSE_AGREEMENT=eval.
- 
Run <NEO4J_HOME>/bin/neo4j-admin server license --accept-evaluation.
 
- 
 
- 
- 
Before starting up the database for the first time, it is recommended to use the set-initial-passwordcommand ofneo4j-adminto define the password for the native userneo4j.If the password is not set explicitly using this method, it will be set to the default password neo4j. In that case, you will be prompted to change the default password at first login.
 For more information, see Set an initial password.
- 
Start Neo4j: - 
To run Neo4j as a console application, use: $NEO4J_HOME/bin/neo4j console.
- 
To run Neo4j in a background process, use: $NEO4J_HOME/bin/neo4j start.
 
- 
Configure Neo4j to start automatically on system boot
You can create a Neo4j service and configure it to start automatically on system boot.
- 
Create the file /lib/systemd/system/neo4j.service with the following contents: [Unit] Description=Neo4j Graph Database After=network-online.target Wants=network-online.target [Service] ExecStart=/opt/neo4j/bin/neo4j console Restart=on-abnormal User=neo4j Group=neo4j Environment="NEO4J_CONF=/opt/neo4j/conf" "NEO4J_HOME=/opt/neo4j" LimitNOFILE=60000 TimeoutSec=120 [Install] WantedBy=multi-user.target
- 
Reload systemctl to pick up the new service file: systemctl daemon-reload
- 
Configure Neo4j to start at boot time: systemctl enable neo4j
- 
Before starting up the database for the first time, it is recommended to use the set-initial-passwordcommand ofneo4j-adminto define the password for the native userneo4j.If the password is not set explicitly using this method, it will be set to the default password neo4j. In that case, you will be prompted to change the default password at first login.
 For more information, see Set an initial password.
- 
Start Neo4j: systemctl start neo4j
- 
Check the status of the newly created service: systemctl status neo4j
- 
Reboot the system (if desired) to verify that Neo4j restarts on boot: reboot
For more information on operating the Neo4j system service, see Neo4j system service.
Setting the number of open files
Linux platforms impose an upper limit on the number of concurrently open files per user and session.
To check your limit for the current session, run the command ulimit -n.
The default value is 1024.
ulimit -nHowever, if you experience exceptions on Too many open files or Could not stat() directory, you have to increase the limit to 40000 or more, depending on your usage patterns.
This is especially true when many indexes are used, or the server installation sees too many open network connections or sockets.
A quick solution is the command ulimit -n <the-new-limit>, but it will set a new limit only for the root user and will affect only the current session.
If you want to set the value system-wide, follow the instructions for your platform.
The following steps set the open file descriptor limit to 60000 for the user neo4j under Ubuntu 16.04 LTS, Debian 8, CentOS 7, or later versions.
Running Neo4j as a service
- 
Open the neo4j.service file with root privileges. sudo systemctl edit neo4j.service
- 
Append the following to the [Service]section, created in Configure Neo4j to start automatically on system boot:[Service] ... LimitNOFILE=60000
Running Neo4j as an interactive user (e.g., for testing purposes)
- 
Open the user.conf file with root privileges in a text editor. This example uses Vim: sudo vi /etc/systemd/user.conf
- 
Uncomment and define the value of DefaultLimitNOFILE, found in the[Manager]section.[Manager] ... DefaultLimitNOFILE=60000
- 
Open the /etc/security/limits.conf file. sudo vi /etc/security/limits.conf
- 
Define the following values: neo4j soft nofile 60000 neo4j hard nofile 60000
- 
Reload the systemdsettings.sudo systemctl daemon-reload
- 
Reboot your machine. 
Access Neo4j
By default, Neo4j Community Edition does not include graph tools such as visualization, data exploration, and monitoring. However, you can use the Neo4j Aura console to access these features for free. No subscription is required.
- 
Sign up or log in to the Aura Console. 
- 
On the Instances page, click the Self-managed tab and then + Add deployment button. 
- 
Select URL Connection. 
- 
Provide a Name and Connection URL. If you have installed Neo4j locally on your system, you can connect to http://localhost:7474. 
- 
Click the Connect dropdown to launch various graph tools such as Query, Explore, and Dashboards. 
- 
Type the username neo4jand your password or the default passwordneo4j. You will be prompted to change the latter upon first login.  
You are now connected and can use the Aura Console to run Cypher queries, visualize graphs, and optionally monitor your local Neo4j database in Neo4j Aura. For details, see Get started with Neo4j.
Alternatively, you can use the Neo4j Browser, a web-based user interface for interacting with Neo4j that is included with the Neo4j installation.
To access the Neo4j Browser, open a web browser and navigate to http://localhost:7474.
Connect using the username neo4j with your password or the default password neo4j.
If the default password is used, you will be prompted to change it upon first login.
Uninstall Neo4j
Follow these steps to uninstall Neo4j on Linux:
- 
(Optional) Create a backup to avoid losing your data. 
- 
Stop all Neo4j running services: sudo systemctl stop neo4j sudo systemctl disable neo4j
- 
Delete NEO4J_HOME and the file /lib/systemd/system/neo4j.service: rm /lib/systemd/system/neo4j.service rm -rf NEO4J_HOME