Dive into Grandstack

May 15, 2021

とりあえず、GRANDstack


GRANDstackは、Solution stackに分類されます。 皆さんがよく知っているスタックはいくつかあると思います。 私はMacをよく使っていたので、MAMPとか使ってました。

  1. LAMP (Linux, Apache, MySQL, PHP)
  2. LAPP (Linux, Apache, PostgreSQL, PHP)
  3. ELK (Elasticsearch, Logstash, Kibana)

その中でGRANDstackは非常に面白い今風な構成になっています。 なんと言っても、GraphQLが使われているところが目を引くところです。 GraphQLはAPIのためのクエリ言語でよく使われているREST(Representational State Transfer)とは違うアプローチで実装されています。 名前に Graph と付いているのでグラフデーターベース用と勘違いされそうですが、RDB, NoSQL, GraphDBなど全て使えますのでグラフデータベースに特化したものではありません。

  1. GRANDstack (GraphQL, React, Apollo, Neo4j Database)

今回は、下記のサイトを参照して書きました。

まずは迷わず簡単に作れる事を目指して日本語にしていますので、この入門が終わってから下記のサイトを参照されると理解しやすいと思っています。

https://github.com/grand-stack/grand-stack-starter

準備


以下の材料を用意します。

なお、今回の作業はmacOSで行っています。

シェルがbashじゃなくzshだったりするので、コマンドのプロンプトが、$じゃなく%になっていますが驚かないで読み替えてください。

  1. PC
    • ターミナル (Terminal)
    • ウェブブラウザ (Chromeあたりがオススメ、IEは無理っぽいです)
    • npm (yarnでも良いです)
  2. インターネット回線
    • Boltプロトコルを使いますので 7687 ポートは通れるような環境

    grand-stack / grand-stack-starter のv0.2は、official Neo4j GraphQL Library に置き換えられてリリースされましたが、バグがありソースを修正する必要がありました。 2021-05-14にアップデートされた v0.2.1では修正されています。 新たに作る人は心配ありません。

作るもの


ローカルのPCからネット越しにデータを書き込んで検索ができるアプリを作ります。 さて、どのくらい簡単にできるかチャレンジしてみましょう。

30分あれば余裕だと思います。

  1. GRANDstackのアプリ
    • ローカルに、GRANDstackのアプリ
    • Neo4j SandBoxには、データベース

npmの確認


下記のどちらかのコマンドでバージョンを見てみましょう。

npx が使える5.2.0以上じゃないと困りますが、6系になっていれば良いと思います。

% npm -v
% npm --version

データベースを作成


  1. https://neo4j.com/sandbox/ にアクセス
  2. Launch the Free Sandbox をクリック
  3. Blank Sandbox を選択
  4. Launch Project をクリック

そうするとデータベースが作られます。 1分もかからないと思います。 このサーバは何もしないと3日間で削除されますので評価用だと思ってください。

Blank Sandbox

Connection detailsを開いて、あなた専用の項目をどこかにコピペしましょう。

Bolt URL

これらの項目をどこかにコピペするかブラウザをオープンしたままにしましょう。

  1. Username(初期値は簡単なのでコピペ不要)
  2. Password
  3. Bolt URL

下記に例をあげます。

Username: neo4j
Password: xxxxxxxxxxxxxxxxx
bolt://xxxxxxxxxxxxxxxxx:7687

GRANDstackアプリの作成


ターミナルを起動する

アプリケーション > ユーティリティ > ターミナル.app

アプリケーションのフォルダーを作る

ディレクトリーの名前は grandproj にしましたが自由につけてください

% pwd
/Users/<username>

% mkdir grandproj
% cd grandproj
% pwd
/Users/<username>/grandproj

アプリケーションを作る

% npx create-grandstack-app myNewApp
? Please choose which project template to use (Use arrow keys)
❯ React 
  React-TS 
  Angular 
  Flutter 
  API-Only 

ここでは、 React を選びましょう。

既に選択されているので、そのまま Return です。

? Install dependencies? Yes
? Initialize a git repository? No
? Now let's configure your GraphQL API to connect to Neo4j. If you don't have a 
Neo4j instance you can create one for free in the cloud at https://neo4j.com/san
dbox

