• Home
  • Archive
  • Tools
  • Contact Us

The Customize Windows

Technology Journal

  • Cloud Computing
  • Computer
  • Digital Photography
  • Windows 7
  • Archive
  • Cloud Computing
  • Virtualization
  • Computer and Internet
  • Digital Photography
  • Android
  • Sysadmin
  • Electronics
  • Big Data
  • Virtualization
  • Downloads
  • Web Development
  • Apple
  • Android
Advertisement
You are here:Home » Create Data Science Environment on Cloud Server With Docker

By Abhishek Ghosh September 6, 2017 5:45 am Updated on September 6, 2017

Create Data Science Environment on Cloud Server With Docker

Advertisement

This guide is not directly related to typical Big Data tools like Hadoop. In this guide we will configuring Docker and Jupyter on a cloud server. Here are the steps, commands to create data science environment on cloud server with Docker for data analysis starting with a blank server with SSH. The users following this guide must have adequate knowledge so that they do not need to read guides like our basic server setup. This kind of environment is great for testing and development and avoids the clutter out of installing many packages on localhost. For our works, we need a cloud server instance least 2GB of RAM. Xen, KVM virtualisation should be enough. VPSDime has cheap OpenVZ servers but you should send email to their support for Docker. Their dirt cheap package does not support Docker. Next option is Linode for 2 GB. Next option is OVH. Next option is Digital Ocean (which is most costly among all the names of web hosts).

 

Create Data Science Environment on Cloud Server With Docker For Data Analysis

 

For this example, we are using Ubuntu 16.04 LTS as server OS, however any server OS like REHL, CentOS would work fine. We have previously published series of articles on using Docker. On that series we also had guide on Docker web management UI. Follow both guides to create a new user other than root with full sudo access, another with full sudo access and SSH access. Disable root to SSH. Install Docker. YOUR-USERNAME in our guide is an example of user other than root with full sudo access.

Create Data Science Environment on Cloud Server With Docker

We are installing Docker Community Edition (Docker CE). Running these few commands will do the job :

Advertisement

---

Vim
1
2
3
4
5
6
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
apt update
apt upgrade
apt-cache policy docker-ce
apt install -y docker-ce

Check the status :

Vim
1
sudo systemctl status docker

Make sure to run :

Vim
1
sudo usermod -aG docker YOUR-USERNAME

…after installing Docker, then exit the ssh session, ssh back again, become YOUR-USERNAME and run :

Vim
1
2
mkdir -p /home/YOUR-USERNAME/notebooks
ls -al /home/YOUR-USERNAME/

We need some Docker image to download with some data science stuffs with python 3 like jupyter notebook, and data science libraries like numpy, pandas, scipy, scikit-learn, nltk etc. Like this image has lot of stuffs even for visualisation, machine learning :

Vim
1
https://hub.docker.com/r/alessandroadamo/ubuntu-ds-python3/

One the image is downloaded, you can start ocker container with :

Vim
1
2
3
4
5
6
docker run -d -p 8888:8888 -v /home/ds/notebooks:/home/ds/notebooks alessandroadamo/ubuntu-ds-python3
 
 
Replace `alessandroadamo/ubuntu-ds-python3/` with the name of the image you'll actually download to use. Next step is using a web server with reverse proxy like Nginx. In that way the server can take requests from the public internet and pass to our Jupyter server above. You have to install nginx, use a practical domain/subdomain name and install CertBot/Let's encrypt.
 
There are zillion of guides on our website on installing configuring Nginx and CertBot/Let's Encrypt. Kindly perform a search if you need guides. For Ubuntu, we install `nginx-extras` :

Vim
1
apt install nginx-extras

List of free domain names and guide on CertBot/Let’s Encrypt for Nginx published before. Configuration for port 80 will be like this :

Vim
1
2
3
4
5
6
7
8
9
10
11
12
13
server {
       listen         80;
}
 
