The format is based on Keep a Changelog, and this project adheres to Semantic Versioning. See MAINTAINERS.md for instructions to keep up to date.
- Added
--relayer-source-request-burst
with default=90 to allow a relayer connecting to another relayer to request a 'burst' - Added
--statedb-disable-indexing
to disable indexing of tablet and injecting data into storage engine developer option, don't use that in production. - Added
--eosws-nodeos-rpc-push-extra-addresses
to allow providing a list of backup EOS addresses when push-transaction does not succeed in getting the transaction inside a block (with push_guarantee) - Added
--eosws-max-stream-per-connection
to allow changing how many stream can be active at the same time for a given WebSocket connection, defaults to12
which was the hard-coded value.
- Added
--eosws-statedb-proxy-retries
, Number of time to retry proxying a request to statedb before failing (default 2) - Added
--eosws-nodeos-rpc-proxy-retries
, Number of time to retry proxying a request to statedb before failing (default 2)
- Added
--mindreader-max-console-length-in-bytes
which is the limit in bytes that we allow action trace's console output to be before truncating them. - Environment variable
MINDREADER_MAX_TOKEN_SIZE
can now be set to overridebufio.Scanner()
max token size (default52428800
, i.e.50Mb
) for EOSIO chains with huge transactions - Flag
--accounthist-mode
to specific the accounthist mode of operation - Added
tools check accounthist-shards
to - Flag
--common-include-filter-expr
,--common-exclude-filter-expr
,--common-system-actions-include-filter-expr
can optionally specify multiple values, separated by;;;
and prefixed by#123;
where 123 is a block number at which we stat applying that filter - Added
accounthist
tools allows you to scan and read accountsdfuseeos tools accounthist read ...
dfuseeos tools accounthist scan ...
- Flag
--search-router-truncation-low-block-num
to make the router aware of lower-block-truncation and serve requests accordingly - Flag
--mindreader-oneblock-suffix
that mindreaders can each write their own file per block without competing for writes. dfuse-io/dfuse-eosio#140 - Flag
--eosws-disabled-messages
a comma separated list of ws messages to disable. - Flag
--common-system-shutdown-signal-delay
, a delay that will be applied between receiving SIGTERM signal and shutting down the apps. Health-check foreosws
anddgraphql
will respond 'not healthy' during that period.
- Improved
dfuseeos tools check statedb-reproc-injector
output by showing all shard statistics (and not just most highest block). - Breaking Change Changed
--statedb-enable-pipeline
flag to--statedb-disable-pipeline
to make it clearer that it should not be disable, if you were using the flag, change the name and invert the logical value (i.e.--state-enable-pipeline=false
becomes--state-disable-pipeline=true
) - When using filtering capabilities, only absolutely required system actions will be indexed/processed.
- Added missing
updateauth
anddeleteauth
as require system actions in flagcommon-system-actions-include-filter-expr
.
- Fixed a bug in
TiKV
store implementation preventing it to delete keys correctly. - Fixed a bug in
eosws
WebSocketget_transaction_lifecycle
where a transaction not yet in the database would never stream back any message to the client. - Fixed a bug with
--mindreader-no-blocks-log
option actually not being picked up (always false) - Fixed a bug with
/state/table/row
not correctly reading row when it was in the table index. - Fixed a bug with
/state/tables/scopes
where the actual block num used to query the data was incorrect leading to invalid response results. - Fixed a bug with gRPC
dfuse.eosio.statedb.v1/State#StreamMultiScopesTableRows
where the actual block num used to query the data was incorrect leading to invalid response results. - Fixed issue when reading ABI from StateDB where speculative writes were not handled correctly.
- Fixed issue when reading Table Row from StateDB where speculative writes were not handled correctly.
- Fixed a potential crash when reading ABI from StateDB and it does not exist in database.
- Added
tokens
,accountBalances
,tokenBalances
calls to dgraphql (based on tokenmeta)
- Breaking Change FluxDB has been extracted to a dedicated library (github.com/dfuse-io/fluxdb) with complete re-architecture design.
- Breaking Change FluxDB has been renamed to StateDB and is incompatible with previous written data. See FluxDB Migration section below for more details on how to migrate.
merger
startblock behavior changed, now relies on state-file, see streamingfast/merger#1- Changed
merger-seen-blocks-file
flag tomerger-state-file
to reflect this change. merger
now properly handles storage backend errors when looking for where to startmindreader
now automatically produces "merged blocks" instead of "one-block-files" when catching up (based on blocktime or if a blockmeta is reachable at--common-blockmeta-addr
)mindreader
now sets optimal EOS VM settings automatically if the platform supports it them when doingdfuseeos init
.- Changed
--abicodec-export-cache-url
flag toabicodec-export-abis-base-url
and will contain only the URL of the where to export the ABIs in JSON. - Changed
--abicodec-export-cache
flag toabicodec-export-abis-enabled
.
- Added
tokenmeta
app, with its flags - Added support for filtered blocks, search indices and trxdb, with
--common-include-filter-expr
and--common-include-filter-expr
. - Added
merged-filter
app (not running by default), that generates filtered merged blocks files from regular merged blocks files. - Added truncation handling to
trxdb-loader
, which will only keep a moving window of data intrxdb
, and delete preceding transactions. Enabling that feature requires reprocessing trxdb.--trxdb-loader-truncation-enabled
--trxdb-loader-truncation-window
--trxdb-loader-truncation-purge-interval
- Added
--statedb-reproc-shard-scratch-directory
to run StateDB reprocessing sharder using scratch directory to reduce RAM usage - Added
--merger-one-block-deletion-threads
(default:10) to allow control over one-block-files deletion parallelism
- Added
--merger-max-one-block-operations-batch-size
to allow control over one-block-files batches that are looked up on storage,
- Added
--eosws-with-completion
(default: true) to allow control over that feature - Added
--mindreader-merge-threshold-block-age
when processing blocks with a blocktime older than this threshold, they will be automatically merged: (default 12h) - Added
--mindreader-batch-mode
to force always merging blocks (like --mindreader-merge-and-store-directly did) AND overwriting existing files in destination. - Added
--mindreader-wait-upload-complete-on-shutdown
flag to control how mindreader waits on upload completion when shutting down (previously waited indefinitely) - Added
--search-live-hub-channel-size
flag to specific the size of the search live hub channel capacity - Added
--search-live-preprocessor-concurrent-threads
: number of thread used to run file source preprocessor function - Added
--abicodec-export-abis-file-name
, contains the URL where to export the ABIs in JSON - Added
--metrics-listen-addr
to control on which address to server the metrics API (Prometheus), setting this value to an empty string disable metrics serving. - Added
--dashboard-metrics-api-addr
to specify a different API address where to retrieve metrics for the dashboard. - Added Experimental support for kvdb backend
netkv://
, an extremely simple network layer overbadger
to allow running dfuse components in separate instances.
- The
--merger-delete-blocks-before
flag is now removed and is the only behavior for merger. - The
--mindreader-merge-and-store-directly
flag was removed. That behavior is now activated by default when encountering 'old blocks'. Also see new flag mindreader-batch-mode. - The
--mindreader-discard-after-stop-num
flag was removed, its implementation was too complex and it had no case where it was really useful. - The
--mindreader-producer-hostname
flag was removed, this option made no sense in the context ofmindreader
app. - The
--eosq-disable-tokenmeta
flag was removed, token meta is now included, so this flag is now obsolete. - The
--eosq-on-demand
flag was removed, this was unused in the codebase.
- Fixed issue where
blockmeta
was not serving on GRPC at all because it couldn't figure out where to start on the stream - Fixed issue with
merger
with a possible panic when reading a one-block-file that is empty, for example on a non-atomic storage backend - Fixed issue with
mindreader
not stopping correctly (and showing any error) if the bootstrap phase (ex: restore-from-snapshot) failed. - Fixed issue with
pitreos
not taking a backup at all when sparse-file extents checks failed. - Fixed issue with
dfuseeos tools check merged-blocks
(start/end block, false valid ranges when the first segment is not 0, etc.) - Improved performance by using value for
bstream.BlockRef
instead of pointers and ensuring we use the cached version. mindreader
andnode-manager
improvednodeos
log handling
FluxDB required an architecture re-design to fit with our vision about the tool and make it chain agnostic (so it is easier to re-use on our other supported chain).
The code that was previously found here has been extracted to its own library (https://github.com/dfuse-io/fluxdb).
There is now a new app named StateDB (statedb
is the app identifier) in dfuse for EOSIO that uses FluxDB to
support all previous API endpoints served by the FluxDB app as well as now offering a gRPC interface.
While doing this, we had to change how keys and data were written to the underlying engine. This means that all your previous data stored cannot be read anymore by the new StateDB and that new data written by StateDB will not be compatible on a previous instance.
What that means exactly is that StateDB will require to re-index all the current merged blocks up to live blocks before being able to serve requests. This is the main reason why we decided to rename the app, so you are forced to peform this step.
Here the steps required to migrate to the new statedb
app:
-
In your
dfuse.yaml
config, under replace thefluxdb
app bystatedb
and all flags prefixed withfluxdb-
must now be prefixed withstatedb-
.From:
start: args: - ... - fluxdb - ... flags: ... fluxdb-http-listen-addr: :9090 ...
To:
start: args: - ... - statedb - ... flags: ... statedb-http-listen-addr: :9090 ...
-
If you had a customization for
fluxdb-statedb-dsn
, you must first renamed itstatedb-store-dsn
tostatedb-store-dsn
. Important You must use a new fresh database, so update your argument so it points to a new database, ensuring we don't overwrite data over old now incompatible data. If you did not customize the flag, continue reading, the default value has changed to point to a fresh storage folder.If you had a customization for
eosws-flux-addr
, rename toeosws-statedb-grpc-addr
and ensure it points to the StateDB GRPC address (and not the HTTP address), its value must be the same as the flagstatedb-grpc-listen-addr
. -
If you have a custom
fluxdb-max-threads
flag, removed it, customizing this value is not supported anymore. -
From an operator standpoint, what we suggest is to craft a
dfuse.yaml
config that starts StateDB only in inject mode only. You let this instance run until StateDB reaches the live block of your network.Once you have reached this point, you can now perform a switch to the new StateDB database. Stop the injecting instance. Stop your production instance, renaming old app id
fluxdb
tostatedb
(and all flags) then reconfigure it so thestatedb-store-dsn
points to the database populated by the injecting instance. At this point, you can restart your production node and continue normally using the newstatedb
app.
See release notes.
See release notes.
- Added
apiproxy
application, with its flags - Added
--log-format
option for JSON output andlog-to-file
bool (default to true, same behavior as before) - Filtering (whitelist and blacklist) of what is indexed in Search, based on Google's Common Expression Language. See details here. Added
--search-common-action-filter-on-expr
and--search-common-action-filter-out-expr
.- NOTE: This doesn't affect what is extracted from the chain, allowing you to re-index selectively without a chain replay.
- CLI: dfuseeos init now writes dfuse.yaml with the
start
command's flags, also the array of components to start - CLI: new
{dfuse-data-dir}
replacement string in config flags, also changed default flag values --node-manager-config-dir
now./producer
(wasmanager/config
)--node-manager-data-dir
now{dfuse-data-dir}/node-manager/data
(wasmanagernode/data
)--mindreader-config-dir
now./mindreader
(wasmindreadernode/config
)--mindreader-data-dir
now{dfuse-data-dir}/mindreader/data
(wasmindreadernode/data
)- CLI: regrouped some flags:
--search-indexer-dfuse-hooks-action-name
,--search-live-dfuse-hooks-action-name
,--search-forkresolver-dfuse-hooks-action-name
fused into new--search-common-dfuse-hooks-action-name
.--search-...-mesh-publish-polling-duration
fused into new--search-common-mesh-publish-polling-duration
.- all of the
--search-mesh-...
options were renamed to--search-common-mesh-...
(previously--search-mesh-service-version
,--search-mesh-namespace
,--search-mesh-store-addr
) dashboard
: now separate metrics for mindreader vs producer nodedashboard
doesn't act as a reverse proxy anymore (apiproxy
does)dashboard
's default port is now:8081
eosq
's port is now proxied through:8080
, so use that.- App
manager
renamed tonode-manager
. All of its flags were changed from--manager-...
to--node-manager-...
- The
--search-...-indexing-restrictions-json
. This was replaced by the filtering listed above.
- Added
--nodeos-path
to control whichnodeos
executable is used.
- Removed
--chain-name
, replaced by--config-file
(or-c
) - Removed
init --reset
option,dfusebox purge
does it all now.
- Renamed
dfusebox
todfuse for EOSIO
dfusebox.yaml
todfuse.yaml
dfusebox-data
todfuse-data
--data-dir
now defaults to./dfusebox-data
, and is separate from a chain name or the config file location.dfusebox init
now only generates adfusebox.yaml
config file, which can be booted withdfusebox start
.dfusebox init
now only has the interactive method. We can later add more programmatic method to boot chains. With adfusebox.yaml
config now, however, we can reuse initializations multiple times.- License changed to Apache 2.0
- Added GitHub workflow for PR checks