multiplex

A binary stream multiplexer

  • 所有者: max-mapper/multiplex
  • 平台:
  • 許可證:
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

multiplex

A binary stream multiplexer. Stream multiple streams of binary data over a single binary stream. Like mux-demux but faster since it only works with binary streams.

NPM

api

var multiplex = require('multiplex')([options], [onStream])

Returns a new multiplexer. You can use this to create sub-streams. All data written to sub-streams will be emitted through this. If you pipe a multiplex instance to another multiplex instance all substream data will be multiplexed and demultiplexed on the other end.

onStream will be called with (stream, id) whenever a new remote sub-stream is created with an id that hasn't already been created with .createStream.

Options include:

  • opts.limit - set the max allowed message size. default is no maximum

Any other options set in options are used as defaults options when creating sub streams.

stream = multiplex.createStream([id], [options])

Creates a new sub-stream with an optional whole string id (default is the stream channel id).

Sub-streams are duplex streams.

Options include:

  • opts.chunked - enables chunked mode on all streams (message framing not guaranteed)
  • opts.halfOpen - make channels support half open mode meaning that they can be readable but not writable and vice versa

stream = multiplex.receiveStream(id, [options])

Explicitly receive an incoming stream.

This is useful if you have a function that accepts an instance of multiplex
and you want to receive a substream.

stream = multiplex.createSharedStream(id, [options])

Create a shared stream. If both ends create a shared stream with
the same id, writing data on one end will emit the same data on the other end

events

multiplex.on('error', function (err) {})

Emitted when the outer stream encounters invalid data

multiplex.on('stream', function (stream, id) {})

Emitted when a it a new stream arrives.

stream.on('error', function (err) {})

Emitted if the inner stream is destroyed with an error

example

var multiplex = require('multiplex')
var plex1 = multiplex()
var stream1 = plex1.createStream()
var stream2 = plex1.createStream()

var plex2 = multiplex(function onStream(stream, id) {
  stream.on('data', function(c) {
    console.log('data', id, c.toString())
  })
})

plex1.pipe(plex2)

stream1.write(new Buffer('stream one!'))
stream2.write(new Buffer('stream two!'))

contributing

multiplex is an OPEN Open Source Project. This means that:

Individuals making significant and valuable contributions are given commit-access to the project to contribute as they see fit. This project is more like an open wiki than a standard guarded open source project.

See the CONTRIBUTING.md file for more details.

contributors

multiplex is only possible due to the excellent work of the following contributors:

主要指標

概覽
名稱與所有者max-mapper/multiplex
主編程語言JavaScript
編程語言JavaScript (語言數: 1)
平台
許可證
所有者活动
創建於2013-12-19 04:19:01
推送於2018-07-08 17:12:29
最后一次提交2016-03-06 16:54:08
發布數20
最新版本名稱v6.7.0 (發布於 2016-03-06 16:54:08)
第一版名稱v4.0.0 (發布於 2014-11-09 23:03:51)
用户参与
星數143
關注者數11
派生數24
提交數99
已啟用問題?
問題數20
打開的問題數8
拉請求數11
打開的拉請求數3
關閉的拉請求數4
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?