mq(4) — message queue

Mq serves a 9p file tree representing groups of buffered two-way data
streams for multiple readers and writers accessible through the
standard read(2) and write(2) file I/O interface.


Streams may be organized within an arbitrary file tree structure, which
provides a means of namespacing and grouping.


A directory denotes a group of streams.  Any number of streams and
sub-groups may be created within a group.  Grouped streams share
configuration and an order file.

The read-only meta-stream called order provides ordering information for
data written to streams within a group.  Special readers such as
`mq-cat(1)` can tap into this stream to retrieve data coming from
multiple streams in the same order it was written.

See the [`mq(4)`][mq] manual page for a complete
description of supported data modes, queue replay options, usage reference,
and other details.


Mount the `mq(4)` file server and use it to persist an `rc(1)` shell session.

	mq -s detach
	mount -c /srv/detach /n/detach
	mkdir /n/detach/rc
	cd /n/detach/rc
	echo replay all >ctl
	touch fd0 fd1 fd2
	rc -i <fd0 >>fd1 >>[2]fd2 &

Attach to the shell:

	cat fd1 & cat fd2 & cat >>fd0

The program [`pin(1)`][pin] provides a polished interface for persisting
program sessions.  It also makes use of the data ordering feature for
faithful reproduction of session history.

The program `mq-cat(1)` is an example of an ordered multi-stream reader.

[mq]: http://a-b.xyz/95/34b5
[pin]: http://a-b.xyz/9b/2151
Last 5 commits (shortlog)
Date Author Short message Commit hash
2021-01-27 kvik mq: limit root directory permission ca32bdbe21c2092e50d6945950463a76520f499f
2021-01-20 kvik mq: naming is hard, try again 0f2488ea74810014cded7398098a29cdea01fcd2
2021-01-17 kvik mq: fix Tcreate handling e4ac0181296586a41efb642e962281f03c099c2a
2021-01-07 kvik mkfile: remove the 'package' target 0768b64ca8608e7f6f374a139d0f921d06c6a24e
2020-12-27 kvik mq: appease "non-interruptable temporary" warnings a163296abcd761fab9bfeae31de4a8a89d6f15c1
Files (browse)