Cheatsheet
This cheatsheet provides a quick reference for commonly used commands, ports, credentials, and configurations for your Web3 Pi node.
Default Credentials
SSH Access:
| Username | Password | 
|---|---|
| ethereum | ethereum | 
Note: You are required to change this password upon first SSH login.
Grafana Dashboard:
| Username | Password | 
|---|---|
| admin | admin | 
Note: You will be prompted to change this password upon first Grafana login. It is highly recommended to do so.
Common Network Ports
| Port | Service / Description | Access Method | 
|---|---|---|
| 22 | SSH | SSH | 
| 80 | Installation Monitor / Status Page | HTTP | 
| 3000 | Grafana Dashboard | HTTP | 
| 5052 | Lighthouse HTTP REST API | HTTP | 
| 5353 | mDNS (Avahi Daemon) | mDNS | 
| 7197 | Basic System Monitor JSON API | HTTP | 
| 8008 | InfluxDB HTTP API | HTTP | 
| 8545 | Execution Client JSON-RPC (Geth) | HTTP | 
| 8546 | Execution Client WebSocket RPC (Geth) | HTTP | 
| 8551 | Execution Client Engine API (Geth) | HTTP | 
| 9000 | Consensus Client P2P (Lighthouse) | TCP/UDP | 
| 9000 | Consensus Client P2P (Nimbus) | TCP/UDP | 
| 9090 | Cockpit System Dashboard | HTTPS | 
| 30303 | Execution Client P2P (Geth) | TCP/UDP | 
How to find your nodes ip address or hostname
- Hostname: Use the hostname you chose during image creation (e.g., web3pi.local,eop-1.local). Check via SSH withhostname.
- IP Address: Check your router's admin panel or use network scanning tools to find the IP address assigned to your Raspberry Pi.
- LCD Display: If installed, the LCD Dashboard shows the current IP address and hostname.
Log files
- Web3 Pi Logs: /var/log/web3pi.log
- rc.local logs: /root/first-run.flag
Internet connectivity
Bandwidth
To achieve optimal synchronization performance, your internet connection should have a download bandwidth of at least 160 Mb/s (20 MB/s). The upload requirement, however, is significantly lower. The synchronization process with the Ethereum mainnet requires downloading approximately 1.2 TB of data. [1.1 TB download, 25 GB upload - October 2024] So please be cautious if your internet connection is metered. A slower internet connection will still function, though the synchronization process will take longer. While upload and download speeds are important, they are only one factor in determining the quality of your connection. Ideally, a stable connection with low latency (ping) is recommended. For optimal performance, having a static public IP address is beneficial, but it is not strictly necessary.
WIFI
The default and recommended method for connecting the Raspberry Pi in the Web3 Pi project is via a wired Ethernet connection with automatic DHCP configuration. However, you can also connect Raspberry Pi 4/5 to the internet using the built-in WiFi module. To do so, in Raspberry Pi Imager, you must provide the SSID and password for your WiFi network.
Although using WiFi is possible, we strongly recommend using a wired connection. Over time, WiFi may lead to issues with connection stability and bandwidth performance.
Note
If you are using WIFI, do not connect the Ethernet cable to the Raspberry Pi.
Common Monitoring & Management Commands (via SSH)
Many system management and logging commands require elevated privileges. Use sudo before the command as shown below. You will be prompted for the ethereum user's password the first time you use sudo in a session.
Replace <service_name> with the actual service: w3p_geth, w3p_lighthouse-beacon, or w3p_nimbus-beacon.
Service Management (systemd)
- Check Status: See if a service is running and view recent log snippets.
- Start Service:
- Stop Service:
- Restart Service: (Stop and then start)
- Enable Service: (Start automatically on boot - usually pre-configured)
- Disable Service: (Prevent starting automatically on boot)
Viewing Logs (journald)
- View Full Logs: Show all logs for a service (press qto exit).
- Follow Logs (Live): Watch logs as they are generated (press Ctrl+Cto exit).
- View Last N Lines: Show only the most recent log entries.
- View Logs Since Time: Show logs since a specific time (e.g., "1 hour ago", "2025-04-24 10:00:00").
System Resource Monitoring
- Interactive Process Viewer: Shows CPU, Memory usage, tasks.
- Disk Usage (Overall): Show usage for all mounted filesystems. (No sudoneeded)
- Memory Usage: Show free and used RAM and Swap. (No sudoneeded)
- System Uptime & Load: (No sudoneeded)
Node Specific Checks
- Geth Console (Sync Status): Attach to the Geth console. (No sudoneeded)
System Updates
- Check for Available Updates: Refreshes the package list.
- List Upgradable Packages: See what packages have updates available. (No sudoneeded)
- (Use with Caution) Apply Updates: Upgrades installed packages. Refer to specific Web3 Pi update guides if available.
InfluxDB
InfluxDB stores device status measurements and serves as the data source for Grafana.
The Influx database is fed by the basic-eth2-node-monitor application, which collects data from Ethereum clients. It also receives input from the basic-system-monitor application, which gathers operating system statistics and serves them as JSON over HTTP.
Clearing the Database
To clear the database, run the following commands:
Nimbus
- Service name: w3p_nimbus-beacon
- Default directory: /mnt/storage/.nimbus/data/shared_mainnet_0
- Startup script: /home/ethereum/clients/nimbus/nimbus.sh
Clear saved data
Geth
- Service name: w3p_geth
- Default directory: /mnt/storage/.ethereum
- Startup script: /home/ethereum/clients/geth/geth.sh
Clear saved data
Lighthouse
- Service name: w3p_lighthouse-beacon
- Default directory: /mnt/storage/.lighthouse
- Startup script: /home/ethereum/clients/lighthouse/lighthouse.sh
Clear saved data
JWT Secret
The jwt.hex file contains the JWT secret used to enable authenticated communication between the execution client and the consensus client. This file is generated by the installation script.
- Location: /home/ethereum/clients/secrets/jwt.hex
Storage
PCIe Generation
By default, Web3 Pi uses PCIe Gen 2, which is the officially supported version. However, if you have a PCIe Gen 3 capable device, you can enable it by editing the config.txt file.
Benefits of PCIe Gen 3:
- Higher Bandwidth: PCIe Gen 3 offers double the bandwidth compared to PCIe Gen 2. This means faster data transfer rates, which can be especially beneficial for high-speed storage devices like NVMe SSDs or network cards.
- Improved Performance: For applications that are bottlenecked by PCIe bandwidth, enabling Gen 3 can significantly improve performance.
While Raspberry Pi 5 is designed for PCIe Gen 2, upgrading to Gen 3 can unlock more potential in compatible devices.
Warning
Enabling PCIe Gen 3 on a Raspberry Pi 5 can cause instability. Only proceed if you know what you're doing and have a compatible device.
Scripts
The Web3 Pi image comes with several useful scripts pre-installed. These can be found in the home directory of the ethereum user at /home/ethereum/scripts.
Below is a description of each script and how to execute them:
- 
sudo ./scripts/shutdown.shThis script gracefully shuts down the device. It first stops the services, allowing them time to finish their tasks, and then powers off the system.
- 
sudo ./scripts/reboot.shThis script gracefully reboots the device. It first stops the services, giving them time to complete their tasks, and then restarts the system.
- 
sudo ./scripts/formatMe.shThis script marks the mapped storage as "to be formatted" during the next installation. It’s useful when reinstalling the Web3 Pi image.
- 
sudo ./scripts/versions.shThis script checks the versions of the currently installed applications and compares them to the latest available online. It covers applications such as Geth, Nimbus, and Lighthouse.
- 
sudo ./scripts/update_geth.shThis script updates the Geth application to the latest available version. It stops the service, installs the new version, and then restarts the service.
- 
sudo ./scripts/update_nimbus.shThis script updates the Nimbus application to the latest available version. It stops the service, installs the new version, and then restarts the service.
- 
sudo ./scripts/check_install.shThis script checks the installation and configuration of Web3 Pi. It verifies installed packages, active services, disk and swap usage, network connectivity, and other important aspects. The output is formatted and color-coded for better readability.
You can also view and execute scripts from the Cockpit Web3 Pi Script Runner plugin.
CCZE
Newer version of the Web3 Pi image include CCZE, which enables automatic colorization of logs from applications such as Geth and Nimbus, significantly improving readability.
An example how to use CCZE: