This repository has been archived by the owner on Feb 11, 2020. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 506
Mosca advanced usage
Behrad edited this page May 5, 2015
·
14 revisions
###On this section we will list all the pubsubsettings that you can use as mosca brokers (plus the options for each one).
var pubsubsettings = {
//using ascoltatore
type: 'mongo',
url: 'mongodb://localhost:27017/mqtt',
pubsubCollection: 'ascoltatori',
mongo: {}
};
Mongo options:
-
url
: the mongodb url (default: 'mongodb://localhost:27017/ascoltatori?auto_reconnect') -
pubsubCollection
: where to store the messages on mongodb (default: pubsub) -
mongo
: settings for the mongodb connection
var pubsubsettings = {
type: 'redis',
redis: require('redis'),
db: 12,
port: 6379,
return_buffers: true, // to handle binary payloads
host: "localhost"
};
Redis options:
-
port
, the optional port to connect to; -
host
, the optional host to connect to; -
db
, the database to connect to (defaults to 0); -
password
, the optional password to use; -
sub_conn
, the optional redis connection to use for the sub and psub commands; -
pub_conn
, the optional redis connection to use for the pub command; -
redis
, the redis module (it will automatically be required if not present).
var pubsubsettings = {
type: 'mqtt',
json: false,
mqtt: require('mqtt'),
host: '127.0.0.1',
port: 1883
};
Mosquitto options:
-
clientId
, the id of the MQTT client (max 23 chars) -
keepalive
, the keepalive timeout in seconds (see the MQTT spec), the default is 3000; -
port
, the port to connect to; -
host
, the host to connect to; -
mqtt
, the mqtt module (it will automatically be required if not present).
var pubsubsettings = {
type: 'amqp',
json: false,
amqp: require('amqp'),
exchange: 'ascolatore5672'
};
Amqp options:
-
client
, which is passed through to the amq.createConnection method; -
exchange
, the exchange name; -
amqp
, the amqp module (it will automatically be required if not present);
You can use any of the QlobberFSQ constructor options, for example:
var pubsubsettings = {
type: 'zmq',
json: false,
zmq: require("zmq"),
port: "tcp://127.0.0.1:33333",
controlPort: "tcp://127.0.0.1:33334",
delay: 10
};
-
port
, the zmq port where messages will be published; -
controlPort
, the zmq port where control messages will be exchanged; -
remotePorts
, the remote control ports that will be connected to; -
zmq
, the zmq module (it will automatically be required if not present); -
delay
, a delay that is applied to theready
andclosed
events (the default is 5ms);
You could just use NO settings at all and store everything in memory and not in a pub/sub broker
##Further Configuration
###A few known events to listen for:
-
clientConnected
: when a client is connected; the client is passed as a parameter. -
clientDisconnecting
: when a client is being disconnected; the client is passed as a parameter. -
clientDisconnected
: when a client is disconnected; the client is passed as a parameter. -
published
: when a new message is published; the packet and the client are passed as parameters. -
delivered
: when a client has sent back a puback for a published message; the packet and the client are passed as parameters. -
subscribed
: when a client is subscribed to a topic; the topic and the client are passed as parameters. -
unsubscribed
: when a client is unsubscribed to a topic; the topic and the client are passed as parameters.
###Other options of mosca (the ones we inserted in our moscaSettings var) Mosca Options:
-
port
, the port where to create the server. -
host
, the IP address of the server (see http://nodejs.org/api/net.html#net_server_listen_port_host_backlog_callback). -
backend
, all the options for creating the Ascoltatore (we pass the pubsubsettings var on this one) that will power this server. -
ascoltatore
, By default mosca creates an ascoltatore instance under the hood. With this setting you can pass your own ascoltatore instance. (If you set that theres no need to set thebackend
) -
maxInflightMessages
, the maximum number of inflight messages per client. -
logger
, the options for Bunyan. (Example: {level: 'debug'} ) -
logger.childOf
, the parent Bunyan logger. -
persistence
, the options for the persistence. A sub-keyfactory
is used to specify what persistence to use. -
secure
, an object that includes three properties: -
port
, the port that will be used to open the secure server -
keyPath
, the path to the key -
certPath
, the path to the certificate -
allowNonSecure
, starts both the secure and the unsecure sevrver. -
http
, an object that includes the properties:-
port
, the port that will be used to open the http server -
bundle
, serve the bundled mqtt client -
static
, serve a directory -
stats
, publish the stats every 10s (default false).
-
##Persistence
You can use Mongo, Redis and LevelUp for persistence storage (mostly for the offline messages feature)
Below are the options you can use for persistence.
-
url
, the connection URL of the database -
ttl
, an object containing two values:-
subscriptions
, the time (ms) after which subscriptions will expire. It defaults to 1 hour. -
packets
, the time (ms) after which packets will expire. It defaults to 1 hour.
-
-
mongo
, all the options for the MongoDB driver. -
connection
, a MongoDB client to be reused (optional) - thats if you already have a MongoDB client that you use.
-
port
, the Redis' port. -
host
, the Redis' host. -
password
, the Redis' password. -
redisOpts
, the options for the Redis client. -
channel
, the pub/sub channel that will be used to synchronize the various clients. Defaults to'moscaSync'
. -
ttl
, an object containing three values:-
subscriptions
, the time (ms) after which subscriptions will expire. It defaults to 1 hour. -
packets
, the time (ms) after which packets will expire.
-
LevelUp options:
-
path
, the path to the database -
ttl
, an object containing three values:-
checkFrequency
, the frequency at which the the expiration will be checked. It defaults to 1 minute. -
subscriptions
, the time (ms) after which subscriptions will expire. It defaults to 1 hour. -
packets
, the time (ms) after which packets will expire. It defaults to 1 hour.
-
-
db
, the AbstractLevelDown implementation. - all other
levelup
options.