mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-03-12 01:40:10 +08:00
20171019-7 选题
This commit is contained in:
parent
69325f932b
commit
f042efd655
@ -0,0 +1,142 @@
|
||||
Why Use Docker with R? A DevOps Perspective
|
||||
============================================================
|
||||
|
||||
[][11]
|
||||
|
||||
There have been several blog posts going around about why one would use Docker with R.
|
||||
In this post I’ll try to add a DevOps point of view and explain how containerizing
|
||||
R is used in the context of the OpenCPU system for building and deploying R servers.
|
||||
|
||||
> Has anyone in the [#rstats][2] world written really well about the *why* of their use of Docker, as opposed to the the *how*?
|
||||
>
|
||||
> — Jenny Bryan (@JennyBryan) [September 29, 2017][3]
|
||||
|
||||
### 1: Easy Development
|
||||
|
||||
The flagship of the OpenCPU system is the [OpenCPU server][12]:
|
||||
a mature and powerful Linux stack for embedding R in systems and applications.
|
||||
Because OpenCPU is completely open source we can build and ship on DockerHub. A ready-to-go linux server with both OpenCPU and RStudio
|
||||
can be started using the following (use port 8004 or 80):
|
||||
|
||||
```
|
||||
docker run -t -p 8004:8004 opencpu/rstudio
|
||||
|
||||
```
|
||||
|
||||
Now simply open [http://localhost:8004/ocpu/][13] and
|
||||
[http://localhost:8004/rstudio/][14] in your browser!
|
||||
Login via rstudio with user: `opencpu` (passwd: `opencpu`) to build or install apps.
|
||||
See the [readme][15] for more info.
|
||||
|
||||
Docker makes it easy to get started with OpenCPU. The container gives you the full
|
||||
flexibility of a Linux box, without the need to install anything on your system.
|
||||
You can install packages or apps via rstudio server, or use `docker exec` to a
|
||||
root shell on the running server:
|
||||
|
||||
```
|
||||
# Lookup the container ID
|
||||
docker ps
|
||||
|
||||
# Drop a shell
|
||||
docker exec -i -t eec1cdae3228 /bin/bash
|
||||
|
||||
```
|
||||
|
||||
From the shell you can install additional software in the server, customize the apache2 httpd
|
||||
config (auth, proxies, etc), tweak R options, optimize performance by preloading data or
|
||||
packages, etc.
|
||||
|
||||
### 2: Shipping and Deployment via DockerHub
|
||||
|
||||
The most powerful use if Docker is shipping and deploying applications via DockerHub. To create a fully standalone
|
||||
application container, simply use a standard [opencpu image][16]
|
||||
and add your app.
|
||||
|
||||
For the purpose of this blog post I have wrapped up some of the [example apps][17] as docker containers by adding a very simple `Dockerfile` to each repository. For example the [nabel][18] app has a [Dockerfile][19] that contains the following:
|
||||
|
||||
```
|
||||
FROM opencpu/base
|
||||
|
||||
RUN R -e 'devtools::install_github("rwebapps/nabel")'
|
||||
|
||||
```
|
||||
|
||||
It takes the standard [opencpu/base][20]
|
||||
image and then installs the nabel app from the Github [repository][21].
|
||||
The result is a completeley isolated, standalone application. The application can be
|
||||
started by anyone using e.g:
|
||||
|
||||
```
|
||||
docker run -d 8004:8004 rwebapps/nabel
|
||||
|
||||
```
|
||||
|
||||
The `-d` daemonizes on port 8004.
|
||||
Obviously you can tweak the `Dockerfile` to install whatever extra software or settings you need
|
||||
for your application.
|
||||
|
||||
Containerized deployment shows the true power of docker: it allows for shipping fully
|
||||
self contained appliations that work out of the box, without installing any software or
|
||||
relying on paid hosting services. If you do prefer professional hosting, there are
|
||||
many companies that will gladly host docker applications for you on scalable infrastructure.
|
||||
|
||||
### 3 Cross Platform Building
|
||||
|
||||
There is a third way Docker is used for OpenCPU. At each release we build
|
||||
the `opencpu-server` installation package for half a dozen operating systems, which
|
||||
get published on [https://archive.opencpu.org][22].
|
||||
This process has been fully automated using DockerHub. The following images automatically
|
||||
build the enitre stack from source:
|
||||
|
||||
* [opencpu/ubuntu-16.04][4]
|
||||
|
||||
* [opencpu/debian-9][5]
|
||||
|
||||
* [opencpu/fedora-25][6]
|
||||
|
||||
* [opencpu/fedora-26][7]
|
||||
|
||||
* [opencpu/centos-6][8]
|
||||
|
||||
* [opencpu/centos-7][9]
|
||||
|
||||
DockerHub automatically rebuilds this images when a new release is published on Github.
|
||||
All that is left to do is run a [script][23]
|
||||
which pull down the images and copies the `opencpu-server`binaries to the [archive server][24].
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
|
||||
via: https://www.r-bloggers.com/why-use-docker-with-r-a-devops-perspective/
|
||||
|
||||
作者:[Jeroen Ooms][a]
|
||||
译者:[译者ID](https://github.com/译者ID)
|
||||
校对:[校对者ID](https://github.com/校对者ID)
|
||||
|
||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||
|
||||
[a]:https://www.r-bloggers.com/author/jeroen-ooms/
|
||||
[1]:https://www.opencpu.org/posts/opencpu-with-docker/
|
||||
[2]:https://twitter.com/hashtag/rstats?src=hash&ref_src=twsrc%5Etfw
|
||||
[3]:https://twitter.com/JennyBryan/status/913785731998289920?ref_src=twsrc%5Etfw
|
||||
[4]:https://hub.docker.com/r/opencpu/ubuntu-16.04/
|
||||
[5]:https://hub.docker.com/r/opencpu/debian-9/
|
||||
[6]:https://hub.docker.com/r/opencpu/fedora-25/
|
||||
[7]:https://hub.docker.com/r/opencpu/fedora-26/
|
||||
[8]:https://hub.docker.com/r/opencpu/centos-6/
|
||||
[9]:https://hub.docker.com/r/opencpu/centos-7/
|
||||
[10]:https://www.r-bloggers.com/
|
||||
[11]:https://www.opencpu.org/posts/opencpu-with-docker
|
||||
[12]:https://www.opencpu.org/download.html
|
||||
[13]:http://localhost:8004/ocpu/
|
||||
[14]:http://localhost:8004/rstudio/
|
||||
[15]:https://hub.docker.com/r/opencpu/rstudio/
|
||||
[16]:https://hub.docker.com/u/opencpu/
|
||||
[17]:https://www.opencpu.org/apps.html
|
||||
[18]:https://rwebapps.ocpu.io/nabel/www/
|
||||
[19]:https://github.com/rwebapps/nabel/blob/master/Dockerfile
|
||||
[20]:https://hub.docker.com/r/opencpu/base/
|
||||
[21]:https://github.com/rwebapps
|
||||
[22]:https://archive.opencpu.org/
|
||||
[23]:https://github.com/opencpu/archive/blob/gh-pages/update.sh
|
||||
[24]:https://archive.opencpu.org/
|
||||
[25]:https://www.r-bloggers.com/author/jeroen-ooms/
|
Loading…
Reference in New Issue
Block a user