HowTo run NodeCore

From Veriblock Wiki
Revision as of 21:26, 20 October 2020 by VeriBlockTim (talk | contribs)
Jump to: navigation, search
Other languages:

See: Main_Page, NodeCore_QuickStart, NodeCore_Operations, Nodecore.properties

Overview

NodeCore is the service that runs the VBK blockchain. It is written in Java, and runs on Windows, Linux, and Mac.

To see an operations guide for installing NodeCore, see: NodeCore_Operations

To see a quickstart to get NC running fast, see: NodeCore_QuickStart

To modify the nodecore.properties file, see: Nodecore.properties

Steps

Unzip the package:

Windows Mac and Linux
Unzip the nodecore-*.zip file In the bin folder, then run nodecore.bat Unzip to your preferred directory, then run nodecore.

Note: On Linux & Mac systems, you may need to make the nodecore shell script executable by running the following command:

When you first run NodeCore, it will create several other files in a new mainnet folder (nodecore.properties, veriblock.nodecore.log, nodecore.dat, etc...), and load the existing blockchain.

NodeCore may take several minutes to load all the blocks in the blockchain. See the highest block at https://explore.veriblock.org/network-stats. This shows the number of blocks your local instance must load to be in sync with the chain. NodeCore will create a cache file such that when you restart it they will load faster next time.

FAQ

What startup flags are available

-d, description: The data directory where NodeCore generated files reside
-c, description: The configuration file location

How to set NodeCore Log Path

You can specify log path with an environmental variable like so:

export NODECORE_LOG_PATH=/home/user/nodecore_logs/

How can block times be negative?

A negative age indicates the miner's clock was ahead.

For more background, see: https://en.bitcoin.it/wiki/Block_timestamp

How to upgrade NodeCore and keep your wallet

Since mainnet is now live, updating is very fast.

If you do NOT have a previous wallet/address/balance download the latest nodecore found here https://explore.veriblock.org/api/stats/download.

If you do have a wallet/address/balance that you want to carry over make sure you do the following:

  1. Make sure you have a backup of your wallet! You can copy the mainnet folder which contains your wallet.dat, or use the NodeCore_CommandLine#importwallet command from the NC_CLI.
  2. Ensure that you unzip your newlyl downloaded NodeCore to a new folder location - do not overwrite your previous version
  3. In the new version:
    1. Create a mainnet folder most likely in the "nodecore-0.X.X/bin" directory.
    2. Copy in your previous wallet.dat and walletconfig.dat files into the "nodecore-0.X.X/bin/mainnet" directory.
  4. Run your new version of nodecore and start to sync.
  5. When you run NC_CLI getinfo on the new version of the running nodecore, you should see your previous wallet and balance.

How to upgrade NodeCore PoW and keep your Bitcoin wallet

When upgrading your PoP miner, you can copy the file "bitcoin-pop.wallet" from the bin folder of your current PoP miner directory to the bin folder of your new PoP miner.

How to specify a data directory for NodeCore

NodeCore can take a data directory -d as part of the startup.

Example for Linux:

cd /<myDir>/nodecore-0.4.10/bin
./nodecore -d /home/user/data/
  1. nodecore.properties will be in /home/user/data/nodecore.properties
  2. /mainnet folder will be in /home/user/data/mainnet

Example for Windows

cd <myDir>\nodecore-0.4.10\bin
nodecore.bat -d C:\data

# nodecore.properties will be in C:\data\nodecore.properties
# /mainnet folder will be in C:\data\mainnet

How to send from a specific address?

https://wiki.veriblock.org/index.php?title=NodeCore_CommandLine#send

send <amount> <destinationAddress> [sourceAddress]

How to set NodeCore log level

Currently NodeCore log level can be set through the NODECORE_LOG_LEVEL process environmental variable. Once set, NodeCore needs to be restarted.

The default is "INFO", which can create very large log files.

This impacts the "veriblock.nodecore.*.log" (which is the biggest log file). It does not affect the other, much smaller, log files.

WINDOWS

This is an example of setting it in Windows, and then starting NodeCore:

set NODECORE_LOG_LEVEL=WARN
echo %NODECORE_LOG_LEVEL%
nodecore.bat

LINUX

Run in same session, such as a screen:

export NODECORE_LOG_LEVEL=WARN
echo $NODECORE_LOG_LEVEL
./nodecore

Troubleshooting

NodeCore is stuck on a block

Ideally this should not happen, but if it does first try restarting NodeCore.

Java out-of-memory

It is possible that you only have a 32-bit version of Java installed. 64-bit is highly recommended.

Modify the start file (nodecore.bat for windows, nodecore for linux) to increase the memory limit. Pass in a value, such as "1024 MB" into the DEFAULT_JVM_OPTS variable:

DEFAULT_JVM_OPTS=-Xmx1024m

NodeCore keeps turning off with "Application exit"

If messages like:

INFO [main] n.Program [Program.java:133] Application exit

Then something external is shutting off NodeCore (such as a server restart, external process kill, or something else).

Having trouble on a mac

On a Mac, you need to install OpenJDK, our releases are tested on the LTS versions here -> https://adoptopenjdk.net/