RでWebアプリケーションを開発するためのパッケージShinyをWebアプリケーションとして動作させるためのサーバ。オンプレミスの有償版は金額が高く、ホスティングサービスは無償アカウントもあるがデータを外部のサーバに置くのは問題が多いため、オープンソース版を使う。いくつかのOSではパッケージが用意されているが、Gentoo向けには無いのでソースからビルドする。
Pythonと親和性が高いGentooでは特に事前にインストールするものはない。R自体はインストールする必要がある。
基本的にマニュアル通り。以前は1ステップ必要な手順が抜けていて、コミュニティの書き込みを参照する必要があったが、修正されているようだ。
> git clone https://github.com/rstudio/shiny-server.git > cd shiny-server > mkdir tmp > cd tmp > ../external/node/install-node.sh # 環境変数をセット > DIR=`pwd` > PATH=$DIR/../bin:$PATH > cmake -DCMAKE_INSTALL_PREFIX=/usr/local ../ > make > mkdir ../build > (cd .. && ./bin/npm install) > (cd .. && ./bin/node ./ext/node/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js rebuild) > make install # 設定ファイルを配置するディレクトリの作成 > mkdir /etc/shiny-server > cp ../config/default.config /etc/shiny-server/shiny-server.conf
shinyユーザを作成し、各種ディレクトリ等を作成する。
今回は、/home/shinyをホームディレクトリとしたshinyユーザを作成し、各種ディレクトリもここに集約する。shinyユーザにはシェルを与えずログインできないようにしておく。
/etc/shiny-server/shiny-server.confを上記ディレクトリ構成にあわせて設定する。
マニュアルにはないが、bookmarksディレクトリを書き込み可能な形で設定しておかないと、サーバが起動しない。
# Instruct Shiny Server to run applications as the user "shiny"                                                    
run_as shiny;
# Define a server that listens on port 3838                                                                        
server {
  listen 3838 0.0.0.0;
  # Define a location at the base URL                                                                              
  location / {
    # Host the directory of Shiny Apps stored in this directory                                                    
    site_dir /home/shiny/server;
    # Log all Shiny output to files in this directory                                                              
    log_dir /home/shiny/log;
    # Bookmark dir                                                                                                 
    bookmark_state_dir /home/shiny/bookmarks;
    # When a user visits the base URL rather than a particular application,                                        
    # an index of the applications available in this directory will be shown.                                      
    directory_index on;
  }
}
Gentoo OpenRC用の起動スクリプト。
注意点は、start-stop-daemonのオプション「–background」「–make-pidfile」をつけておくこと。
shinyは勝手にバックグラウンドにならないのでbackgroundオプションで切り離し、 pidファイルも生成しないのでmake-pidfileでpidfileオプションで指定した場所にpidファイルを吐き出させる。これでstop関数が正常に動作する。
#!/sbin/openrc-run
# Copyright 1999-2016 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
description="R Shiny Server"
pidfile="/var/run/shiny-server.pid"
command="/usr/local/shiny-server/bin/shiny-server"
depend() {
        use net
}
start() {
        ebegin "Starting Shiny Server"
        start-stop-daemon --start --quiet --background --make-pidfile --pidfile ${pidfile} --exec ${command} \
        >> /home/shiny/log/shiny-server.log 2>&1
        eend $?
}
stop() {
        ebegin "Stopping Shiny Server"
        start-stop-daemon --stop --quiet --pidfile ${pidfile}
        eend $?
}