sgnl.events
¶
a module for storing event processing utilities
EventProcessor
¶
Bases: object
Base class for processing events via Kafka.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
kafka_server
|
str, the host:port combination to connect to the Kafka broker |
None
|
|
input_topic
|
str, the name of the input topic(s) |
None
|
|
output_topic
|
str, the name of the output topic(s) |
None
|
|
topic_partitions
|
int, number of partitions to create new output topics with, default is 1 |
None
|
|
process_cadence
|
float, maximum rate at which data is processed, defaults to 0.1s |
0.1
|
|
request_timeout
|
float, timeout for requesting messages from a topic, defaults to 0.2s |
0.2
|
|
num_messages
|
int, max number of messages to process per cadence, defaults to 10 |
10
|
|
tag
|
str, a nickname for the instance, defaults to 'default' |
'default'
|
|
send_heartbeats
|
bool, send periodic heartbeat messages to Kafka for monitoring |
False
|
|
heartbeat_cadence
|
float, cadence on which to write heartbeat messages to Kafka |
None
|
|
heartbeat_topic
|
str, Kafka topic to send heartbeats to |
None
|
Source code in sgnl/events.py
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 |
|
catch(signum, frame)
¶
Shuts down the event processor gracefully before exiting.
Source code in sgnl/events.py
183 184 185 186 187 |
|
fetch()
¶
Fetch for messages from a topic and processes them.
Source code in sgnl/events.py
141 142 143 144 145 146 147 148 149 150 151 152 153 154 |
|
finish()
¶
Finish remaining events when stopped and/or shutting down.
NOTE: Derived classes may implement this if desired.
Source code in sgnl/events.py
203 204 205 206 207 208 |
|
handle()
¶
Handles ingested events.
NOTE: Derived classes need to implement this.
Source code in sgnl/events.py
196 197 198 199 200 201 |
|
heartbeat()
¶
Send heartbeat messages to Kakfa to monitor the health of this process.
Source code in sgnl/events.py
210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 |
|
ingest(message)
¶
Ingests a single event.
NOTE: Derived classes need to implement this.
Source code in sgnl/events.py
189 190 191 192 193 194 |
|
process()
¶
Processes events at the specified cadence.
Source code in sgnl/events.py
156 157 158 159 160 161 162 163 164 165 166 167 168 |
|
start()
¶
Starts the event loop.
Source code in sgnl/events.py
170 171 172 173 174 |
|
stop()
¶
Stops the event loop.
Source code in sgnl/events.py
176 177 178 179 180 181 |
|
append_args(parser)
¶
Append event processing specific options to an ArgumentParser instance.
Source code in sgnl/events.py
239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 |
|