Edited at

気になるサービス・アプリまとめ【気になったものを随時追加】

気になるアプリ・サービスのリサーチ置き場。

docker hubのofficial repositoryやrancher2.0カタログ由来多め。

(まとめ、備忘録用なので、追記記述なし&追加順番も適当になると思います。)


From


  • Docker Hub - official repository

  • Rancher2.0カタログアプリ

  • etc...


気になるアプリ・サービス一覧


Firebase (update: 181120)


Firebaseとは、最近大きく注目を集めているMBaaS(Mobile Backend as a Service)、つまりモバイル開発のためのクラウド・ベースのバックエンドサービスです。2014年にGoogleに買収され、Google I/O 2016で新バージョンが発表されました。

ここでのバックエンドとはDB、認証、ストレージ、解析、メッセージングプラットフォームなど(詳細は公式サイト参照)で、主にネイティブアプリ向けのプラットフォームとして提供されています。

- 今Googleで最も熱いサービスFirebaseで、リアルタイムWebアプリをサクッと作ってみた



参考ページ

Web開発が捗るFirebase入門!JavaScriptで「Webユーザー認証」機能を超お手軽に作るチュートリアル大公開!

今Googleで最も熱いサービスFirebaseで、リアルタイムWebアプリをサクッと作ってみた

Firebaseの各機能を3行で説明する


redis (update: 181119)


Redisとは「remote dictionary server」から名前が付けられたオープンソースのkey-valueデータストアです。

MemcacheDB等のKVSとの最大の違いは、格納するバリューがデータ構造というところです。

つまり、リスト・セット・ハッシュなどのデータ構造で格納できるのでバリューに対してアトミックな操作ができます。

例えば、リストではプッシュしたりポップしたりできるのです。

これによって大規模なデータの操作をする時にデータ構造だけプログラムの外部で管理する事ができるので大変便利です。

- redis、それは危険なほどのスピード

Redisは万人にすすめられる、文句なしに最高に素晴らしい製品です。データベースというよりは、プログラミング言語の配列やマップをサーバ上でアトミックに安全に読み書きできる共有メモリ構造といった感じで、一時的なデータ置き場として使うことが多いですが、SQLしか使ってない人もみんな触れてみてほしいです。

- MongoDBの様なNoSQLに勢いがあるのは何故ですか?SQLと比べてどんな利点や欠点がありますか?



trial with docker


docker-compose.yml

version: "3.1"

services:
redis:
container_name: redis
image: redis



MongoDB (update: 181119)


MongoDBは、オープンソースソフトウェアのドキュメント指向データベースである。C++言語で記述されており、開発とサポートはMongoDB Inc.によって行なわれている。

- MongoDB - Wikipedia



ドキュメント型データベースとは?


ドキュメント型データベースとは、保存するデータ構造が自由なデータベースです。

一件分のデータはドキュメントと呼ばれ、JSONやXMLなどの記述書式で書かれたデータが保存されます。

容易にスケールアウトできるような構造をしたドキュメント型データベースが多いので、急なシステムの増強も可能です。

コンピュータの性能を向上させるスケールアップよりも、スケールアウトする方がコストは安く済むので、ドキュメント型データベースはコスト面でも有利なデータベースとなっています。

- ドキュメント型データベースとは



trial with docker (from official repository)


docker-compose.yml

version: '3.1'

services:

mongo:
image: mongo
restart: always
environment:
MONGO_INITDB_ROOT_USERNAME: root
MONGO_INITDB_ROOT_PASSWORD: example

mongo-express:
image: mongo-express
restart: always
ports:
- 8081:8081
environment:
ME_CONFIG_MONGODB_ADMINUSERNAME: root
ME_CONFIG_MONGODB_ADMINPASSWORD: example


authenticationエラーがでるので、ユーザの追加が必要。以下参照。

Enable Auth - Procedure

追記: environmentで指定したユーザ名とパスワードでも使えました。とりあえず試すだけなら、そちらでもよさそうです。


Kafka (update: 181119)


2011年にLinkedInから公開されたオープンソースの分散メッセージングシステムである.Kafkaはウェブサービスなどから発せられる大容量のデータ(e.g., ログやイベント)を高スループット/低レイテンシに収集/配信することを目的に開発されている.

- Apache Kafkaに入門した



セールスポイント



  • Fast とにかく大量のメッセージを扱うことができる

  • Scalable Kafkaはシングルクラスタで大規模なメッセージを扱うことができダウンタイムなしでElasticかつ透過的にスケールすることができる

  • Durable メッセージはディスクにファイルとして保存され,かつクラスタ内でレプリカが作成されるためデータの損失を防げる(パフォーマンスに影響なくTBのメッセージを扱うことができる)

  • Distributed by Design クラスタは耐障害性のある設計になっている

    - Apache Kafkaに入門した



Vault (update: 181119)


Vault を一言で言うと、機密情報(Secret) を管理するツールです。

- HashiCorp社が出したVaultとはどういうものなのか

これまで機密情報は - 格納される場所、メディアがバラバラ - その管理体系もバラバラ - アクセス権限もバラバラ - 誰がアクセスしたかの監査もできない という状態でした。これらを統合的に扱えるようにするシステムが Vault です。

- HashiCorp社が出したVaultとはどういうものなのか



JFrog (update: 181119)


オープンソースのソフトウェア配布ツールを作っている

- ソフトウェアの配布過程を自動化するJFrogが$50Mの巨額を調達して飛躍を目指す