国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務(wù)器 > Web服務(wù)器 > 正文

Docker快速入門以及環(huán)境配置詳解

2024-09-01 13:48:17
字體:
供稿:網(wǎng)友

前言

數(shù)據(jù)科學(xué)開發(fā)環(huán)境配置起來讓人頭疼,會(huì)碰到包版本不一致、錯(cuò)誤信息不熟悉和編譯時(shí)間漫長等問題。這很容易讓人垂頭喪氣,也使得邁入數(shù)據(jù)科學(xué)的這第一步十分艱難。而且這也是一個(gè)完全不常見的準(zhǔn)入門檻。

還好,過去幾年中出現(xiàn)了能夠通過搭建孤立的環(huán)境來解決這個(gè)問題的技術(shù)。本文中我們就要介紹的這種技術(shù)名叫Docker。Docker能讓開發(fā)者簡單、快速地搭建數(shù)據(jù)科學(xué)開發(fā)環(huán)境,并支持使用例如Jupyter notebooks等工具進(jìn)行數(shù)據(jù)探索。

簡介

Docker 最初 dotCloud 公司內(nèi)部的一個(gè)業(yè)余項(xiàng)目

Docker 基于 Go 語言

Docker 項(xiàng)目的目標(biāo)是實(shí)現(xiàn)輕量級的操作系統(tǒng)虛擬化解決方案

Docker 的基礎(chǔ)是 Linux 容器(LXC)等技術(shù)

Docker 容器的啟動(dòng)可以在秒級實(shí)現(xiàn),這相比傳統(tǒng)的虛擬機(jī)方式要快得多

Docker 對系統(tǒng)資源的利用率很高,一臺(tái)主機(jī)上可以同時(shí)運(yùn)行數(shù)千個(gè) Docker 容器

下面的圖片比較了 Docker 和傳統(tǒng)虛擬化方式的不同之處,可見容器是在操作系統(tǒng)層面上實(shí)現(xiàn)虛擬化,直接復(fù)用本地主機(jī)的操作系統(tǒng),而傳統(tǒng)方式則是在硬件層面實(shí)現(xiàn)。

 docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

 docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

容器除了運(yùn)行其中應(yīng)用外,基本不消耗額外的系統(tǒng)資源,使得應(yīng)用的性能很高,同時(shí)系統(tǒng)的開銷盡量小。傳統(tǒng)虛擬機(jī)方式運(yùn)行 10 個(gè)不同的應(yīng)用就要起 10 個(gè)虛擬機(jī),而Docker 只需要啟動(dòng) 10 個(gè)隔離的應(yīng)用即可。

主要優(yōu)勢為:

     更快速的交付和部署 - 容器成為了最小單位

     更高效的虛擬化 - 內(nèi)核級虛擬化

     更輕松的遷移和拓展

     更簡單的管理

基本概念

主要是三個(gè):

鏡像(Image)

     一個(gè)只讀的模板,鏡像可以用來創(chuàng)建 Docker 容器

    可以簡單創(chuàng)建或更新現(xiàn)有鏡像,或者直接下載使用其他人的

容器(Container)

    容器是從鏡像創(chuàng)建的運(yùn)行實(shí)例,在啟動(dòng)的時(shí)候創(chuàng)建一層可寫層作為最上層(因?yàn)殓R像是只讀的)

    可以被啟動(dòng)、開始、停止、刪除。每個(gè)容器都是相互隔離的、保證安全的平臺(tái)

    可以把容器看做是一個(gè)簡易版的 Linux 環(huán)境(包括root用戶權(quán)限、進(jìn)程空間、用戶空間和網(wǎng)絡(luò)空間等)和運(yùn)行在其中的應(yīng)用程序

倉庫(Repository)

    集中存放鏡像文件的場所

    最大的公開倉庫是 Docker Hub

    國內(nèi)的公開倉庫包括 Docker Pool 等

    當(dāng)用戶創(chuàng)建了自己的鏡像之后就可以使用 push 命令將它上傳到公有或者私有倉庫,這樣下次在另外一臺(tái)機(jī)器上使用這個(gè)鏡像時(shí)候,只需要從倉庫上 pull 下來就可以了

    Docker 倉庫的概念跟 Git 類似,注冊服務(wù)器可以理解為 GitHub 這樣的托管服務(wù)

