/kyoto-a-api

Server side for A team in Kyoto

Primary LanguageKotlin

Server Side Application for SHABEL - Realime Messaging Application

概要

SHABELはLine SUMMER INTERNSHIP 2018 エンジニアスクールコースにてKyoto Aチームによって開発されたリアルタイムメッセージングアプリです。

このレポジトリではSHABELにおけるサーバーサイドアプリケーションを扱っています。 クライアントのレポジトリはこちらからアクセスできます。

開発環境

  • Kotlin
  • SpringBoot (REST API, STOMP over Websocket)
  • IntelliJ

デプロイ

  1. docs/nginx/kyoto_api.conf を /etc/nginx/conf.d/任意の名前.conf にコピー。

  2. コピーしたconfig fileを環境に合わせて書き換え。

  3. nginxを再起動

  4. docs/models.sqlをサーバー上で実行

    mysql -h localhost -u [user] -p < models.sql
  5. プロジェクトルートでGradleビルドを行う

    gradlew build
  6. build/libs/に作成されたjarファイルをサーバーに転送

  7. nohupを用いてバックグラウンドで実行

    sudo nohup java -jar api.jar &

実装機能

STOMP over Websocket

SHABELではリアルタイムでのメッセージのやり取りをSTOMP over Websocketを用いて実現しています。 STOMPはPub - Sub型のメッセージングプロトコルであり、TCP上、Websocket上で利用できますす。今回はWebsocket上での実装を行いました。

REST API

リアルタイム以外で情報を受け取る時はSTOMP上ではなくREST APIを叩いて取得するようになっています。

APIリファレンス

https://kyoto-a-api.pinfort.me/swagger-ui.htmlからSwagger UI形式のAPIリファレンスを見ることができます。