milkcocoaのiOSとNode.js SDKを実案件で使ってみた話
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932358/_____-4.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932636/2cdcf07a6205a78f0b8d19c8ee18888e.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932659/nodejs-image-processing.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932650/ios-logo.jpg)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932320/3d1d2a2d0ca697dc27fc44d6c98484c6.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932322/6d551da9a65ede10f45fc81742aff276.png)
(最近milkcocoa公認エバンジェリストに!)
株式会社LIG
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932328/______.jpeg)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932330/11.png)
伝説のウェブデザイナーを探して
・社長が砂浜に埋められる
秒速結婚
・結婚相手を募集して
すぐに結婚した社員
世界一即戦力な男
・あの男がLIGに入社
http://liginc.co.jp
おもしろネタな
イメージが強い会社です。
が
エンジニアもいてやることは
しっかりとやってますよ!
おもしろだけでは無い、
というイメージを作れれば幸いです。
私の歴史
1989年4月4日 宮城県栗原市で生誕
2014年7〜8月
Connpassでイベント漁りしている時期
milkcocoaハッカソンというタイトルを発見 調べてみた
http://connpass.com/event/8469/
2014年9月6,7日
MashupAwordのハッカソンで初めて利用
チュートリアルを見て感動
2014年9月9日
milkcocoaハッカソンに(終盤から)参加
2014年4月1日 LIGに入社
2014年9月26日
HTML5minutes!で登壇
http://slides.com/sugawararyousuke/milkcocoa-web/#/
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932984/2f78bd79a8fce79d76007ecb9943d418.png)
2014年10月18日
第21回 Creators Meetup で登壇
node-webkitとmilkcocoaでネイティブなチャットアプリ作る話
2014年11月14日
弊社ブログ (http://liginc.co.jp)で執筆
「インタラクティブコンテンツを作ろう!milkcocoaで5分のチャットアプリ制作」
http://liginc.co.jp/web/programming/server/129348
2014年12月
Qiitaでmilkcocoa系記事執筆しはじめる
milkcocoa iOSテスト版を使ってiOSとWebサイトを連動させてみるミニマム構成〜IoTっぽいことをする入門 http://qiita.com/n0bisuke/items/6b04d0a21b8b2c1eeec2
milkcocoaで接続出来るドメインを制限してみる。 http://qiita.com/n0bisuke/items/5b00f094eada60a438ea
フロント開発でメチャ活躍するmilkcocoaがサーバー側(Node.js)でも活躍してくれた。 http://qiita.com/n0bisuke/items/c6fa760e4bb480e95d2f
最近(2014年12月)
milkcocoaを実案件で使っている
詳細は後ほど
milkcocoaを実案件で使ってみた話
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932358/_____-4.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
1. milkcocoa ios SDK
2. milkcocoa Node.js SDK
milkcocoa iOS SDK
を使ったIoTな事例
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932650/ios-logo.jpg)
milkcocoa iOS SDK
・注: SDKはまだ開発中です
・Swift向けに限定的に使わせて頂きました。
参考: Milkcocoa iOSテスト版を使ってiOSとWebサイトを連動させてみるミニマム構成〜IoTっぽいことをする入門
http://qiita.com/n0bisuke/items/6b04d0a21b8b2c1eeec2
import UIKit
import Milkcocoa
class ViewController: UIViewController {
let milkcocoa = Milkcocoa(url:"https://{アプリid}.mlkcca.com")
override func viewDidLoad() {
super.viewDidLoad()
let dataStore = milkcocoa.dataStore("ios")
dataStore.on("send", { data in
println(data.value["msg"].asString!)
})
dataStore.send(["msg":"hello! JS! I am iOS"])
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
}
シンプルな使い方
ViewController.swift
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932653/be3427c13eb53c3299c59db0a98ceeb1.png)
Milkcocoa.framework
を通常にliblary追加する時のように読み込ませる
Step1: ライブラリ読込
Step2 : Cooding
作ったもの
社内受付システム
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932698/8501032051ef87543c64f62b63b48336.png)
ROMO
・手前味噌 iPhoneがラジコンになる知育ロボットRomoで遊んでみよう http://liginc.co.jp/web/programming/other-programming/130665
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932710/476.png)
・教育用 ラジコンロボット
・iPhoneを本体に接続して利用
・iOS向けのSDKが公開されている
受付システム構成
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932908/dfaacc75c5bb8c294d1ede592cfc2aa4.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
デモっぽいもの
公開されてるROMOの二種類のライブラリ
・RMCore : キャタピラ,LED,角度など物理的な操作
・RMCharacter: 表情,声,感情,目線などキャラクター操作
Web屋がIoTやる時のジレンマとmilkcocoa
・色々なデバイスとWebを繋げるため、Web以外の色々な言語や知識が必要となる。
・色々な言語やデバイスを使うのは楽しい。けど、全てを習熟させられる程時間は無い
(接続部分を作るだけでも結構時間掛かってしまうことも...)
デバイスの連携がカンタンに出来ればプロダクトの設計などメタレイヤーに集中出来る
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
接続部分はmilkcocoaに任せる
milkcocoa Node.js SDK
を使った
サーバー負荷分散な事例
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932659/nodejs-image-processing.png)
milkcocoa Node.js SDK
・注: SDKはまだ開発中です
・Node.js向けに試しに使ってみました。
参考: フロント開発でメチャ活躍するMilkcocoaがサーバー側(Node.js)でも活躍してくれた。
http://qiita.com/n0bisuke/items/c6fa760e4bb480e95d2f
月刊ライトニングトーク2014年10月号で
Technical Rockstarts 部谷氏が発表
var MilkCocoa = require("./milkcocoa");
var milkcocoa = new MilkCocoa("https://{アプリid}.mlkcca.com");
var ds = milkcocoa.dataStore("node");
ds.on("send", function(data) {
console.log(data);
});
ds.send({ msg : "Hellow Web I'm node.js"});
シンプルな使い方
app.js(Node.js)
・zipをダウンロード
・(zip内のindex.jsをmilkcocoa.jsに変更)
・require()するだけ
Step1: ライブラリ読込
Step2 : Cooding
$ wget http://cdn.mlkcca.com/nodejs/milkcocoa.zip
$ unzip milkcocoa.zip
$ cd milkcocoa
$ ls
README.md index.js sample.js
$ mv index.js milkcocoa.js
作っているもの
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932874/images.jpg)
Twitter連動型のインタラクティブなサイト
作っているもの構成(初期)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/933049/0716f5b30c36481693f2ac5258c44ca2.png)
※EC2とS3で分けるのは重要
作っているもの構成(今)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/933046/c14de5b929aa3444a9f1f3b5eec9ef1b.png)
時間、お金、知識が無くても同時アクセスをさばけるよ!
作っているもの全体像
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/933079/29dba2fc7fd73c951ac02523de1b78f2.png)
デモっぽいもの
...はまだ見せれません。
けど、
12月18日(木)にティザーサイト、
12月25日(木) クリスマスに
リリースします!
LIGブログをチェックしていて下さい!!
インタラクティブ時のジレンマとmilkcocoa
・インフラ側は同時アクセス数が大事
・アクセス時のオートスケールだったりに掛かる作業コストを含めた金額面は安く無い
ユーザーからの同時接続数を考える手間が無くなると、プロダクトの設計などメタレイヤーに集中出来る
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932362/439c3506071b7d5d7b8df86a9fba46ab.png)
接続部分はmilkcocoaに任せる
個人的に感じるmilkcocoaメリット
・フロントエンジニアでもインタラクティブコンテンツ
・マルチプラットフォーム
・チュートリアルやドキュメントが分かり易い
・Technical Rockstarsがサポートしてくれる
milkcocoaサポート
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932944/6cc440bbc74e705e8c36cb25c4bb76ba.png)
Node.jsのSDKで
文字化けが起こったけど
すぐに解決
milkcocoaサポート
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932935/24bf4261a0ad7f59e46263646a9de0f9.png)
iOS SDK使いたい!
といったら作ってくれた!
milkcocoaサポート
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932940/580a682bb596fdc8ca3748cefb949cce.png)
Swiftで使いたい!
といったらSwiftで
作ってくれた!
BaaSって他にも色々あるけど
Technical Rockstarsが
サポートしてくれるのがmilkcocoaの強みとして大きな要素
私の歴史(再掲)
1989年4月4日 宮城県栗原市で生誕
2014年4月1日 LIGに入社
2014年8月 milkcocoaを知る
2014年9月 milkcocoaハッカソン
2014年9月 ハッカソンでmilkcocoaを利用
2014年9月 html5minuts登壇
2014年10月 creators meetup登壇
2014年11月 milkcocoaでLIGブログ執筆
2014年12月 milkcocoaでQiitaに執筆
2014年12月 milkcocoaを案件で利用
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932601/14397d0ecbd84f2bb261c5cf9d0da208.png)
![](https://s3.amazonaws.com/media-p.slid.es/uploads/sugawararyousuke/images/932601/14397d0ecbd84f2bb261c5cf9d0da208.png)
milkcocoaが人生を変えた
milkcocoaと出会う前
milkcocoaと
出会った後
まとめ
・milkcocoa使うと自分の作りたいことに集中出来るよ
・milkcocoaはサポート強いから分からないことはどんどん聞こう
・人生変わったよ
まとめ
ありがとうございました。