server {
 
    client_max_body_size 10M;
 
    location / {
        
        proxy_pass http://127.0.0.1:8888;
    }
}

If you need to password protect the frontend, you can install apache2-utils and generate password for YOUR-USERNAME :

Vim
1
2
apt install apache2-utils
sudo htpasswd -c /etc/nginx/.htpasswd YOUR-USERNAME

You need to change the Nginx config :

Vim
1
2
3
4
5
6
...
    location / {
...
        auth_basic "Restricted";
        auth_basic_user_file /etc/nginx/.htpasswd;
...

Check by running :

Vim
1
service nginx -t

and restart Nginx :

Vim
1
2
sudo systemctl restart nginx
# service nginx restart

Facebook Twitter Pinterest

Abhishek Ghosh

About Abhishek Ghosh

Abhishek Ghosh is a Businessman, Surgeon, Author and Blogger. You can keep touch with him on Twitter - @AbhishekCTRL.

Here’s what we’ve got for you which might like :

Articles Related to Create Data Science Environment on Cloud Server With Docker

  • Nginx WordPress Installation Guide (All Steps)

    This is a Full Nginx WordPress Installation Guide With All the Steps, Including Some Optimization and Setup Which is Compatible With WordPress DOT ORG Example Settings For Nginx.

  • How Setup Private Docker Registry on Ubuntu 16.04 LTS Cloud Server

    You Can Have Your Own Docker Registry on Own Cloud Server Instance. Here is How Setup Private Docker Registry on Ubuntu 16.04 LTS Cloud Server.

  • WordPress Multisite on Nginx on Ubuntu 14.04 on HP Cloud

    Here is a Step by Step Guide on Setting Up WordPress Multisite on Nginx on Ubuntu 14.04 on HP Cloud with All Commands and the Configuration.

  • Steps To Install Nginx Plus on Ubuntu Server (HP Cloud)

    Here Are the Steps To Install Nginx Plus on Ubuntu Server Running on HP Cloud. Nginx Plus is the Paid Version of Nginx with Extra Features.

performing a search on this website can help you. Also, we have YouTube Videos.

Take The Conversation Further ...

We'd love to know your thoughts on this article.
Meet the Author over on Twitter to join the conversation right now!

If you want to Advertise on our Article or want a Sponsored Article, you are invited to Contact us.

Contact Us

Subscribe To Our Free Newsletter

Get new posts by email:

Please Confirm the Subscription When Approval Email Will Arrive in Your Email Inbox as Second Step.

Search this website…

 

Popular Articles

Our Homepage is best place to find popular articles!

Here Are Some Good to Read Articles :

  • Cloud Computing Service Models
  • What is Cloud Computing?
  • Cloud Computing and Social Networks in Mobile Space
  • ARM Processor Architecture
  • What Camera Mode to Choose
  • Indispensable MySQL queries for custom fields in WordPress
  • Windows 7 Speech Recognition Scripting Related Tutorials

Social Networks

  • Pinterest (24.3K Followers)
  • Twitter (5.8k Followers)
  • Facebook (5.7k Followers)
  • LinkedIn (3.7k Followers)
  • YouTube (1.3k Followers)
  • GitHub (Repository)
  • GitHub (Gists)
Looking to publish sponsored article on our website?

Contact us

Recent Posts

  • Hybrid Multi-Cloud Environments Are Becoming UbiquitousJuly 12, 2023
  • Data Protection on the InternetJuly 12, 2023
  • Basics of BJT TransistorJuly 11, 2023
  • What is Confidential Computing?July 11, 2023
  • How a MOSFET WorksJuly 10, 2023
PC users can consult Corrine Chorney for Security.

Want to know more about us?

Read Notability and Mentions & Our Setup.

Copyright © 2023 - The Customize Windows | dESIGNed by The Customize Windows

Copyright  · Privacy Policy  · Advertising Policy  · Terms of Service  · Refund Policy