安裝

官方網(wǎng)站提供了 Mac, Linux 和 Windows 版本的安裝教程。因?yàn)槲掖蛩闶褂锰摂M機(jī)進(jìn)行安裝測試,所以這里主要走 Linux 的安裝教程,不過其他的應(yīng)該大同小異。我的 ubuntu 版本是 14.04 LTS, trusty

Docker 目前只能安裝在 64 位平臺(tái)上,并且要求內(nèi)核版本不低于 3.10,實(shí)際上內(nèi)核越新越好,過低的內(nèi)核版本容易造成功能的不穩(wěn)定??梢酝ㄟ^下面的命令來檢查內(nèi)核版本(兩個(gè)方式,都可以):

parallels@ubuntu:~$ uname -aLinux ubuntu 3.13.0-83-generic #127-Ubuntu SMP Fri Mar 11 00:25:37 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux
parallels@ubuntu:~$ cat /proc/versionLinux version 3.13.0-83-generic (buildd@lgw01-55) (gcc version 4.8.2 (Ubuntu 4.8.2-19ubuntu1) ) #127-Ubuntu SMP Fri Mar 11 00:25:37 UTC 2016

這里我們按照官網(wǎng)的教程,不使用 apt-get 而是使用 curl 來進(jìn)行安裝。

     1、如果沒有安裝 curl,使用 sudo apt-get update; sudo apt-get install curl 來進(jìn)行安裝

      2、下載最新的 Docker 包 curl -fsSL https://get.docker.com/ | sh

      如果想要以 non-root 用戶的角色來使用,請使用 sudo usermod -aG docker parallels(這里 parallels 是用戶名),注意需要注銷并重新登錄以應(yīng)用改動(dòng)

     3、驗(yàn)證安裝

           需要先啟用 docker sudo service docker start

           然后可以用 docker version 來查看版本

          最后使用 docker run hello-world 來測試

版本信息

parallels@ubuntu:~$ docker versionClient: Version:  1.10.3 API version: 1.22 Go version: go1.5.3 Git commit: 20f81dd Built:  Thu Mar 10 15:54:52 2016 OS/Arch:  linux/amd64Server: Version:  1.10.3 API version: 1.22 Go version: go1.5.3 Git commit: 20f81dd Built:  Thu Mar 10 15:54:52 2016 OS/Arch:  linux/amd64

成功運(yùn)行 hello world 的結(jié)果

parallels@ubuntu:~$ docker run hello-worldHello from Docker.This message shows that your installation appears to be working correctly.To generate this message, Docker took the following steps: 1. The Docker client contacted the Docker daemon. 2. The Docker daemon pulled the "hello-world" image from the Docker Hub. 3. The Docker daemon created a new container from that image which runs the executable that produces the output you are currently reading. 4. The Docker daemon streamed that output to the Docker client, which sent it to your terminal.To try something more ambitious, you can run an Ubuntu container with: $ docker run -it ubuntu bashShare images, automate workflows, and more with a free Docker Hub account: https://hub.docker.comFor more examples and ideas, visit: https://docs.docker.com/userguide/

這之后的部分是課程需求。

我們需要安裝 docker machine virtual box,具體步驟為:

# 獲取權(quán)限$ sudo su# 下載 Docker Machine 的二進(jìn)制文件 $ curl -L https://github.com/docker/machine/releases/download/v0.6.0/docker-machine-`uname -s`-`uname -m` > /usr/local/bin/docker-machine && chmod +x /usr/local/bin/docker-machine# 驗(yàn)證安裝$ docker-machine versiondocker-machine version 0.6.0, build e27fb87

添加源

把這行添加到 /etc/apt/sources.list 文件中 deb http://download.virtualbox.org/virtualbox/debian trusty contrib

       wget -q https://www.virtualbox.org/download/oracle_vbox.asc -O- | sudo apt-key add -

更新并安裝 sudo apt-get update; sudo apt-get install virtualbox-5.0

配置

然后是一些配置,先重設(shè)默認(rèn)的虛擬機(jī)

      刪除原來的默認(rèn)(如果有的話)docker-machine rm default

      創(chuàng)建新的默認(rèn)虛擬機(jī) docker-machine create --driver virtualbox default(這一步可能需要等一下,我用的是 Parallel Desktop 11,還需要在虛擬機(jī)設(shè)置中開啟 CPU 虛擬化,主要是支持 vt-x)

