This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
projects:amateur_radio:meshtastic:getting_started [2024/05/08 04:08] – removed - external edit (Unknown date) 127.0.0.1 | projects:amateur_radio:meshtastic:getting_started [2024/06/20 18:05] (current) – [Python CLI Quickstart] don't enable mqtt while configuring lora Andrew Yong | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | ====== Getting Started with Meshtastic in Singapore ====== | ||
+ | ([[# | ||
+ | |||
+ | ===== Reasons to Use Meshtastic ===== | ||
+ | |||
+ | < | ||
+ | |||
+ | < | ||
+ | |||
+ | ==== For Laypersons ==== | ||
+ | |||
+ | Meshtastic provides a phone app that looks and feels similar to other messaging apps, except that it does not require any cellular data or Wi-Fi. Instead, communications take place over a network of devices (nodes) that are owned and operated by the users, with nodes relaying messages to other nodes in range (typically several kilometers). | ||
+ | |||
+ | ==== For Persons with An Interest in Electronics or Radio Communications ==== | ||
+ | |||
+ | Meshtastic is a great platform with opportunities to observe and experiment with radio communications in the real world, urban and outdoors. The software, firmware and protocol are open source and extensible; the protocol can send GPS coordinates, | ||
+ | |||
+ | For more information about the LoRa modulation/ | ||
+ | |||
+ | ==== Use Cases ==== | ||
+ | |||
+ | * Off-grid communications | ||
+ | * Backcountry hiking, cycling etc. | ||
+ | * Unreliable/ | ||
+ | * Decentralized, | ||
+ | * Disaster Response/ | ||
+ | * Tactical situational awareness (e.g.: ATAK) | ||
+ | * Sensor networks (environment sensors, GPIO sensors) | ||
+ | * **And more!** | ||
+ | |||
+ | ===== Buy Hardware to Use Meshtastic ===== | ||
+ | |||
+ | :!: Do not power up LoRa boards without an antenna attached, the transmitter may get damaged by the reflected signal :!: | ||
+ | |||
+ | Minimum hardware needed to get connected: | ||
+ | |||
+ | - **[[https:// | ||
+ | - **[[https:// | ||
+ | - **[[https:// | ||
+ | |||
+ | ==== Meshtastic Devices ==== | ||
+ | |||
+ | :!: When ordering, select the 923 MHz option if available, otherwise, 915 MHz, or 868 MHz if no other 900 MHz band is available | ||
+ | |||
+ | :?: The device hardware for 868/915/923 MHz selection is the same, just with different antennae in the box; 433 MHz has hardware differences and can't be used for 900 MHz band | ||
+ | |||
+ | * Portable All-In-One Devices (screen, battery, GPS, antenna, sensor(s), enclosure, low power consumption) | ||
+ | * [[https:// | ||
+ | * Portable All-In-One Kits (screen, battery, GPS, antenna, sensor(s)) | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | * DIY Kits (screen, antenna, optional battery; suitable for home/office use or powering with USB power bank) | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | |||
+ | :!: Heltec devices are missing USB-C Configuration Channel resistors, so USB-C PD compliant supplies will likely not supply power. Using a USB-A to USB-C cable solves this issue. LILYGO boards have the correct CC resistors (i.e. 5.1 kΩ from pins CC1 and CC2 to ground) and do not have this issue. | ||
+ | |||
+ | ==== Meshtastic Software ==== | ||
+ | |||
+ | :?: Connects to the Meshtastic node over Bluetooth LE, USB serial or Wi-Fi. Optional if you have a standalone node with keyboard. | ||
+ | |||
+ | * Android device + [[https:// | ||
+ | * iOS device + [[https:// | ||
+ | * Desktop device + [[https:// | ||
+ | |||
+ | ==== Antennae ==== | ||
+ | |||
+ | * With appropriate frequency for configured region | ||
+ | * 915 MHz are usually fine for SG_923 (LongFast default frequency is 917.125 MHz) | ||
+ | * Some devices bundle an antenna, they may not have best resonance at 923 MHz but are good enough to start with | ||
+ | |||
+ | === Antenna Suggestions (TODO: NanoVNA test reports) === | ||
+ | |||
+ | * **Taoglas TI.92.2113** - SMA 2 dBi hinged dipole; [[https:// | ||
+ | * **Ziisor TX915-JKD-20** - SMA 3.5 dBi hinged dipole; [[http:// | ||
+ | * **Ziisor TX915-JZLW-15** - U.FL 3 dBi fixed dipole; [[https:// | ||
+ | * **BETAFPV Moxon V2**- SMA 5.9 dBi directional 2-element yagi?; [[https:// | ||
+ | ==== Nice to Haves ==== | ||
+ | |||
+ | * **Battery** | ||
+ | * For mobile nodes that have battery connectors and onboard lithium-ion chargers | ||
+ | * For battery backup of stationary nodes | ||
+ | * [[projects: | ||
+ | * **Solar power** for hard-to-access nodes | ||
+ | * Bypass the DC-DC buck-boost connector on the USB-A end of the cable if using a LoRa board with built-in battery/ | ||
+ | * [[projects: | ||
+ | * **IP-rated enclosure** for outdoor nodes | ||
+ | |||
+ | ===== Installing Meshtastic Firmware ===== | ||
+ | |||
+ | Flash the latest firmware with the [[https:// | ||
+ | |||
+ | - Appropriate USB COM port drivers must be installed (Windows/ | ||
+ | - Put the device into programming mode | ||
+ | * Battery powered devices: Connect USB cable, hold the boot button, tap the reset button, release the boot button | ||
+ | * USB powered devices: Hold the boot button, connect USB cable, release the boot button | ||
+ | - Select your board and the latest firmware at [[https:// | ||
+ | - Click //Flash//, // | ||
+ | - Select //Full Erase and Install// if this is the first time installing Meshtastic, this will wipe any leftover data from factory programming | ||
+ | |||
+ | For more experienced ESP32 users, standard tools and methods to flash ESP32 can be used as well, with files from the [[https:// | ||
+ | |||
+ | |||
+ | ===== First Use Configuration ===== | ||
+ | |||
+ | ==== Region Configuration ==== | ||
+ | |||
+ | A freshly installed Meshtastic device must have its region configured before the LoRa radio is enabled, this sets limits on the Meshtastic device and LoRa radio to operate within local regulation restrictions. The exact firmware limits for each region can be found in the [[https:// | ||
+ | |||
+ | Devices are only visible to, and can only communicate with, devices configured with the same region. | ||
+ | |||
+ | * **Android/ | ||
+ | * **Python CLI**: '' | ||
+ | |||
+ | **Usable regions in Singapore**: | ||
+ | |||
+ | * **EU_433** | ||
+ | * Frequency band: 433 - 434 MHz | ||
+ | * ERP: 10 mW (10 dBm) | ||
+ | * Duty cycle: 10% | ||
+ | * IMDA TS SRD band: 26a | ||
+ | * **SG_923** <- use this, it has higher output power, no duty cycle restriction and is also allocated to LPWAN | ||
+ | * Frequency band: 917 - 923 MHz | ||
+ | * ERP: 100 mW (20 dBm) | ||
+ | * IMDA TS SRD band: 30d (not 30b/30c as [[https:// | ||
+ | * **Do not use regions not listed above** as they have other allocations here | ||
+ | |||
+ | ==== Meshtastic Channel Configuration ==== | ||
+ | |||
+ | * Meshtastic channels are logical channels (like Telegram channels, WhatsApp groups) | ||
+ | * Primary - Telemetry and position data | ||
+ | * Secondary - Free to use, up to 7 channels | ||
+ | * Channel named “admin” is a special channel used to configure nodes over the mesh | ||
+ | * Name and encryption configured per-channel | ||
+ | * Shareable as QR code or a deeplink URL | ||
+ | |||
+ | **Creating a Private 9V1 Primary Channel with Default Secondary Channel** | ||
+ | |||
+ | Motivations: | ||
+ | |||
+ | * Encrypt the primary channel with a private name | ||
+ | * Don't send plaintext GPS position messages over MQTT forwarding | ||
+ | * Don't send plaintext telemetry over MQTT forwarding | ||
+ | * Connectivity with SG_923 Meshtastic users on the default SG_923 LongFast channel | ||
+ | * Rebroadcast public SG_923 Meshtastic traffic | ||
+ | |||
+ | Steps (the easy way): | ||
+ | |||
+ | - [[user: | ||
+ | - Install the channel and LoRa settings with the URL | ||
+ | * **Android/ | ||
+ | * **Python CLI**: '' | ||
+ | |||
+ | Steps (the hard way, adapted from [[https:// | ||
+ | |||
+ | - Ensure you have not changed the LoRa [[https:// | ||
+ | - On your PRIMARY channel, set channel name to '' | ||
+ | - Configure and enable a SECONDARY channel named '' | ||
+ | - If your LoRa channel is at the default ('' | ||
+ | * '' | ||
+ | |||
+ | ==== Enable MQTT Forwarding ==== | ||
+ | |||
+ | Because we don't currently have enough nodes in Singapore to form a full mesh, we need to enable MQTT forwarding to use the Internet as a backhaul to forward messages between isolated nodes and meshes. | ||
+ | |||
+ | The node must either be connected to Wi-Fi directly (mesh router-client to MQTT bridge), or be paired with an Android or iOS device with "MQTT Client Proxy" enabled (mobile node). | ||
+ | |||
+ | In future, when a full mesh is formed, MQTT can be disabled for a truly decentralized and private mesh, or left enabled as a backup in case of dead zones in the mesh. | ||
+ | |||
+ | * **Android/ | ||
+ | - In //Modules// -> //MQTT// | ||
+ | - // | ||
+ | - Portable nodes with BLE to phone only: //MQTT Client Proxy//: on | ||
+ | - Leave the other settings at defaults to use the Meshtastic public MQTT server | ||
+ | - In // | ||
+ | - '' | ||
+ | * **Python CLI**: | ||
+ | - '' | ||
+ | - Portable nodes with BLE to phone only: '' | ||
+ | - '' | ||
+ | |||
+ | ==== Configuration for Wi-Fi MQTT Routers ==== | ||
+ | |||
+ | :!: Turning Wi-Fi on turns BLE off, so further configuration will have to be done over the Web Client, Android client or Python CLI. | ||
+ | |||
+ | * **Android/ | ||
+ | - In //Device Configuration// | ||
+ | - //Device Role//: Router & Client | ||
+ | - // | ||
+ | - // | ||
+ | - //Device GPS//: Off | ||
+ | - //Fixed Position//: On | ||
+ | * **Python CLI**: | ||
+ | - '' | ||
+ | - '' | ||
+ | |||
+ | === Enable Store & Forward === | ||
+ | |||
+ | [[https:// | ||
+ | |||
+ | * Must be installed on a ROUTER or ROUTER_CLIENT node. | ||
+ | * This is an artificial limitation, but is in place to enforce best practices. | ||
+ | * Router nodes are intended to be always online. If this module misses any messages, the reliability of the stored messages will be reduced. | ||
+ | * ESP32 Processor based device with onboard PSRAM (T-Beam > v1.0, T3S3, and maybe others). | ||
+ | |||
+ | * **Android/ | ||
+ | - In // | ||
+ | * **Python CLI**: | ||
+ | - '' | ||
+ | |||
+ | :?: To find GPS coordinates for your address, you can use the [[https:// | ||
+ | :!: Please write to [[me@ndoo.sg]] if you have a site to offer for a Wi-Fi to MQTT router; we will sponsor the hardware. | ||
+ | |||
+ | ===== Build, Buy or 3D Print Enclosure for your Meshtastic Device ===== | ||
+ | |||
+ | Meshtastic devices are primarily development boards, thus being bare PCBs; many also use U.FL/IPEX connections for their LoRa antenna, which are extremely fragile. For your Meshtastic device to leave your desk, you are likely to want an enclosure. | ||
+ | |||
+ | Have a look at [[.device_enclosures: | ||
+ | ===== Python CLI Quickstart ===== | ||
+ | |||
+ | If you have used Meshtastic before and just want to switch over to SG_923, here are all the commands you need to get configured. | ||
+ | |||
+ | <code bash> | ||
+ | # Licensed hams | ||
+ | meshtastic --set-ham [YOUR_CALLSIGN] --set-owner-short | ||
+ | # Other users | ||
+ | meshtastic --set-owner [LONG_NAME] --set-owner-short | ||
+ | |||
+ | # Set region | ||
+ | meshtastic --set lora.region 18 && sleep 15 | ||
+ | |||
+ | # Set channel and tx power (don't configure it at the same time as changing regions) | ||
+ | meshtastic --set lora.channel_num 4 --set lora.tx_power 0 && sleep 15 | ||
+ | |||
+ | |||
+ | # IF Portable device | ||
+ | meshtastic --set mqtt.enabled true --set mqtt.proxy_to_client_enabled true | ||
+ | |||
+ | # ELSEIF Stationary MQTT router | ||
+ | meshtastic | ||
+ | |||
+ | # ENDIF | ||
+ | |||
+ | # IF configuring channels via channel URL | ||
+ | meshtastic --seturl [CONTACT ME FOR URL] | ||
+ | |||
+ | # ELSEIF configuring channels manually | ||
+ | meshtastic --ch-longfast | ||
+ | meshtastic --ch-set name 9V1 --ch-index 0 | ||
+ | meshtastic --ch-set psk [CONTACT ME FOR PSK] --ch-index 0 | ||
+ | meshtastic --ch-set downlink_enabled true --ch-index 0 --ch-set uplink_enabled true --ch-index 0 | ||
+ | meshtastic --ch-set name LongFast --ch-index 1 | ||
+ | meshtastic --ch-set psk 0x01 --ch-index 1 | ||
+ | meshtastic --ch-set downlink_enabled true --ch-index 1 --ch-set uplink_enabled true --ch-index 1 | ||
+ | meshtastic --ch-enable --ch-index 1 | ||
+ | |||
+ | # ENDIF | ||
+ | |||
+ | </ | ||
+ | |||
+ | Android/iOS app: Skip ahead to [[# | ||
+ | |||
+ | ===== Other Meshtastic Notes ===== | ||
+ | |||
+ | ==== Data Rates ==== | ||
+ | |||
+ | ^ Channel setting | ||
+ | | Short Range / Fast | Short Fast | **10.94 kbps** | ||
+ | | Short Range / Slow | Short Slow | **6.25 kbps** | ||
+ | | Medium Range / Fast | Medium Fast | **3.52 kbps** | ||
+ | | Medium Range / Slow | Medium Slow | **1.95 kbps** | ||
+ | | Long Range / Fast | Long Fast | **1.07 kbps** | ||
+ | | Long Range / Moderate | ||
+ | | Long Range / Slow | Long Slow | **0.18 kbps** | ||
+ | | Very Long Range / Slow | Very Long Slow | **0.09 kbps** | ||
+ | - [[https:// | ||
+ | |||
+ | ==== Windows Python Incompatibility ==== | ||
+ | |||
+ | * Windows 11's built in Python binaries did not work out of the box with Meshtastic, I had to install Python' | ||
+ | - Install latest Python from [[https:// | ||
+ | - <code bash>pip install --upgrade pip</ | ||
+ | - <code bash>pip install meshtastic</ | ||
+ | |||
+ | ==== Entering ESP32 Download Mode ==== | ||
+ | |||
+ | * Entering download mode on ESP32-C3 (and most other ESP32 based boards): | ||
+ | * Warm reset (useful if disconnecting power is inconvenient, | ||
+ | - Hold BOOT | ||
+ | - Tap RST | ||
+ | - Release BOOT after 2 seconds | ||
+ | * Cold reset | ||
+ | - Remove all power sources (USB, battery, solar, etc.) | ||
+ | - Hold BOOT | ||
+ | - Insert power supply | ||
+ | - Release BOOT after 2 seconds |