Skip to content

Files

Latest commit

 

History

History
70 lines (53 loc) · 2.71 KB

README.md

File metadata and controls

70 lines (53 loc) · 2.71 KB

Inter-Canister Call Overhead

What

  • Calculate overhead for using Inter-Canister Call (ICC) on the Internet Computer

Why

  • Helps to decide on single- vs multi- canister architecture

How

  • Call a chain of canisters with various depth in a loop
    • The last canister in the chain does a no-op operation, eg. 1+1
    • Measure outer_time –- time outside of dfx call
    • Measure inner_time –- time inside the top level canister (testnet, mainnet)
    • Measure iterations of the loop
    • Calculate time_diff –- inner/outer time difference
    • Calculate time_per_call_ms -- time per ICC
      • time_per_call = inner_time / (iterations * depth)
    • Calculate call_rate -- ICC rate per sec
  • Assuming finalization rate at 1 ops/s it does not make sense to run experiment with
    • inner_time < 10 sec, error >10%
    • inner_time > 20 sec, too slow

Summary

testnet mainnet
Maximal depth setup 20 4
Median time per inter-canister call ~2.36 ms ~30.5 ms
Median inter-canister call rate ~423 calls/s ~32.7 calls/s
Median inner/outer time difference ~5.02 sec ~4.51 sec
Analysis Python Notebook ipynb ipynb

Testnet

  • Maximal depth setup: 20
  • Median time per inter-canister call: ~2.36 ms
  • Median inter-canister call rate: ~423 calls/s
  • Median inner/outer time difference: ~5.02 sec
  • Analysis Python Notebook

image image image image

Mainnet

  • Maximal depth setup: 4
  • Median time per inter-canister call: ~30.5 ms
  • Median inter-canister call rate: ~32.7 calls/s
  • Median inner/outer time difference: ~4.51 sec
  • Analysis Python Notebook

image image image image

Notes

  • More numbers and charts at Analysis ipython notebook ./<folder>/analysis.ipynb
  • Run experiment with ./<folder>/run_exp.sh, adjust input values before the run

Issues

  • Sometimes dfx hands for way too long, use gtimeout Xs to cut execution after a timeout

Links