然后如果直接在菜單中選擇 Virtual Box 的話,就會(huì)發(fā)現(xiàn)什么都沒有,技巧是要在剛才的命令行中輸入 virtualbox,然后就可以看到下面的界面:

docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

在 Settings - Network 中選擇 Port Forwarding,然后按照如圖所示添加記錄

 docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

這里的 Host Port: 9234 記為 A,Guest Port: 9001 記為 B。然后就可以啟動(dòng) docker 中老師提供的鏡像了:

命令為 docker run -it -p 9001:9000 cmusvsc/apachecmda:1.1(需要下載一段時(shí)間,然后再解壓一段時(shí)間),這里 9001 記為 C,9000 記為 D。

接著就會(huì)直接連接到 docker 中的虛擬機(jī),從之后的圖中可以看到命令行前面的內(nèi)容也變化了。然后我們輸入命令開啟前端

cd /home/Spring2016/ApacheCMDA-Frontend./activator run # 相當(dāng)于在 9000 端口開啟

docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

不要關(guān)現(xiàn)在的終端,開啟一個(gè)新的終端。用

docker exec -it `docker ps -q` /bin/bash

進(jìn)入正在執(zhí)行的 docker

等待一段時(shí)間后,繼續(xù)走以下命令

# 開啟 MySQL 服務(wù)器service mysql startcd /home/Spring2016/ApacheCMDA-Backend./activator "run 9034"

然后可以見到

docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

然后等待一段時(shí)間(第一運(yùn)行需要編譯),就可以見到主頁面了:

也可以嘗試直接 localhost:9001

docker快速入門,docker,配置開發(fā)環(huán)境,docker入門實(shí)戰(zhàn)

還記得前面的端口轉(zhuǎn)發(fā)嗎?這里解釋一下:

     A,也就是 9234,是用戶訪問的端口號

     B,也就是 9001,我們通過虛擬機(jī)的端口轉(zhuǎn)發(fā)從 9234 轉(zhuǎn)到了 9001

     C,也就是 9001(這個(gè)命令中的 docker run -it -p 9001:9000 cmusvsc/apachecmda:1.1),是虛擬機(jī)繼續(xù)轉(zhuǎn)發(fā)的端口

     D,也就是 9000(這個(gè)命令中的 docker run -it -p 9001:9000 cmusvsc/apachecmda:1.1),是 Docker 容器中接收請求的端口。

也就是說,B 和 C 一定要一樣,A 和 D 可以在命令中設(shè)置。至于為什么后端需要運(yùn)行在 9034 端口,是因?yàn)榍岸撕秃蠖送ㄟ^這個(gè)端口通訊(應(yīng)該是寫死在代碼里的)

掛載主機(jī)數(shù)據(jù)卷到容器內(nèi),可以通過如下命令進(jìn)行文件夾映射

docker run -it -p 9999:9999 -p 9001:9000 -v ~/localFolder:/sharedFolder cmusvsc/apachecmda:1.1

從容器內(nèi)拷貝文件到主機(jī)上

# 列出 containerdocker ps# 復(fù)制 這個(gè)不知道為啥不行docker cp <containerId>:/file/path/within/container /host/path/target# 掛載映射docker run -it -v /home/parallels/Documents/code:/home/code cmusvsc/apachecmda:1.1# 復(fù)制cp -r Spring2016/* ./code/

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家能有所幫助,如果有疑問大家可以留言交流。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 石狮市| 当雄县| 江门市| 上饶市| 鸡东县| 英德市| 临颍县| 杂多县| 吉安县| 遵义市| 乌苏市| 铁岭市| 铜梁县| 鸡东县| 漾濞| 乳源| 韶关市| 临泉县| 河曲县| 东台市| 德惠市| 汕尾市| 西乡县| 融水| 逊克县| 徐闻县| 台中县| 延津县| 迭部县| 武山县| 镇远县| 洪雅县| 嵊泗县| 利辛县| 西贡区| 凤山县| 会理县| 石泉县| 昂仁县| 宁强县| 茶陵县|