node.js how to pipe a output from child process into a webpage

October 16, 2011

Reading time ~1 minute

This is a simple Node.js server that prints the output from a system command (in this example, its a tail program):

// how to pipe a output from child process into a webpage
    // start with importing an http server
    var http = require('http');
    // import the spawn function
    var spawn = require('child_process').spawn;
    // create the server bound to port at bottom
    http.createServer(function(request, response) {
    // write the header with 200 okay with content-type
    response.writeHead(200, {
    'Content-Type': 'text/plain'
    // everytime there is a new request, spawn an child process
    var tail_child = spawn('tail', ['-f', '/var/log/system.log']);
    // kill tail_child everytime the connection ends to keep from many processes being created
    request.connection.on('end', function() {
    // observe the output by binding to the data event
    // because javascript is not good at handling buffers, use the function for buffering data
    tail_child.stdout.on('data', function(data) {
    // write it on the console
    // send it to the browser because the browser will be waiting for the next chunk of data

Ruby's 'Interesting methods'

While in IRB and listing methods on an object, adding this new method to the Object allows for helpful listing of methods. Continue reading

SourceTree cli

Published on July 25, 2014

Augeas parsing errors

Published on March 28, 2014