Navigating EC2 with the Command Line
18 Jul 2016Understanding the directory structure of an AWS EC2 instance is extremely helpful in order to get your apps running. My last post explained how to get an AWS EC2 instance up and running with Shiny Server, this post will layout the directory structure and navigating to important files.
Note: I’m using an Ubuntu 14.04 Amazon Machine Image. The default user is ubuntu. I’ll use 11.22.33.44 as an example IP address. Be sure to replace this with your IP address when you see it. The public DNS will use the same convention, however the .
s will be replaced with -
.
Loggin In
Log into an EC2 instance using the secure key, public DNS and ssh
. When launching an EC2 instance you’ll download an secure key pair and the public DNS is available on the EC2 dashboard. Replace everything after ubuntu@ with your public DNS.
If you’re logged in you should see some info about your instance and the text before the $
should say ubuntu@ip-11-22-33-44
.
Directory Structure and Navigation
The starting directory is the /home/ubuntu
or ~
. This is the user directory. Each user on your system has a directory under /home
. This is very similar to any other operating system. Here is the general layout for an EC2 instance.
These are the folders that are most important for running a shiny server. /srv/shiny-server
includes all is where all shiny app related things should go. /var/log/
is the location for system and server logs. Any errors that occure because of the server or non-zero exit status for R will be located here. /etc/nginx
and /etc/nginx/shiny-server
are the location of server configuration files that may need to be changed to set up or change server behavior.
Navigation
Navigating the server is very similar to navigating with terminal. Some of these commands may require sudo
.
So, to change the directory to root use cd /
, to go back to the user directory, cd ~
. To edit the shiny server config sudo nano /etc/shiny-server/shiny-server.conf
. To move files from the user directory to shiny server, sudo mv ~/*.csv /srv/shiny-server/apps/
.
Moving Data into EC2
There are a few different methods for moving data into an EC2 instance. You could use and ftp client, git clone, or use scp
(secure copy). I always use secure copy. I find it just as easy as setting up an ftp client, and git is only good if your files are small. The following command will copy all the files in the documents folder to /home/ubuntu/
scp
can only copy files into a directory that the current user has write permissions to. User ubuntu has permission to write to /home/ubuntu/
but not /srv/shiny-server/apps/data/
the location I store any data for an app. Once the data is on EC2 I move it to the appropriate folder. Then delete the data from the home folder, if it is still there.
Thats about it for navigating an EC2 instance. I’ll add to this post as I use more command line tools with EC2.