forked from StreamMachine/StreamMachine
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstreamer.coffee
55 lines (40 loc) · 1.72 KB
/
streamer.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
StreamMachine = require "./src/streammachine"
nconf = require "nconf"
# FIXME: Need to implement argv handling for version, help, etc
# -- do we have a config file to open? -- #
# get config from environment or command line
nconf.env().argv()
# add in config file
nconf.file( { file: nconf.get("config") || nconf.get("CONFIG") || "/etc/streammachine.conf" } )
# -- Defaults -- #
nconf.defaults StreamMachine.Defaults
# -- Debugging -- #
# These next two sections are for debugging and use tools that are not included
# as dependencies.
if nconf.get("enable-heapdump")
console.log "ENABLING HEAPDUMP (trigger via USR2)"
require("heapdump")
if nconf.get("heapdump-interval")
console.log "ENABLING PERIODIC HEAP DUMPS"
heapdump = require "heapdump"
setInterval =>
file = "/tmp/streammachine-#{process.pid}-#{Date.now()}.heapsnapshot"
heapdump.writeSnapshot file, (err) =>
if err
console.error err
else
console.error "Wrote heap snapshot to #{file}"
, Number(nconf.get("heapdump-interval")) * 1000
# There are three potential modes of operation:
# 1) Standalone -- One server, handling boths streams and configuration
# 2) Master -- Central server in a master/slave setup. Does not handle any streams
# directly, but hands out config info to slaves and gets back logging.
# 3) Slave -- Connects to a master server for stream information. Passes back
# logging data. Offers up stream connections to clients.
core = switch nconf.get("mode")
when "master"
new StreamMachine.MasterMode nconf.get()
when "slave"
new StreamMachine.SlaveMode nconf.get()
else
new StreamMachine.StandaloneMode nconf.get()