Parachains have become extremely popular for building unique use cases, all while maintaining a seamless interoperability amongst various parachains and blockchains, especially within theĀ Polkadot ecosystem. Yet, beneath the surface of coding and implementing business logic on parachains, a labyrinth of vital DevOps activities ā crucial for their deployment, management, and scaling ā often remain overlooked.
Before any parachain goes into production, itās essential to subject it to intense testing within a simulated mainnet environment. Zombienet becomes an invaluable tool in this context to test parachainās resilience by taking it through numerous brute force scenarios, replicating every possible real-world challenge it might encounter. This includes simulations with all node types, fromĀ full nodesĀ toĀ validator nodes, and stress-testing configurations to ensure stability and optimal behavior. A discernible gap also lies in the domain of advanced analytics and proactive monitoring, both imperative to validate performance and ensure readiness for the mainnet.
In pursuit of a solution,Ā ZeeveĀ submitted a detailed grant proposal at Web3 Foundation. Recognizing the merit in addressing this operational gap, the foundation lent its support, awarding a grant to Zeeve for the development of a GUI tool (LARCH) designed to automate the parachain simulation testing workflow using Zombienet.
Details of the Grant:
We are happy to announce that we have successfully completed both milestone I and Milestone II of our grant from the Web3 Foundation. This grant has enabled us to focus on the development of Larch for enhanced management of Zombienet with automation and monitoring.
More details of the grant can be foundĀ here.
The software is now available under an open-source license on GitHub and accessible to everyone, complete with its source code, developer documentation and tutorials. Weāre confident that Larch will significantly benefit the Polkadot/Substrate parachain developer ecosystem, extending its advantages to the larger Web3 community.
What is Larch?
Zeeveās Larch is a comprehensive frontend for Zombienet CLI, seamlessly integrating with K8 and Podman. Larch is thoughtfully designed to simplify the Zombienet network creation, management, and testing processes. With it, developers and parachain teams can swiftly set up the relay chains and parachains with Zombienet, unlocking the potential to test a plethora of configurations, easily, right from the dashboard.
Key Features of Larch:
-
Comprehensive Automation:Ā Parachain setups are crucial and complex. Larch enables a simple UI driven Zombienet setup, including relaychain and parachain core configurations.
-
Intuitive Configurations: Larch allows for a āpick and chooseā based selection for genesis parameters and chain configurations, crucial for initializing parachain setups tailored for the desired Zombienet.
-
Flexible Replication:Ā Choose from the existing zombienet configurations, save them as templates, or quickly modify and retest using previously saved templates. Users can also effortlessly upload new ones without delving into manual configuration creation.
-
More operational control:Ā Users can conveniently execute key operations such as start, delete, view progress & metrics directly from the dashboard, ensuring optimal testing flexibility.
-
All-Inclusive Node Setup:Ā Supports the setup of all node types, be it Full node, Validator node, or Collator node.
-
Real-time Logging:Ā Enables developers to monitor live logs during test runs and review post-run results directly through the interface.
-
Advanced Monitoring:Ā Incorporates a stack of Prometheus and Grafana for effortless monitoring of Zombienet.
-
Cloud Agnostic:Ā Larchās setup is universal and can be installed on any cloud / local machine of choice with Linux based OS.
In summation, Zeeveās Larch is set to transform the way substrate & parachain developers interact with Zombienet, offering a simplified, efficient, and intuitive experience.
Deploying a Zobienet Network using Larch in a few clicks:
This tutorial focuses on creating a template and subsequently, a network from this template. The intention is to emulate the official Zombienet example found atĀ Zombienet on GitHub.
Note:Ā This guide is tailored for Linux systems. For Mac users, please refer to the LarchĀ Prerequisites section. Although Mac isnāt officially supported yet, if Podman emulation operates smoothly, then Larch should be able to manage the network effectively.
Likewise, K8 execution on a remote Linux cluster via a MacāsĀ kubectlĀ setup should function.
Step 1:
Get the larch binary either by downloading from theĀ releasesĀ orĀ build itĀ yourself.
Step 2:
Ensure Podman / kubectl is installed as per theĀ instructionsĀ on your system for the orchestration of the Zombienet networks.
Step 3:
Assign execute permissions to the larch binary using:
chmod 755 larch
Run the larch binary by doing:
./larch
Step 4:
Navigate to http://localhost:9000 in your browser. Click on the āNetwork TemplateĀ +āĀ button located at the pageās top.
Step 5:
Label the template as āsample-templateā. Choose either Podman or Kubernetes as the Provider based on your setup. Proceed by clickingĀ āNextā.
Step 6:
Under theĀ Relaychain ConfigurationĀ section, populate theĀ NodesĀ subsection. Insert āaliceā as the name and select the āValidatorāĀ option. By pressing theĀ +Ā button, add a new node. For this node, input ābobā and again choose āValidatorā. PressĀ Next.
Step 7:
In theĀ Parachain ConfigurationĀ section, tap on the ā+ā button. Set the Parachain ID to 100 (or any other number). Name the collator ācollator01ā and for the command, use āpolkadot-parachainā. Click āNextā.
Step 8:
For this tutorial, weāll bypassĀ HRMP. Simply click āNextā.
Step 9:
Within theĀ Test ConfigurationĀ section, after the pre-filled sections, append the necessary configuration. Store the template by hitting āSaveā.
Step10:
On the Templates page, the new template should now be visible. Select āCreateāĀ to initiate the network. A dialogue box will pop up ā input the networkās name and click āConfirmāĀ to start the orchestration. The app will transition you to the networks page while in the creation state.
Step 11:
To inspect command and execution logs, click on the āEyeāĀ icon. For a detailed command, tap the āCommandāĀ button; a modal will pop up with the command and other metadata. To peruse logs/outputs, select the āOutputāĀ button, opening another modal revealing the streams.
The preceding step concludes the network creation.
Step 12:
To access metrics of the deployed network, head to theĀ My Network pageĀ and tap the āMonitoringāĀ icon. This redirects you to the Grafana service (default login: admin/admin). Within the Dashboards segment, locate and open the dashboard from the āGeneralāĀ folder to inspect metrics.
Wrapping up:
ZeeveĀ is deeply committed to the web3 ecosystem. As we conclude, our goal is clear: we want āLarchā getting adopted widely and put to use in a diverse parachain testing scenarios. We are encouragingĀ Polkadot/SubstrateĀ developers to utilize it for their testing needs and share feedback.Ā ZeeveĀ will continue to update and enhance Larch, adding new features based on community inputs. Together, weāll keep iterating on Larch, ensuring it remains relevant and beneficial for all developers.