public:radio:2024:yaddnet_data_backup
Table of Contents
YaDDNet Data Backup
Offsite Text file backups of all DSC messages
- Alan Spindel initially suggested an offsite backup of the DSC messages in 2019
- YaDDNet has had the facility to send copies of each new message out to specified IP addresses via UDP since that time
- The DSC messages are sent by UDP as simple plain text, for easy archiving
- The archived text file can be used if necessary to rebuild the SQL database table containing the DSC messages in case of disaster
- Since I'm now hosting YaDDNet again I decided I should run a UDP log receiver at home to improve the backup provision
- The daily archive files will be
gzipped
and stored on Dropbox- I could share the link to anyone who is interested in using the saved data
YaDDNet UDP Send to Mirror
- In the
PyYadd.py
function a DSC message is created from the raw incoming data from YaDD (and DSC Decoder) in a standard format. - This involves converting MMSI → Coast or Ship name, finding the
[MID]
and corresponding country etc. - Prior to using the newly created message to inject new data into the SQL server
PyYadd.py
calls the functionsend_to_mirror()
to send out the UDP packet to any configured IP addresses PyYadd.py
then inserts the new data in the SQL server- Any addressed & listening UDP clients receive the UDP packets and append them to a log file
def send_to_mirror(data): log_data = "[log];"+data port = 2505 host = "aaa.bbb.ccc.ddd.eee" host2 = "fff.ggg.hhh.iii" sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) sock.sendto(log_data, (host, port)) sock.sendto(log_data, (host2, port)) return
Backup UDP receive and logrotate
UDP Listener
#!/usr/bin/env python # # udp_logger.py # import SocketServer import socket import threading class ThreadedUDPRequestHandler(SocketServer.BaseRequestHandler): def handle(self): data = self.request[0].strip() socket = self.request[1] self.write_file(data) def write_file(self,text): filename = '/home/gm4slv/yaddlogs/yaddnet_udp_log.txt' f = open(filename, 'a+') log = text f.write(log+"\n") f.close() return class ThreadedUDPServer(SocketServer.ThreadingMixIn, SocketServer.UDPServer): pass if __name__ == "__main__": HOST, PORT = "", 2505 server = ThreadedUDPServer((HOST, PORT), ThreadedUDPRequestHandler) ip, port = server.server_address server.serve_forever() # Start a thread with the server -- # that thread will then start one # more thread for each request server_thread = threading.Thread(target=server.serve_forever) # Exit the server thread when the main thread terminates server_thread.daemon = True server_thread.start() server.shutdown()
- The UDP Log Receiver listens to UDP/2505 for incoming packets from YaDDNet. These are of the form:
[log];2024-04-19 08:43:06;NLD_MB_HF1;2187.5;SEL;002050480;COAST;205;Belgium;Ostende Radio;SAF;636092799;SHIP;636;Liberia;CISNES, D5HF4, Cargo;TEST;NOINF;--;--;REQ;OK [log];2024-04-19 08:43:28;BDXC-Han-Remote;12577.0;SEL;002241022;COAST;224;Spain;Coruna Radio;SAF;538005991;SHIP;538;Marshall Islands;NAVIG8 VIOLETTE, V7IH3, Tanker;TEST;NOINF;--;--;REQ;OK
- each new packet is appended to the running log file
/home/gm4slv/yaddlogs/yaddnet_udp_log.txt
- the file will grow indefinitely if left to itself!
Logrotate
- run by Crontab every day at midnight
- copies the current running log to a timestamped file
- erases the contents of the running log file
gzips
the timestamped copy and moves it to Dropbox
## CRONTAB ENTRY 00 00 * * * /home/gm4slv/bin/yaddlog_rotate.sh /dev/null 2>&1
#!/bin/bash # # yaddlog_rotate.sh DROPBOX=/home/gm4slv/Dropbox/Yaddlogs/ DIR=/home/gm4slv/yaddlogs INFILE=yaddnet_udp_log.txt TIMESTAMP=`date +%Y%m%d_%H%M` OUTFILE=$TIMESTAMP\_$INFILE cp $DIR/$INFILE $DIR/$OUTFILE cat /dev/null > $DIR/$INFILE gzip $DIR/$OUTFILE mv $DIR/$OUTFILE.gz $DROPBOX
- This creates a
gzipped
log file in my Dropbox of each day's new DSC messages
Starting the UDP Listener at boot-up
- crontab entry to start it as a background job at
@reboot
# # CRONTAB ENTRY # @reboot python /home/gm4slv/bin/udp_logger.py &
— John Pumford-Green 19/04/24 09:31 BST
Last updated : 06/03/25 06:49 GMT
Further Information
public/radio/2024/yaddnet_data_backup.txt · Last modified: 06/03/25 06:49 GMT by 127.0.0.1