Docker的上手(Ubuntu140.4 Mate)
来源:互联网 发布:徐金华seo 编辑:程序博客网 时间:2024/06/05 12:00
首先按照官网运行https://docs.docker.com/engine/installation/linux/ubuntu/#prerequisites
然后不知道怎么用,然后需要
安装Docker-Compose(需要先安装docker)
1. Go to the Compose repository release page on GitHub.
2. Follow the instructions from the release page and run the curl command, which the release page specifies, in your terminal.
【“Permission denied” Run sudo -i, then the two commands below, then exit.】
3. An example command illustrating the format,Apply executable permissions to the binary.Test the installation.
curl -L https:
//github
.com
/docker/compose/releases/download/1
.8.1
/docker-compose-
`
uname
-s`-`
uname
-m` >
/usr/local/bin/docker-compose
chmod
+x
/usr/local/bin/docker-compose
<br>docker-compose --version
Alternative install options
Install using pip
pip version 6.0 or greater is required
pip
install
docker-compose
Install as a container
curl -L https:
//github
.com
/docker/compose/releases/download/1
.8.0
/run
.sh >
/usr/local/bin/docker-compose
chmod
+x
/usr/local/bin/docker-compose
最后就可以使用docker了,具体按照下面我转载的一篇博文
本次主要是详细记录Docker1.12在Ubuntu16.04上的安装过程,创建Docker组(避免每次敲命令都需要sudo),Docker常用的基本命令的总结,在容器中运行Hello world,以及创建一个基于Python Flask的web应用容器的全过程。
1.Docker1.12在Ubuntu16.04上安装
1.1.先决条件1,添加Docker源
wxl@wxl-pc:~$ sudo apt-get update
- 1
- 2
- 1
- 2
增加CA证书
wxl@wxl-pc:~$ sudo apt-get install apt-transport-https ca-certificates
- 1
- 1
添加GPG Key(一种加密手段)
wxl@wxl-pc:~$ sudo apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
- 1
- 1
创建docker.list文件
wxl@wxl-pc:~$ sudo vim /etc/apt/sources.list.d/docker.list#添加Ubuntu16.04LST的入口deb https://apt.dockerproject.org/repo ubuntu-xenial main
- 1
- 2
- 3
- 1
- 2
- 3
再次更新源
wxl@wxl-pc:~$ sudo apt-get update
- 1
- 2
- 1
- 2
以防万一,清除过时的源
wxl@wxl-pc:~$ sudo apt-get purge lxc-docker
- 1
- 1
验证下APT是从正确的库源下载应用的
wxl@wxl-pc:~$ apt-cache policy docker-engine
- 1
- 1
至此,可见已经配置好了Docker的源
1.2.先决条件2,安装aufs驱动linux-image-extra
For Ubuntu Trusty, Wily, and Xenial, it’s recommended to install the Linux-image-extra kernel package. The linux-image-extra package allows you use the aufs storage driver可以实现容器间可执行文件和运行库的共享。
更新源,会发现Hit:9 https://apt.dockerproject.org/repo ubuntu-xenial InRelease,也说明Docker在第一步1设置成功。
wxl@wxl-pc:~$ sudo apt-get update
- 1
- 2
- 1
- 2
安装 linux-image-extra
wxl@wxl-pc:~$ sudo apt-get install linux-image-extra-$(uname -r)
- 1
- 1
1.3.安装Docker(如果先决条件1,2步正确完成了)
更新源
wxl@wxl-pc:~$ sudo apt-get update
- 1
- 1
通过apt命令在线安装docker
wxl@wxl-pc:~$ sudo apt-get install docker-engine
- 1
- 1
开启docker的守护进程(Docker服务开启)
wxl@wxl-pc:~$ sudo service docker start
- 1
- 1
国际惯例,用一个Hello world的来测试安装成功
wxl@wxl-pc:~$ sudo docker run hello-world
- 1
- 1
本地本来没有Hello World镜像,通过Docker源获取到,并成功现实Hello world。
查看正在运行的容器
sudo docker ps -ls
- 1
- 1
1.4.创建Docker用户组,避免使用sudo
如第一步最后“查看正在运行的容器”如果没有sudo,不以root身份权限运行查看容器命令则会报错Cannot connect to the Docker daemon. Is the docker daemon running on this host?如图
原因:
The docker daemon binds to a Unix socket instead of a TCP port. By default that Unix socket is owned by the user root and other users can access it with sudo. For this reason, docker daemon always runs as the root user.
To avoid having to use sudo when you use the docker command, create a Unix group called docker and add users to it. When the docker daemon starts, it makes the ownership of the Unix socket read/writable by the docker group.
创建用户组docker,可以避免使用sudo
将docker和wxl(王小雷用户名,在创建主机时默认用户名称是ubuntu)添加到一个组内
#默认是ubuntu用户#wxl@wxl-pc:~$ sudo usermod -aG docker ubuntu# 将wxl的用户添加到docker用户组中,如果多个用户需要用空格隔开 如 wxl wxl1 wxl2用户wxl@wxl-pc:~$ sudo usermod -aG docker wxl
- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
注意需要重新启动计算机或者注销用户再登入,才能生效。这样就不需要使用sudo命令了。
那么,如何将wxl从docker用户组移除?
sudo gpasswd -d wxl docker
如何删除刚才创建的docker用户组?
sudo groupdel docker
如何创建和删除新用户,如用户newuser
sudo adduser newuser
sudo userdel newuser
1.5.如何更新Docker
wxl@wxl-pc:~$ sudo apt-get upgrade docker-engine
- 1
- 1
1.6.如何卸载Docker
wxl@wxl-pc:~$ sudo apt-get purge docker-engine
- 1
- 1
2.运行一个web应用–Python Flask
2.1.docker简单命令汇总如下:
- docker run ubuntu /bin/echo “hello world” -运行ubuntu镜像并且在命令窗口输出”hello world”
- docker run -t -i ubuntu /bin/bash -进入ubuntu这个镜像的bash命令窗口,可以操作本镜像ubuntu的命令如ls
- docker ps - 列出当前运行的容器
- docker logs - 展示容器的标准的输出(比如hello world)
- docker stop - 停止正在运行的容器
- docker version -可以查看守护的进程,docker版本以及go版本(docker本身是用go语言写的)
总结,可以看出docker的命令一般为
[sudo] docker [subcommand] [flags] [arguments]
如docker run -i -t ubuntu /bin/bash
2.2.开始运行Python Flask
运行Python Flask应用(这个过程可能很慢,根据网速而定,因为如果本地没有镜像training/webapp:latest会自动线上获取)
完成
查看运行中打容器通过 docker ps -l
注意:查看你打端口号,可能和我打不一样
我的是(把Terminal最大化容易识别)
指定端口号,通过Docker -p,如将32769更改为5000
浏览器访问 http://localhost:80 或者http://localhost/
根据Container ID 或者 NAMES 来使用log和top命令,如我执行时产生的CONTAINER ID是83442361e61b,而NAMES是reverent_saha
# 按Ctrl+c结束 查看logwxl@wxl-pc:~$ docker logs -f reverent_saha
- 1
- 2
- 1
- 2
wxl@wxl-pc:~$ docker top reverent_saha
- 1
- 1
#返回JSON文档查看配置和状态信息wxl@wxl-pc:~$ docker inspect reverent_saha#通过特定JSON文档的元素查看特定的配置和状态信息,如IPwxl@wxl-pc:~$ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' reverent_saha
- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
开启/删除/当前的web应用容器
#关闭reverent_saha名称为的web应用容器wxl@wxl-pc:~$ docker start reverent_saha#删除reverent_saha名称为的web应用容器(注意,容器必须是stop状态)wxl@wxl-pc:~$ docker rm reverent_saha
- 1
- 2
- 3
- 4
- 5
- 1
- 2
- 3
- 4
- 5
关闭web应用容器,通过docker ps -l 查看容器开启状态
wxl@wxl-pc:~$ docker stop reverent_saha#开启reverent_saha名称为的web应用容器wxl@wxl-pc:~$ docker ps -l
- 1
- 2
- 3
- 1
- 2
- 3
此时,在打开 http://localhost/ 已经无法链接,因为停止来python flask的web应用。
算一个简单了解吧
概述:基于Docker的TensorFlow机器学习框架搭建和实例源码解读,TensorFlow作为最火热的机器学习框架之一,Docker是的容器,可以很好的结合起来,为机器学习或者科研人员提供便捷的机器学习开发环境,探索人工智能的奥秘,容器随开随用方便快捷。源码解析TensorFlow容器创建和示例程序运行,为热爱机器学者降低学习难度。
默认机器已经装好了Docker(Docker安装和使用可以看我另一篇博文:Ubuntu16.04安装Docker1.12+开发实例+hello world+web应用容器)。
1.下载TensorFlow镜像
docker pull tensorflow/tensorflow#或者#sudo docker pull tensorflow/tensorflow
- 1
- 2
- 3
- 1
- 2
- 3
2.创建TensorFlow容器,源码解读
docker run --name xiaolei-tensortflow -it -p 8888:8888 -v ~/tensorflow:/notebooks/data tensorflow/tensorflow
- 1
- 1
docker run
运行镜像,--name
为容器创建别名,-it
保留命令行运行,-p 8888:8888
将本地的8888端口http://localhost:8888/
映射,-v ~/tensorflow:/notebooks/data
将本地的~/tensorflow文件夹挂载到新建容器的/notebooks/data下(这样创建的文件可以保存到本地~/tensorflow)tensorflow/tensorflow
为指定的镜像,默认标签为latest(即tensorflow/tensorflow:latest)
3.开启TensorFlow容器
3.1.可以直接从命令行中右键打开连接,或者在浏览器中输入localhost:8888,然后将命令行中的token粘贴上去。
4.开始TensorFlow编程(Python语言)
4.1.在首页可以New
一个Python项目
4.2.tensorflow示例源码解读
from __future__ import print_function#导入tensorflowimport tensorflow as tf#输入两个数组,input1和input2然后相加,输出结果with tf.Session(): input1 = tf.constant([1.0, 1.0, 1.0, 1.0]) input2 = tf.constant([2.0, 2.0, 2.0, 2.0]) output = tf.add(input1, input2) result = output.eval() print("result: ", result)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
4.3.运行程序,输出的结果为(运行成功)
result: [ 3. 3. 3. 3.]
- 1
- 1
5.其他 linux,TensorFlow,Docker相关操作
5.1.关闭TensorFlow和开启TensorFlow环境
#关闭tensorflow容器docker stop xiaolei-tensortflow#开启TensorFlow容器docker start xiaolei-tensortflow#浏览器中输入 http://localhost:8888/
- 1
- 2
- 3
- 4
- 5
- 6
- 1
- 2
- 3
- 4
- 5
- 6
5.2.解决文件的读写权限
#查看读写权限ls -l#将tensorflow 变为属于xiaolei(系统默认)用户sudo chown -R xiaolei tensorflow/#将tensorflow 变为属于xiaolei(系统默认)用户组sudo chgrp -R xiaolei tensorflow/
- Docker的上手(Ubuntu140.4 Mate)
- Docker 快速上手系列(4): 数据卷,数据卷容器的概念及相关操作
- Docker Guideline Docker 上手操作
- WebAPP的mate标签
- html的mate标记
- Docker上手-安装tomcat
- Docker 快速上手指南
- 树梅派应用4:基于Ubuntu Mate的树莓派NAS搭建
- Flex--Mate框架(基于标签的事件框架)
- 众说纷纭的Flex框架Mate
- 移动端的html mate
- Git上手(4)分支
- Docker 快速上手系列(1): 镜像的概念及相关操作
- Docker 快速上手系列(2): 容器的概念及相关操作
- Docker 快速上手系列(3): 仓库的概念及相关操作
- Docker快速上手系列(1):镜像的概念及相关操作
- 打开树莓派3b(ubuntu16.04 mate)的spi配置
- 在树莓派3b的Unbuntu Mate系统上设置网络文件共享(samba)
- 百度地图
- 取数字问题
- scikit learn(sklearn)机器学习算法选择
- NYOJ586疯牛(二分查找算法)
- RxJava+Retrofit上手
- Docker的上手(Ubuntu140.4 Mate)
- 自动化测试
- LR2
- Java数组练习(三)选择排序
- springmvc 接受 map类型的参数
- 递归典型算法
- QT中显示GIF图片
- YOU NEED PYTHON writeup
- angula初探