2016年7月27日 星期三

RTMP

https://www.vultr.com/docs/setup-nginx-rtmp-on-ubuntu-14-04 Setup Nginx-RTMP on Ubuntu 14.04 Modified on: Wed, Jul 20, 2016 at 5:45 pm EST Linux Guides Ubuntu Web Servers RTMP is great for serving live content. When RTMP is paired with FFmpeg, streams can be converted into various qualities. Vultr is great for these applications as they provide fast and dedicated CPU performance. Vultr’s global network also ensures that you can deliver high quality live content with minimal delay. Lets get started! Installing Nginx and Nginx-RTMP Install the tools required to compile Nginx and Nginx-RTMP from source. sudo apt-get install build-essential libpcre3 libpcre3-dev libssl-dev Make a working directory and switch to it. mkdir ~/working cd ~/working Download the Nginx and Nginx-RTMP source. wget http://nginx.org/download/nginx-1.7.5.tar.gz wget https://github.com/arut/nginx-rtmp-module/archive/master.zip Install the Unzip package. sudo apt-get install unzip Extract the Nginx and Nginx-RTMP source. tar -zxvf nginx-1.7.5.tar.gz unzip master.zip Switch to the Nginx directory. cd nginx-1.7.5 Add modules that Nginx will be compiled with. Nginx-RTMP is included. ./configure --with-http_ssl_module --add-module=../nginx-rtmp-module-master Compile and install Nginx with Nginx-RTMP. make sudo make install Install the Nginx init scripts. sudo wget https://raw.github.com/JasonGiedymin/nginx-init-ubuntu/master/nginx -O /etc/init.d/nginx sudo chmod +x /etc/init.d/nginx sudo update-rc.d nginx defaults Start and stop Nginx to generate configuration files. sudo service nginx start sudo service nginx stop Installing FFmpeg Add the FFmpeg PPA. sudo apt-get install software-properties-common sudo add-apt-repository ppa:kirillshkrogalev/ffmpeg-next Update the package lists. sudo apt-get update Install FFmpeg. sudo apt-get install ffmpeg Note: The apt-add-repository command may not be installed in some cases. To install it run sudo apt-get install software-properties-common. Configuring Nginx-RTMP and FFmpeg Open the Nginx configuration file. sudo nano /usr/local/nginx/conf/nginx.conf Append the following. rtmp { server { listen 1935; chunk_size 4096; application live { live on; record off; exec ffmpeg -i rtmp://localhost/live/$name -threads 1 -c:v libx264 -profile:v baseline -b:v 350K -s 640x360 -f flv -c:a aac -ac 1 -strict -2 -b:a 56k rtmp://localhost/live360p/$name; } application live360p { live on; record off; } } } After you've added the above, you can customize settings such a video bitrate, audio bitrate and resolution. These changes will only be applied to the lower quality stream. To add more qualities, copy and paste the exec ffmpeg line and change the settings. You'll also need to create a new application. You can do this by copying and pasting the live360 example that has been included. Don't forget to update the exec ffmpeg line with the address of the new application. You can do this by changing the final RTMP address in the exec ffmpeg line. Note: Changing the value after -b:v will change the video bitrate. This is measured in kilobits per second. Changing the value after -b:a will change the audio bitrate. This is measured in kilobits per second. Changing the value after -s will change the resolution. Save the file by pressing Control and X together. Restart Nginx. sudo service nginx restart Note: For best performance, each stream being converted should have its own CPU core. For example two qualities, 360P and 480P are being created from a 720P stream. A Vultr instance with at least two CPU cores should be used. Security Note If you're using a firewall, you'll need to make sure TCP 1935 is allowed. The current configuartion allows anyone to stream to your server. We can fix this by only allowing certain IP addresses the publish permission. Open the Nginx configuration. sudo nano /usr/local/nginx/conf/nginx.conf Look for the following lines. live on; record off; Add the following to each set of the above lines. Change 0.0.0.0 to your IP address. allow publish 127.0.0.1; allow publish 0.0.0.0; deny publish all; The configuration should now look something like this. rtmp { server { listen 1935; chunk_size 4096; application live { live on; record off; allow publish 127.0.0.1; allow publish 0.0.0.0; deny publish all; exec ffmpeg -i rtmp://localhost/live/$name -threads 1 -c:v libx264 -profile:v baseline -b:v 350K -s 640x360 -f flv -c:a aac -ac 1 -strict -2 -b:a 56k rtmp://localhost/live360p/$name; } application live360p { live on; record off; allow publish 127.0.0.1; allow publish 0.0.0.0; deny publish all; } } } Save the file by pressing Control and X together. Restart Nginx. sudo service nginx restart Configuring Software to Work with Nginx-RTMP Streaming applications typically have two fields for connection information. The first field is usually for the server information and the second field is usually for the stream name or key. The information that you should place into each field is listed. The stream name or key can be set to anything. Field 1: rtmp://your.vultr.ip/live/ Field 2: stream-key-you-set To view streams open the following links in a player supporting RTMP. rtmp://your.vultr.ip/live/stream-key-you-set rtmp://your.vultr.ip/live360p/stream-key-you-set

2016年7月26日 星期二

openswan