Hit <Return> When you are ready.  

既に、Neo4j SandboxでDBを構築してますので Return します。

? Enter the connection string for Neo4j
    (use neo4j+s:// or bolt+s:// scheme for encryption) (bolt://localhost:7687) 

Sandboxの Bolt URL を入力します。

Websocket Bolt URL の長いURLではありません。

? Enter the Neo4j user neo4j

Sandboxの Username を入力します。

規定値の neo4j なので、そのまま Return します。

? Enter the password for this user (letmein) 

Sandboxの Password を入力します。

Initializing Project...
  ✔ Create GRANDstack App
    ✔ Creating directory '/Users/<username>/grandproj/myNewApp'
    ✔ Downloading latest release
    ✔ Extracting latest release
    ✔ Creating Local env file with configuration options...
    ✔ Creating scripts configuration...
    ✔ Removing unused templates:
       ✔ web-react-ts
       ✔ web-angular
       ✔ mobile_client_flutter
  ✔ Installing Packages with npm
    ✔ Installing GRANDstack CLI and dependencies
    ✔ Installing api dependencies
    ✔ Installing web-react dependencies

Thanks for using GRANDstack! We've created your app in '/Users/<username>/grandproj/myNewApp'
You can find documentation at: https://grandstack.io/docs


To start your GRANDstack web application and GraphQL API run:

        cd myNewApp
        npm run start

Then (optionally) to seed the database with sample data, in the api/ directory in another terminal run:

        npm run seedDb

The default application is a simple business reviews application. Feel free to suggest updates by visiting the open source template repo and opening an issue: https://github.com/grand-stack/grand-stack-starter/issues.

アプリケーションを動かす


プログラムを作ると画面にはどうやって動かすかが書いてあるのでそれを実行

% cd myNewApp
% npm run start

20:34:12 React | Starting the development server...
20:34:12 React | 
20:35:06 React | Compiled successfully!
20:35:06 React | 
20:35:06 React | You can now view grand-stack-starter-web-react in the browser.
20:35:06 React | 
20:35:06 React |   Local:            http://localhost:3000
20:35:06 React |   On Your Network:  http://xxx.xxx.xxx.xxx:3000
20:35:06 React | 
20:35:06 React | Note that the development build is not optimized.
20:35:06 React | To create a production build, use npm run build.
20:35:06 React | 

空のデータベースに初期データを作成


% cd grandproj/myNewApp/api
% npm run seedDb

> grand-stack-starter-api@0.0.1 seedDb /Users/<username>/grandproj/myNewApp/api
> babel-node src/seed/seed-db.js

Database seeded!

画面を表示しましょう


これで、GRANDstackのアプリケーションが動くようになりました。

アプリケーションを動かした時点で表示されていると思いますが、 再読み込みすると登録したデータが表示されます。

http://localhost:3000

localhost 3000

GraphQLのサーバにアクセス


今度はGraphQLのサーバに直接問い合わせを書いてみましょう。

今回作成されたデータの一部はこのようになっています。

Schema

スキーマの一部に Business がありますのでここに問い合わせを書いてみます。 プロパティは、 name address city state とたくさん書いてますが テストなので、 name だけでも構いません。

では、GraphQLのサーバにアクセスしましょう。

http://localhost:4001/graphql

このような問い合わせを書いて実行したら右のような値が帰ってきます。

{
  businesses{
    name
    address
    city
    state
  }
}

localhost 4001

SandBox側も見てみるとあたりまえですが同じデータがあるのが確認できます。

MATCH (n:Business) RETURN n

Match Business

簡単でしたか?


Ruby on Railsのscaffoldを使ってBlogアプリケーションを作りますが それと同じくらい簡単にアプリケーションが完成しました。

これをベースにオリジナルのアプリケーションが簡単に作れます。

GRANDstackのフレームワークでは、GraphQLの問い合わせを Cypherに変換して問い合わせをします。


Profile picture

Written by Koji Annoura who lives and works in Fukuoka Japan. You should follow them on X (Twitter)