ExploreModelMatrix on a Shiny server?While the installation of ExploreModelMatrix locally is a relatively straightforward operation, sometimes you might require an instance of it running on a server, e.g. for teaching purposes, or to provide a working version of it because you or your collaborators are lacking admin rights.
One possible solution would be to access the instance running at http://shiny.imbei.uni-mainz.de:3838/ExploreModelMatrix, which we provide also for demonstration purposes. Alternatively, you might need to deploy ExploreModelMatrix for internal use, or with a different set of examples/functionality. This vignette details the steps to do so - it might still require the intervention of your local IT service, and some degree of tech savvyness.
ExploreModelMatrixYou should mainly refer to this excellent reference: http://docs.rstudio.com/shiny-server/, the Administrator’s Guide beautifully written and maintained by the RStudio team.
In the case of the instance linked above (http://shiny.imbei.uni-mainz.de:3838/ExploreModelMatrix), the deployment is on a Ubuntu-based server. If this is your case too, please go to https://docs.rstudio.com/shiny-server/#ubuntu-14.04
If you are already familiar with Shiny Server, you can consider going directly here: http://docs.rstudio.com/shiny-server/#quick-start
Follow the indications in the main reference guide to see whether you have all packages installed, and visit the address which will refer to the address of your server (http://your.server.address:3838/sample-apps/hello/).
ExploreModelMatrixYou need to:
ExploreModelMatrixExploreModelMatrix on the serverExploreModelMatrixYou need first to install Bioconductor
sudo su - -c "R -e \"install.packages('BiocManager')\""Once that is done, you can install ExploreModelMatrix with
sudo su - -c "R -e \"BiocManager::install('ExploreModelMatrix')\""You can also install the development version of ExploreModelMatrix from GitHub with
# install remotes first
sudo su - -c "R -e \"BiocManager::install('remotes')\""
# and then ExploreModelMatrix
sudo su - -c "R -e \"BiocManager::install('csoneson/ExploreModelMatrix')\""Keep in mind that if you are running the server as root, you could simply open R in the terminal and install the required packages with
ExploreModelMatrix on the serverYou essentially need to do two things:
/srv/shiny-server, create a folder (e.g. via mkdir) named ExploreModelMatrix, and create a file in there called app.R. Edit its content (e.g. with vi, nano, or any other editor), copy-pasting the following lines:library("ExploreModelMatrix")
ExploreModelMatrix()/etc/shiny-server/shiny-server.conf. To do this, again use any text editor (e.g. vi), and add the following linesserver {
  listen 3838;
  #...
  ### FROM HERE
  location /ExploreModelMatrix {
    # Run this location in 'app_dir' mode, which will host a single Shiny
    # Application available at '/srv/shiny-server/myApp'
    app_dir /srv/shiny-server/ExploreModelMatrix;
    # Log all Shiny output to files in this directory
    log_dir /var/log/shiny-server/ExploreModelMatrix;
    # 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 off;
    # recommended, to wait for the application to start
    app_init_timeout 250;
  }
  ### TO HERE
  # ...
}You might need to restart the Shiny Server (systemctl restart shiny-server on Ubuntu). Then you should be good to go!
Visit http://your.server.address:3838/ExploreModelMatrix for your personal running instance.
ExploreModelMatrix at the IMBEIhttp://shiny.imbei.uni-mainz.de:3838/ExploreModelMatrix is the address for the public instance of ExploreModelMatrix on the Shiny Server I manage at the Institute of Medical Biostatistics, Epidemiology and Informatics.
The relevant setup of that machine is the following (in case you are asking what specs you need):
lsb_release -a
  No LSB modules are available.
  Distributor ID: Ubuntu
  Description: Ubuntu 16.04.2 LTS
  Release: 16.04
  Codename: xenialsessionInfo()
#> R version 4.4.0 beta (2024-04-15 r86425)
#> Platform: x86_64-pc-linux-gnu
#> Running under: Ubuntu 22.04.4 LTS
#> 
#> Matrix products: default
#> BLAS:   /home/biocbuild/bbs-3.19-bioc/R/lib/libRblas.so 
#> LAPACK: /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3.10.0
#> 
#> locale:
#>  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
#>  [3] LC_TIME=en_US.UTF-8        LC_COLLATE=en_US.UTF-8    
#>  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
#>  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
#>  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
#> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
#> 
#> time zone: America/New_York
#> tzcode source: system (glibc)
#> 
#> attached base packages:
#> [1] stats     graphics  grDevices utils     datasets  methods   base     
#> 
#> other attached packages:
#> [1] ExploreModelMatrix_1.16.0
#> 
#> loaded via a namespace (and not attached):
#>  [1] tidyr_1.3.1          sass_0.4.9           utf8_1.2.4          
#>  [4] generics_0.1.3       digest_0.6.35        magrittr_2.0.3      
#>  [7] evaluate_0.23        grid_4.4.0           fastmap_1.1.1       
#> [10] jsonlite_1.8.8       limma_3.60.0         promises_1.3.0      
#> [13] purrr_1.0.2          fansi_1.0.6          scales_1.3.0        
#> [16] jquerylib_0.1.4      shinydashboard_0.7.2 cli_3.6.2           
#> [19] shiny_1.8.1.1        rlang_1.1.3          cowplot_1.1.3       
#> [22] munsell_0.5.1        cachem_1.0.8         yaml_2.3.8          
#> [25] tools_4.4.0          rintrojs_0.3.4       dplyr_1.1.4         
#> [28] colorspace_2.1-0     ggplot2_3.5.1        httpuv_1.6.15       
#> [31] DT_0.33              BiocGenerics_0.50.0  vctrs_0.6.5         
#> [34] R6_2.5.1             mime_0.12            stats4_4.4.0        
#> [37] lifecycle_1.0.4      S4Vectors_0.42.0     htmlwidgets_1.6.4   
#> [40] MASS_7.3-60.2        shinyjs_2.1.0        pkgconfig_2.0.3     
#> [43] pillar_1.9.0         bslib_0.7.0          later_1.3.2         
#> [46] gtable_0.3.5         glue_1.7.0           Rcpp_1.0.12         
#> [49] statmod_1.5.0        xfun_0.43            tibble_3.2.1        
#> [52] tidyselect_1.2.1     knitr_1.46           xtable_1.8-4        
#> [55] htmltools_0.5.8.1    rmarkdown_2.26       compiler_4.4.0