- Run
- Docker Build
- How to run NineChronicles Headless on AWS EC2 instance using Docker
- Nine Chronicles GraphQL API Documentation
$ dotnet run --project ./NineChronicles.Headless.Executable/ -- --help
Usage: NineChronicles.Headless.Executable [command]
Usage: NineChronicles.Headless.Executable [--app-protocol-version <String>] [--genesis-block-path <String>] [--no-miner] [--host <String>] [--port <Nullable`1>] [--swarm-private-key <String>] [--miner-private-key <String>] [--store-type <String>] [--store-path <String>] [--ice-server <String>...] [--peer <String>...] [--trusted-app-protocol-version-signer <String>...] [--rpc-server] [--rpc-listen-host <String>] [--rpc-listen-port <Nullable`1>] [--graphql-server] [--graphql-host <String>] [--graphql-port <Nullable`1>] [--graphql-secret-token-path <String>] [--no-cors] [--workers <Int32>] [--confirmations <Int32>] [--nonblock-renderer] [--nonblock-renderer-queue <Int32>] [--strict-rendering] [--dev] [--dev.block-interval <Int32>] [--dev.reorg-interval <Int32>] [--log-action-renders] [--aws-cognito-identity <String>] [--aws-access-key <String>] [--aws-secret-key <String>] [--aws-region <String>] [--tx-life-time <Int32>] [--message-timeout <Int32>] [--tip-timeout <Int32>] [--demand-buffer <Int32>] [--static-peer <String>...] [--miner-count <Int32>] [--skip-preload] [--minimum-broadcast-target <Int32>] [--bucket-size <Int32>] [--chain-tip-stale-behavior-type <String>] [--tx-quota-per-signer <Int32>] [--rpc-remote-server] [--maximum-poll-peers <Int32>] [--transport-type <String>] [--completion] [--help] [--version]
NineChronicles.Headless.Executable
Commands:
validation
chain
key
apv
Options:
-V, --app-protocol-version <String> App protocol version token (Required)
-G, --genesis-block-path <String> (Required)
--no-miner
-H, --host <String>
-P, --port <Nullable`1>
--swarm-private-key <String> The private key used for signing messages and to specify your node. If you leave this null, a randomly generated value will be used.
--miner-private-key <String> The private key used for mining blocks. Must not be null if you want to turn on mining with libplanet-node.
--store-type <String>
--store-path <String>
-I, --ice-server <String>...
--peer <String>...
-T, --trusted-app-protocol-version-signer <String>... Trustworthy signers who claim new app protocol versions
--rpc-server
--rpc-listen-host <String> (Default: 0.0.0.0)
--rpc-listen-port <Nullable`1>
--graphql-server
--graphql-host <String> (Default: 0.0.0.0)
--graphql-port <Nullable`1>
--graphql-secret-token-path <String> The path to write GraphQL secret token. If you want to protect this headless application, you should use this option and take it into headers.
--no-cors Run without CORS policy.
--workers <Int32> Number of workers to use in Swarm (Default: 5)
--confirmations <Int32> The number of required confirmations to recognize a block. 0 by default. (Default: 0)
--nonblock-renderer Uses non-blocking renderer, which prevents the blockchain & swarm from waiting slow rendering. Turned off by default.
--nonblock-renderer-queue <Int32> The size of the queue used by the non-blocking renderer. 512 by default. Ignored if --nonblock-renderer is turned off. (Default: 512)
--strict-rendering Flag to turn on validating action renderer.
--network-type <NetworkType> Network type. (Default: Main) (Allowed values: Main, Internal, Test)
--dev Flag to turn on the dev mode. false by default.
--dev.block-interval <Int32> The time interval between blocks. It's unit is milliseconds. Works only when dev mode is on. 10000 (ms) by default. (Default: 10000)
--dev.reorg-interval <Int32> The size of reorg interval. Works only when dev mode is on. 0 by default. (Default: 0)
--log-action-renders Log action renders besides block renders. --rpc-server implies this.
--aws-cognito-identity <String> The Cognito identity for AWS CloudWatch logging.
--aws-access-key <String> The access key for AWS CloudWatch logging.
--aws-secret-key <String> The secret key for AWS CloudWatch logging.
--aws-region <String> The AWS region for AWS CloudWatch (e.g., us-east-1, ap-northeast-2).
--tx-life-time <Int32> The lifetime of each transaction, which uses minute as its unit. 60 (m) by default. (Default: 60)
--message-timeout <Int32> The grace period for new messages, which uses second as its unit. 60 (s) by default. (Default: 60)
--tip-timeout <Int32> The grace period for tip update, which uses second as its unit. 60 (s) by default. (Default: 60)
--demand-buffer <Int32> A number that determines how far behind the demand the tip of the chain will publish `NodeException` to GraphQL subscriptions. 1150 blocks by default. (Default: 1150)
--static-peer <String>... A list of peers that the node will continue to maintain.
--miner-count <Int32> The number of miner task(thread). (Default: 1)
--skip-preload Run node without preloading.
--minimum-broadcast-target <Int32> Minimum number of peers to broadcast message. 10 by default. (Default: 10)
--bucket-size <Int32> Number of the peers can be stored in each bucket. 16 by default. (Default: 16)
--chain-tip-stale-behavior-type <String> Determines behavior when the chain's tip is stale. "reboot" and "preload" is available and "reboot" option is selected by default. (Default: reboot)
--tx-quota-per-signer <Int32> The number of maximum transactions can be included in stage per signer. (Default: 10)
--rpc-remote-server
--transport-type <String> Determines the type of transport. "netmq" and "tcp" is available and "tcp" option is selected by default. (Default: tcp)
--maximum-poll-peers <Int32> The maximum number of peers to poll blocks. int.MaxValue by default. (Default: 2147483647)
--completion Generate a shell completion code
-h, --help Show help message
--version Show version
A headless image can be created by running the command below in the directory where the solution is located.
$ docker build . -t <IMAGE_TAG> --build-arg COMMIT=<VERSION_SUFFIX>
- Nine Chronicles Team uses <VERSION_SUFFIX> to build an image with the latest git commit and push to the official Docker Hub repository. However, if you want to build and push to your own Docker Hub account, <VERSION_SUFFIX> can be any value.
-H
,--host
: Specifies the host name.-P
,--port
: Specifies the port number.--swarm-private-key
: Specifies the private Key used in swarm.--miner-private-key
: Specifies the private Key used in mining.--no-miner
: Disables mining.--store-path
: Specifies the path for storing data.-I
,--ice-server
: Specifies the TURN server info used for NAT Traversal. If there are multiple servers, they can be added by typing:--ice-server serverA --ice-server serverB ...
.--peer
: Adds a peer and if there are multiple peers, they can be added by typing:--peer peerA --peer peerB ...
.-G
,--genesis-block-path
: Specifies the path of the genesis block.-V
,--app-protocol-version
: Specifies the value ofSwarm<T>.AppProtocolVersion
.--rpc-server
: Starts with RPC server mode. Must specify--rpc-listen-port
to use this mode.--rpc-listen-host
: Host name for RPC server mode.--rpc-listen-port
: Port number for RPC server mode.--graphql-server
: Turn on graphQL controller.--graphql-host
: Host name for graphQL controller.--graphql-port
: Port number for graphQL controller.--libplanet-node
: Run with formal Libplanet node. One of this orgraphql-server
must be set.--workers
: Number of workers to use in Swarm.--confirmations
: Specifies the number of required confirmations to recognize a block.--nonblock-renderer
: Uses non-blocking renderer, which prevents the blockchain & swarm from waiting slow rendering. Turned off by default.--nonblock-renderer-queue
: The size of the queue used by the non-blocking renderer. 512 by default. Ignored if--nonblock-renderer
is turned off.--max-transactions
: Specifies the number of maximum transactions can be included in a single block. Unlimited if the value is less then or equal to 0.--network-type
: Choose one ofMain
,Internal
,Test
.Main
by defualt.--dev
: Flag to turn on the dev mode.--dev.block-interval
: Specifies the time interval between blocks by milliseconds in dev mode.--dev.reorg-interval
: Specifies the size of reorg interval in dev mode.--message-timeout
: Specifies the time limit that determines how old the latest message is received will publishNodeException
to GraphQL subscriptions.--tip-timeout
: Specifies the time limit that determines how old the blockchain's tip is updated will publishNodeException
to GraphQL subscriptions.--demand-buffer
: Specifies the number that determines how far behind the demand the tip of the chain will publishNodeException
to GraphQL subscriptions.--miner-count
: Specifies the number of task(thread)s to use for mining.--skip-preload
: Skipping preloading when starting.--minimum-broadcast-target
: Minimum number of the peers to broadcast messages.--bucket-size
: Specifies the number of the peers can be stored in each bucket.--tx-quota-per-signer
: Specifies the number of maximum transactions can be included in stage per signer.--poll-interval
: Specifies the interval between block polling.--transport-type
: Specifies the type of transport to use. Eithernetmq
ortcp
is available.tcp
by default.--maximum-poll-peers
: Specifies the maximum number of peers to poll blocks.
Formatting for PrivateKey
or Peer
follows the format in [Nekoyume Project README][../README.md].
- Docker environment: Docker Installation Guide
- AWS EC2 instance: AWS EC2 Guide
1. Pull ninechronicles-headless Docker image to your AWS EC2 instance from the official Docker Hub repository.
- If you would like to build your own Docker image from your local, refer to this section.
$ docker pull planetariumhq/ninechronicles-headless:latest
Usage: docker pull [<DOCKER_HUB_ACCOUNT>/<IMAGE_NAME>] : [<TAGNAME>]
$ docker volume create 9c-volume
Usage: docker volume create [<VOLUME_NAME>]
$ docker run \ --detach \ --volume 9c-volume:/app/data \ planetariumhq/ninechronicles-headless:latest \ [NineChronicles Headless Options]
- If you want to use the same headless options as your Nine Chronicles game client, refer to
config.json
under%localappdata%\Programs\Nine Chronicles\resources\app
. Insideconfig.json
, refer to the following properties for your headless options:GeniesisBlockPath
MinimumDifficulty
StoreType
AppProtocolVersion
TrustedAppProtocolVersionSigners
IceServerStrings
PeerStrings
NoTrustedStateValidators
NoMiner
Confirmations
NonblockRenderer
NonblockRendererQueue
Workers
- If you are using an Elastic IP on your AWS instance, you must include the IP as the
--host
option but do not need to include the--ice-server
option. - For mining, make sure to include the
--miner-private-key
option with your private key. Also, include--libplanet-node
to run the default libplanet node.
- Docker environment: Docker Installation Guide
- Docker Hub account: Docker Hub Guide
$ docker build . --tag 9c/9c-headless --build-arg COMMIT=9c-1
Usage: docker build . --tag [<DOCKER_HUB_ACCOUNT>/<IMAGE_NAME>] : [<TAGNAME>] --build-arg COMMIT=[<VERSION_SUFFIX>]
$ docker push 9c/9c-headless:latest
Usage: docker push [<DOCKER_HUB_ACCOUNT>/<IMAGE_NAME>] : [<TAGNAME>]
Check out Nine Chronicles GraphQL API Tutorial to get you started with using GraphQL API with NineChronicles Headless.
For more information on the GraphQL API, refer to the NineChronicles Headless GraphQL Documentation.