sudo /etc/init.d/ipsec restart sudo ipsec auto --add test sudo ipsec whack --name test --listen --initiate conn test left=%eth2 leftsourceip=10.20.90.1 leftsubnet=10.20.90.0/24 # leftid=116.59.9.76 leftid=@00A6C2278850 right=61.216.103.2 # rightid=61.216.103.2 rightid=@18B1690131A0 rightsubnet=10.9.8.0/24 rightnexthop=10.9.8.254 rekeymargin=3m keyingtries=2 pfs=no aggrmode=yes ike=3des-sha1-modp1024 # ikev2=yes phase2=esp phase2alg=3des-sha1 authby=secret ikelifetime=28800s auto=start rm /var/run/pluto -rf mkdir /var/run/pluto -p ifconfig ppp0 | grep 'inet addr:' | cut -d: -f2 | awk '{ print $1}' echo @00A6C2278850 @18B1690131A0 : PSK \"25683366\" > /etc/ipsec.secrets killall -9 pluto /usr/libexec/ipsec/pluto --stderrlog --nofork --use-netkey --secretsfile /etc/ipsec.secrets --nat_traversal & /usr/libexec/ipsec/whack --name sonic --ipv4 --host 10.183.128.223 --client 10.20.90.0/24 --srcip 10.20.90.1 --id @00A6C2278850 --to --host 61.216.103.2 --client 10.9.8.0/24 --srcip 61.216.103.2 --id @18B1690131A0 --esp 3des-sha1 --ike 3des-sha1-modp1024 --encrypt --psk --aggrmode /usr/libexec/ipsec/whack --name sonic --listen --initiate

2016年7月22日 星期五

SDK

https://www.dropbox.com/sh/8pyvpyccs56flq2/AACDWO5ig2-GvOeJoEpw8urha?dl=0

2016年7月11日 星期一

testtw

var watson = require('watson-developer-cloud'); var fs = require('fs'); var cp = require('child_process'); var Sound = require('node-aplay'); console.log('start tw watson regonition'); opencmd(); function opencmd() { var speech_to_text = watson.speech_to_text({ username: 'c8090707-bcda-49e0-98f9-172c40420c1a', password: 'cZGWayUpvsSJ', version: 'v1' }); var params = { content_type: 'audio/wav', model: 'zh-CN_BroadbandModel', continuous: true }; // create the stream var recognizeStream = speech_to_text.createRecognizeStream(params); // pipe in some audio //fs.createReadStream('/home/pi/voice/interlude/help.wav').pipe(recognizeStream); // start the recording var mic = cp.spawn('arecord', ['--device=plughw:0,0', '--format=S16_LE', '--rate=44100', '--channels=1']); //, '--duration=10' mic.stderr.pipe(process.stderr); // save a local copy of your audio (in addition to streaming it) by uncommenting this //mic.stdout.pipe(require('fs').createWriteStream('test.wav')); // optionally compress, and then pipe the audio to the STT service mic.stdout.pipe(recognizeStream); // alternate option for testing: comment out all of the mic/flac stuff and pipe from a file //require('fs').createReadStream('test.wav').pipe(transcriptInput); //new Sound('/home/pi/voice/interlude/pleasesay.wav').play(); // end the recording setTimeout(function() { mic.kill(); }, 45* 5000); // and pipe out the transcription //recognizeStream.pipe(fs.createWriteStream('transcription.txt')); //new Sound('/home/pi/voice/interlude/pleasesay.wav').play(); // listen for 'data' events for just the final text // listen for 'results' events to get the raw JSON with interim results, timings, etc. recognizeStream.setEncoding('utf8'); // to get strings instead of Buffers from `data` events /* // listen for 'data' events for just the final text recognizeStream.on('results', function(data) { if(data.results[0] && data.results[0].final && data.results[0].alternatives) { console.log('xxxxx'+data.results[0].alternatives[0].transcript); } //console.log.bind(console, 'data event: '); //var transcription = converter.toBuffer(); //console.log(transcription); }); */ // listen for 'data' events for just the final text recognizeStream.on('error', function() { console.log.bind(console, 'error event: '); //var transcription = converter.toBuffer(); // console.log(transcription); }); // listen for 'data' events for just the final text recognizeStream.on('data', function(data) { console.log('xxxxx'+data); console.log.bind(console, 'data event: '); // var transcription = converter.toBuffer(); // console.log(transcription); }); //['data', 'error', 'connection-close'].forEach(function(eventName) { // recognizeStream.on(eventName, console.log.bind(console, eventName + ' event: ')); //}); }

0109temp.js

var watson = require('watson-developer-cloud'); var mqtt = require('mqtt'); var clientId = ['d', "49fhje", "vehicle", "mycar"].join(':'); iot_client = mqtt.connect("mqtt://49fhje.messaging.internetofthings.ibmcloud.com:1883", { "clientId" : clientId, "keepalive" : 30, "username" : "use-token-auth", "password" : "yz(GjvSahc95RQ2jEo" }); var temploop=[ 12, 33, 22, 34, 26, 35, 27]; var i=0; iot_client.on('connect', function() { console.log('Temp client connected to IBM IoT Cloud.'); var interval = setInterval(function() { console.log("temp: " + temploop[i%7]); iot_client.publish('iot-2/evt/temp/fmt/json', '{"d":{"temp": '+ temploop[i%7] +' }}'); i++; }, 2000); } ); iot_client.subscribe('iot-2/cmd/+/fmt/+', function(err, granted){ console.log('subscribed command, granted: '+ JSON.stringify(granted)); }); iot_client.on("message", function(topic,payload){ console.log('received topic:'+topic+', payload:'+payload);});

2016年7月10日 星期日

https://sourceforge.net/projects/sox/files/latest/download?source-files