Public | Automated Build

Last pushed: 14 days ago
Short Description
A modified build of ThingSpeak IoT platform
Full Description

This fork of ThingSpeak is what I'm using for my own IoT over on and various other sites.

Other than some cosmetic changes this is the same as the original, except we also generate a Docker image in which it's run.

Full instructions are over at

h1. ThingSpeak

"ThingSpeak": is an open source "Internet of Things" application and API to store and retrieve data from things using HTTP over the Internet or via a Local Area Network. With ThingSpeak, you can create sensor logging applications, location tracking applications, and a social network of things with status updates.

In addition to storing and retrieving numeric and alphanumeric data, the ThingSpeak API allows for numeric data processing such as timescaling, averaging, median, summing, and rounding. Each ThingSpeak Channel supports data entries of up to 8 data fields, latitude, longitude, elevation, and status. The channel feeds support JSON, XML, and CSV formats for integration into applications.

The ThingSpeak application also features time zone management, read/write API key management and JavaScript-based charts from Highslide Software / Torstein Hønsi.

Support for ThingSpeak is available on the "ThingSpeak Community": site which features a "Blog":, "Forum":, "Documentation":, and "Tutorials":

h3. Before You Begin

  1. Install Ruby 2, RubyGems, Rails 4, git, and a database like MySQL
  2. Download the application using git: git clone
  3. Change to the thingspeak directory and install the appropriate gems: sudo bundle install

h3. Configuration

  1. Set your database configuration file at config/database.yml (see config/database.yml.example for an example)
  2. Create the database: rake db:create
  3. Create the database tables: rake db:schema:load

h3. Run The Application

  1. Start the server: rails server

Your application will now be running at http://localhost:3000/

h2. Changing Application Text

Make changes to config/locales/en.yml
To avoid errors, please ensure your lines start with spaces, not tabs.
Set your application name using the 'application_name' key.

h2. (Optional) Email Setup

Set your domain, user_name, and password in config/environment.rb

h2. (Optional) Admin Setup

Open a rails console: <code>rails console</code> or <code>RAILS_ENV=production rails console</code>, depending on your environment
Add the admin user: <code>AdminUser.create!(email: 'YOUR_ADMIN_EMAIL@EXAMPLE.COM', password: 'YOUR_PASSWORD', password_confirmation: 'YOUR_PASSWORD')</code>
Exit the rails console: <code>exit</code>
Login via the admin web interface at: "http://YOUR_DOMAIN.COM/admin"

h1. Installation on clean install of Ubuntu 12.04 LTS

<code>sudo apt-get upgrade</code>
<code>sudo apt-get -y install build-essential mysql-server mysql-client libmysqlclient-dev libxml2-dev libxslt-dev git-core curl rubygems</code>
<code>\curl -sSL | bash -s stable</code>
<code>rvm install 2.1</code>
<code>git clone</code>
<code>cd thingspeak</code>
<code>bundle install</code>
<code>cp config/database.yml.example config/database.yml</code>
<code>rake db:create</code>
<code>rake db:schema:load</code>
<code>rails server</code>

h2. Upgrading existing installations

<code>git pull origin master</code>
<code>bundle install</code>
<code>rake db:migrate</code>
If your server is active you can restart it by going to the active terminal, hitting Ctrl-c, and then typing:
<code>rails server</code>

Docker Pull Command
Source Repository

Comments (0)