容器里采纳

by admin on 2019年11月12日

图片 1

Docker 简介

Docker是四个盛开源代码软件项目,让应用程序布置在软件容器下的办事得以自动化进行,借此在Linux操作系统上,提供三个外加的软件抽象层,以至操作系统层设想化的自发性管理机制。Docker利用Linux大旨中的财富分脱机制,比方cgroups,甚至Linux主题名字空间(name
space卡塔尔国,来创建独立的软件容器(containers卡塔 尔(阿拉伯语:قطر‎。那能够在单豆蔻梢头Linux实体下运行,幸免引导一个设想机产生的额外负责.

docker

docker 安装

正文的陈设境遇是Ubuntu 14.04

Windows

Docker Windows 客商端须求开启 Hyper-V,安装进程会自行提示打开与否。

  • 从官方网站下载安装包双击安装。Docker for Windows
    Installer.exe

  • 双击Logo运维docker,初次展开恐怕要求几分钟时间。当右下角出现 docker
    标识认证已经开端运营了!

![](https://upload-images.jianshu.io/upload_images/5238649-2afbcfbef8d38c71.png)

whale-taskbar-circle.png
  • 开采终端发轫 docker 之旅

Windows 下推荐应用 Docker for Windows 顾客端,不要接收 docker
toolbox。当从官方酒店拖取镜像时进程比较感人,建议选用国内镜像加快。

  • Docker

CentOS

  1. 安装正视包

sudo yum install -y yum-utils \
  device-mapper-persistent-data \
  lvm2
  1. 用上边的下令设置 牢固版的 源地址

sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo
  1. 安装 docker-ce

sudo yum install docker-ce
  1. 发端接受

sudo systemctl start docker

sudo docker run hello-world

Docker
详细概念能够去search,轻易的话正是把利用打包到七个容器里的轻量级系统设想化服务

Debian

系统必要:

  • 64 bit
  • Stretch (稳定版)
  • Jessie 8.0 (LTS)
  • Wheezy 7.7 (LTS)
  • Linux 内核大于 3.10
  1. 若安装有旧版本则先卸载

sudo apt-get remove docker docker-engine docker.io
  1. 安装信赖

sudo apt-get update
  • Jessie 或 Stretch 版:

sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    gnupg2 \
    software-properties-common
  • Wheezy 版:

sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    python-software-properties
  1. 添加 Docker 官方 GPG key
    curl -fsSL https://download.docker.com/linux/$(. /etc/os-release; echo "$ID")/gpg | sudo apt-key add -
    4.设置 源地址

sudo add-apt-repository \
   "deb [arch=amd64] https://download.docker.com/linux/$(. /etc/os-release; echo "$ID") \
   $(lsb_release -cs) \
   stable"
  1. 安装 Docker-ce

sudo apt-get update
sudo apt-get install docker-ce

enjoy it:
sudo docker run hello-world

Debian 系统利用 apt-get 默许安装版本相比旧,使用 docker-compose 管理Docker容器时会报错客户端和服务器版本不一致。建议按以上官方安装表明安装新版
Docker。

  • IPython Notebook

Nginx 介绍

Nginx 是三个 web
服务器。它好像于 Lighttpd,作为轻量级的 web server,能够替代重量级的
Apache/IIS。Nginx 专为品质优化而支出,是七个连忙且能经得住高负载核算的 web
server。详细情形见 wiki
页面

IPython Notebook
既是三个互相计算平台,又是叁个记下总结进度的「笔记本」。它由服务端和顾客端两局地构成,当中服务端担负代码的讲授与计量,而客商端担任与客商举办相互影响。
服务端能够运作在本机也能够运作在长途服务器,包括担负运算的 IPython
kernel (与 QT Console 的 kernel 相仿) 以致三个 HTTP/S 服务器
(Tornado)。
而客商端则是二个针对服务端地址的浏览器页面,担任接收客户的输入并担当渲染输出。

下载 Nginx 官方镜像

docker pull nginx

默许标签为新型版,若要求任何版本钦点标签就可以 请从docker
hub
收获帮忙

正文主要记录使用Docker 在服务器布署IPython Note
应用的长河。比守旧的配置方案果然不难轻巧不菲。

nginx-proxy 介绍

nginx-proxy
运转二个容器来运转 nginx 和
docker-gen
在主机上的器皿运行和暂息时 docker-gen 会生成 nginx
反向代理配置並且重新加载 nginx。

| Automated Nginx reverse proxy for docker containers

知识点

  1. Docker 的基本概念
  2. 部署IPython 容器
  3. 利用Nginx 容器反向代理IPython

下载 镜像

docker pull jwilder/nginx-proxy

Docker 的基本概念

下文的操作重要涉及Docker的登时多少个知识点:

  • Docker 的镜像(image)、容器(container)、仓库(registerie)
  • Docker 的安装
  • Docker 的底蕴用法
  • Docker的端口映射
  • Docker 数据卷
  • 链接容器

详尽的音讯能够活动物检疫索

如何利用

  1. 启动 nginx-proxy 容器:

docker run -d -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro jwilder/nginx-proxy
  1. 再开发银行一个亟需被代理的容器,使用条件变量 VIRTUAL_HOST=domain.com

docker run -e VIRTUAL_HOST=domain.com nginx

被代理的器皿必须 expose 被代理的端口,能够因此在 Dockerfile 里面使用
EXPOSE 指令可能在 docker run 时采纳 –expose 参数。

在 DNS 上安装转载 foo.bar.com 到 nginx-proxy
的主机上,之后乞求就能被电动路由到安装了相像 VIRTUAL_HOST
景况变量的容器上。

部署IPython

利用 Letsencrypt 证书加密

letsencrypt-nginx-proxy-companion
是三个轻量级的代理容器,协作
nginx-proxy福如东海全自动创设和自动更新
Let’s Encrypt 证书。

下载IPython 的镜像

官方Docker镜像地址,里面包含5个镜像:

  • notebook
  • ipython
  • scipyserver
  • scipystack
  • nbvierer

总结说一下那多少个镜像的差距 ipython
是以上多少个镜像的同步的根镜像。notebook
提供了八个web的前端。scipystackipython的底子上设置了多数科学总括的包(cython,h5py,matplotlib,numpy,pandas,patsy,scikit-learn,scipy,seaborn,sympy,yt),而scipyserver则在scipystack的底工上提供了web的前端。nbviewer则是nbviewer.ipython.org的实现
越来越多详细音信请到GitHub上的docker-notebook
查看
选择scipystack镜像最简便易行,不过急需下载的东西也越来越多。下文选拔的也是scipystack

$ sudo docker pull ipython/scipyserver

下载 镜像

docker pull jrcs/letsencrypt-nginx-proxy-companion

运行IPython 容器

sudo docker run -d --name IPythonApp -p 8888:8888 -e "PASSWORD=your password" -e "USE_HTTP=1" -v /home/zhiyue/repos/ipython-notebook:/notebooks ipython/scipyserver

浅析一下参数-d 是今后台的点子运维,--name 是容器的别称,-p
是端口映射,-e
是安装情况变量,这里的意况变量PASSWORD设置成你和谐的密码就足以了,USE_HTTP=1
意思是运用http,-v
是设置数据卷,把宿主机的目录挂载到容器里,固然容器被删去,数据也得以保留下来

用法

要将其与原始 nginx 代理容器一同行使,您必得从 nginx-proxy
容器申明3个可写卷:

  • /etc/nginx/certs 创制和立异 Let’s Encrypt 证书
  • /etc/nginx/vhost.d 改善虚构主机配置 (Let’s Encrypt)
  • /usr/share/nginx/html 写入验证文件 (Let’s Encrypt)
  1. 启动 nginx-proxy

docker run -d -p 80:80 -p 443:443 \
  --name nginx-proxy \
  -v /path/to/certs:/etc/nginx/certs:ro \
  -v /etc/nginx/vhost.d \
  -v /usr/share/nginx/html \
  -v /var/run/docker.sock:/tmp/docker.sock:ro \
  --label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
  jwilder/nginx-proxy

--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy
是必备的,不然 Let’s Encrypt 不明了使用哪个容器。

  1. 启动 LetsEncrypt

docker run -d \
  -v /path/to/certs:/etc/nginx/certs:rw \
  -v /var/run/docker.sock:/var/run/docker.sock:ro \
  --volumes-from nginx-proxy \
  jrcs/letsencrypt-nginx-proxy-companion

再开发银行要求被代理和加密的容器,加上环境变量 VIRTUAL_HOST=domain.com

docker run -e "VIRTUAL_HOST=foo.bar.com" ...
要使其能活动创造和改善证书需安装条件变量 LETSENCRYPT_HOST
LETSENCRYPT_EMAIL 即可。

Nginx 反向代理 IPython

有三种方法,生机勃勃种是利用官方的Nginx,另意气风发种是采纳jwilder /
nginx-proxy
,后生龙活虎种方式尤其简明和福利

Docker-compose

Compose
是概念和运行多容器Docker应用程序的工具。
使用Compose,您能够利用YAML文件来配置应用程序的服务。
然后,使用单个命令创造并运转配置中的全体服务。
要详细询问Compose的保有机能,请参阅效果与利益列表

方式1:nginx

  • 应用Nginx的官方镜像nginx

  • Nginx 配置文件
    ipython-server.conf

 map $http_upgrade $connection_upgrade {
        default upgrade;
        ''      close;
 }
server{
        listen 80;
        server_name note.everforget.com;
        location / {
                proxy_pass http://ipython:8888;
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "upgrade";
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header Host $host;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
}

那在那之中要潜心一点是,ipython要选用websock因而要布署websocket,在此之前在此个主题材料查了长久。
proxy_pass http://ipython:8888; ipython和前边容器连接时的别称有关。

  • 运行Nginx容器

$ sudo docker run -d -p 80:80 --name nginx --link IPythonApp:ipython  -v `pwd`/config:/etc/nginx/conf.d  -v `pwd`/logs:/var/log/nginx nginx

Linux 安装

  1. 行使以下命令

sudo curl -L https://github.com/docker/compose/releases/download/1.17.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
  1. 赋可实行权限

sudo chmod +x /usr/local/bin/docker-compose

方式2:nginx-proxy

docker run -d -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro jwilder/nginx-proxy
  • 运行ipython 容器

sudo docker run -d -e "VIRTUAL_HOST=ipython.everforget.com" --name IPython -p 8888:8888 -e "PASSWORD=xxxxxx" -e "USE_HTTP=1" -v /home/zhiyue/repos/ipython-notebook:/notebooks ipython/scipyserver

末尾放一张图:

图片 2

那样就可以任何时候通过web来利用python了。

Windows 安装

以管理人身份运转 PowerShell

Invoke-WebRequest "https://github.com/docker/compose/releases/download/$dockerComposeVersion/docker-compose-Windows-x86_64.exe" -UseBasicParsing -OutFile $Env:ProgramFiles\docker\docker-compose.exe

参考


更新日志:

  • 二〇一四-6-8 增添配图
  • 二零一四-6-6 第三回创作

使用 Compose

率先 创造三个 docker-compose.yml 的文书,在当前目录运转
docker-compose up .

完整 docker-compose 文件

version: '3'
services:
  nginx-proxy:
    image: jwilder/nginx-proxy
    container_name: nginx-proxy
    labels: 
        com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy: "true"
    ports: 
      - 80:80
      - 443:443
    volumes:
      - /docker/nginx/certs:/etc/nginx/certs:ro
      - /docker/nginx/conf.d:/etc/nginx/conf.d
      - /docker/nginx/vhost.d:/etc/nginx/vhost.d
      - /docker/nginx/html/:/usr/share/nginx/html
      - /var/run/docker.sock:/tmp/docker.sock:ro
  letsencrypt:
    image: jrcs/letsencrypt-nginx-proxy-companion
    container_name: letsencrypt
    volumes:
      - /docker/nginx/conf.d:/etc/nginx/conf.d
      - /docker/nginx/vhost.d:/etc/nginx/vhost.d
      - /docker/nginx/html/:/usr/share/nginx/html
      - /docker/nginx/certs:/etc/nginx/certs:rw
      - /var/run/docker.sock:/var/run/docker.sock:ro

  someweb:  
    image: nginx
    container_name: someweb
    environment:
      - VIRTUAL_HOST=somedomain.com
      - LETSENCRYPT_HOST=somedomain.com
      - LETSENCRYPT_EMAIL=example@domain.com
networks:
  default:
    external:
      name: web-proxy

Good Luck!

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图