第12章 開発の基本的な流れ

この章では Armadillo-IoT G3 を使ったアプリケーションソフトウェアの 開発方法について説明します。

Armadillo-IoT G3を使ったアプリケーションソフトウェア開発には、 Ruby等の軽量スクリプト言語を使うことができます。

新たにパケット通信、各種アドオンボードを利用したセンサーからのデータ読み出し を実装したアプリケーションプログラムを実装するときは、Ruby等の軽量スクリプト言語を 使った開発をお勧めします。

Armadillo-IoT G3 の出荷用のユーザーランドには、最初からRubyインタプリタ がインストールされているので、PCと同じように開発を進めることができます。

もちろん、Rubyに限らず、Debian の提供する豊富なパッケージ群から Python や Go、 Haskel といったスクリプト言語を自由にインストールして使うことも可能です。

12.1. 軽量スクリプト言語によるセンサーデータの送信例(Ruby)

ここでは、サンプルとしてArmadillo-IoT G3 に搭載された温度センサーの値を 定期的に HTTP POST でパラメータ名 "temp" に格納した値として送信する例を示します。

温度センサーからの値の取得は sysfs から可能です。

ここで作成するアプリケーションはArmadillo-IoT G3で動作するクライアントと ATDEで動作するテスト用のサーバーの2つです。 ATDEで動作させるためのテスト用のサーバーは、典型的なHTTPプロトコルで アクセスできるWeb APIを持ったサービスを模擬しています。テスト用サーバーは 単に入力されたPOST リクエストの内容を変数に格納してコンソールに出力し、 クライアントには"Thanks!"という文字列を返します。

12.1.1. テスト用サーバーの実装

最初に ATDE にテスト用サーバーの動作に必要なパッケージをインストールします。

[ATDE ~]$  sudo apt-get install ruby
[ATDE ~]$  sudo gem install sinatra-contrib

図12.1 ruby と sinatra のインストール


次にエディタで次のコードを入力して、server.rb として保存してください。

require 'sinatra'

post '/' do
  puts "Temperature is #{params[:temp]}"
  "Thanks!\n"
end

図12.2 テスト用サーバー (server.rb)


12.1.2. テスト用サーバーの動作確認

Armadillo-IoT G3 でクライアントアプリケーションを動かす前に、テスト用サーバーの動作確認を行います。 動作確認は Armadillo-IoT G3 から cURL コマンドを使って、クライアントアプリケーションと同等の リクエストを送ってみます。

まず、ATDE の IPアドレス を確認しておきます。下記の例では、ip コマンドで確認するとATDE のIPアドレス が 172.16.2.117 であることがわかります。

[ATDE ~]$  ip addr
      2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UNKNOWN group default qlen 1000
    link/ether 00:0c:29:30:b0:e0 brd ff:ff:ff:ff:ff:ff
    inet 172.16.2.117/16 brd 172.16.255.255 scope global dynamic enp0s3
       valid_lft 65913sec preferred_lft 65913sec
    inet6 fe80::20c:29ff:fe30:b0e0/64 scope link
       valid_lft forever preferred_lft forever

図12.3 IPアドレスの確認 (ipコマンド)


次の例のように server.rb を実行すると、全てのIPアドレスからのリクエストを 8081番ポートでWebサーバーとして待ち受けます。

[ATDE ~]$  ruby server.rb -p 8081 -o 0.0.0.0
[2016-03-28 16:02:15] INFO  WEBrick 1.3.1
[2016-03-28 16:02:15] INFO  ruby 2.1.5 (2014-11-13) [i386-linux-gnu]
== Sinatra (v1.4.7) has taken the stage on 4567 for development with backup from WEBrick
[2016-03-28 16:02:15] INFO  WEBrick::HTTPServer#start: pid=10849 port=8081
    

ここで、Armadillo-IoT G3 から cURL を使ってテストデータを送ってみましょう。正しく通信できた場合は、"Thanks!" の文字列が表示されます。もし、"Connection refused" 等が表示された場合は、一旦 ATDE のIPアドレスに ping を送信してネットワークの設定に問題が無いか確認してください。

[Armadillo ~]$   curl -d "temp=30" 172.16.2.117:8081
Thanks!

図12.4 curl によるテストデータの送信


正しく受信できた場合は、ATDEで起動しているテスト用サーバーが起動しているコンソールに下記の文字列が出力されます。

Temperature is 30

図12.5 ATDE におけるテストデータの受信表示


12.2. クライアントの実装

Armadillo-IoT G3 で動作するクライアントを実装します。下記のコードをエディタで入力して、client.rb として保存してください。ファイルは、ATDE 上で作成しても Armadillo-IoT G3 上で、vi等を使って作成しても構いません。ATDE で作成した場合は次の手順で、Armadillo-IoT G3 へ転送します。

require 'net/http'

uri = URI.parse(ARGV[0])
thermal_sys = "/sys/class/thermal/thermal_zone0/temp"
File.open(thermal_sys, "r") do |f|
  @temp=(f.read.to_f/1000).round(2)
end
response = Net::HTTP.post_form(uri, {"temp" => @temp})

puts response.body

図12.6 温度送信クライアント(client.rb)


12.3. Armadillo-IoT G3へのファイルの転送

ATDE 上で作成したソースコードを Armadillo-IoT G3 に配置する方法の一例として、 ここでは、SSH を使った転送方法を説明します。

[armadillo ~]#  apt-get install openssh-server

図12.7 Armadillo-IoT G3 へのSSHサーバーのインストール


[ATDE ~]$ scp client.rb atmark@[armadilloのIPアドレス]:~/

図12.8 ATDE から Armadillo-IoT G3 への client.rb の転送


12.4. クライアントの実行

作成した温度送信クライアントを実行します。第一引数にはテスト用サーバーが動いているATDEのIPアドレスとポートをHTTPスキーマのURIで記述してください。

[armadillo ~]#  ruby client.rb  http://172.16.2.117:8081
Thanks!

図12.9 クライアントの実行方法


正しくクライアントとの通信ができた場合、ATDEで動作しているサーバーのコンソールには小数点以下2ケタの温度が表示されます。

Temperature is 33.02

図12.10 ATDE における温度データの受信表示


12.5. C言語による開発環境

C/C++等の資産がある場合は、Armadillo上でgcc/g++を使ってアプリケーションを コンパイルする事もできます。

12.5.1. 開発環境の準備

アプリケーションをコンパイルするために、Armadilloにgcc等を含むツールチェーンを インストールします。 Armadilloのコンソールで次のコマンドを実行してください。

[armadillo ~]#  apt-get install build-essential

図12.11 ツールチェーンのインストール


これで、gcc, make, gdb等が使えるようになりました。 次に、アプリケーションのビルドに必要なライブラリとヘッダーファイルを インストールします。例えば libssl であれば次のコマンドでインストールする ことができます。

[armadillo ~]#  apt-get install libssl-dev

図12.12 開発用パッケージのインストールの例 (libsslの場合)


例に示すように、コンパイルに必要なヘッダーファイルを含むパッケージは、 普通 -dev という名前が付いています。

[ティップ]

必要なヘッダファイルの名前や、共有ライブラリのファイル名がわかっている 場合は、Debian プロジェクトサイトの「パッケージの内容を検索」からファイルの 含まれるパッケージの名前を探す事ができます。

Debian -- パッケージ パッケージの内容を検索 https://www.debian.org/distrib/packages#search_contents

また、パッケージの部分的な名前が分っている場合は「パッケージ管理」で紹介した、 apt-cache search コマンドを使って必要なパッケージを探す事もできます。