Bokeh-Server: Terima TCP Multiline dengan x axis datetime
Jump to navigation
Jump to search
ERROR
Cara ini akan memberikan ERROR
E-1000 (COLUMN_LENGTHS): ColumnDataSource column lengths are not all the same
Masih belum tahu bagaimana cara mengatasinya
client.py
import sys import time import socket import random # Create a TCP/IP socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # Connect the socket to the port where the server is listening server_address = ('192.168.0.100', 2000) sock.connect(server_address) try: for i in xrange(100): m0 = random.random() m1 = random.random() message = "%1.4f" % m0 + " %1.4f" % m1 print >>sys.stderr, 'sending ' , message sock.sendall(message) time.sleep(0.5) finally: print >>sys.stderr, 'closing socket' sock.close()
server.py
import sys import time import datetime import socket from bokeh.plotting import figure, output_server, show, cursession output_server("raw",url='http://192.168.0.100:5006') # Visualization workflow ana1 = [0] ana2 = [0] x = [0] n = datetime.datetime.now() x = ['%d.%d'%(n.minute*60+n.second,n.microsecond)] p = figure(x_axis_type="datetime") p.multi_line([x, ana1],[x, ana2], color=["firebrick","navy"],name='raw') # Create a TCP/IP socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # Bind the socket to the port server_address = ('192.168.0.100', 2000) print >>sys.stderr, 'starting up on %s port %s' % server_address sock.bind(server_address) # Listen for incoming connections sock.listen(1) show(p) renderer = p.select(dict(name="raw")) ds = renderer[0].data_source while True: # Wait for a connection print >>sys.stderr, 'waiting for a connection' connection, client_address = sock.accept() try: print >>sys.stderr, 'connection from', client_address while True: data = connection.recv(20).split() ana1 += data[0] ana2 += data[1] if len(data) == 0: break n = datetime.datetime.now() x += ['%d.%d' %(n.minute*60+n.second,n.microsecond)] ds.data["x"] = x ds.data["ana1"] = ana1 ds.data["ana2"] = ana2 cursession().store_objects(ds) time.sleep(0.01) finally: # Clean up the connection connection.close()