Ubuntu16.04安装Docker1.12+开发实例+hello world+web应用容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本次主要是详细记录Docker1.12在Ubuntu16.04上的安装过程,创建Docker组(避免每次敲命令都需要sudo),Docker常用的基本命令的总结,在容器中运行Hello world,以及创建一个基于Python Flask的web应用容器的全过程。1.Docker1.12在Ubuntu16.04上安装1.1.先决条件1,添加Docker源wxl

本次主要是详细记录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

增加CA证书

wxl@wxl-pc:~$ sudo apt-get install apt-transport-https ca-certificates

添加GPG Key(一种加密手段)

wxl@wxl-pc:~$ sudo apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D

创建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

再次更新源

wxl@wxl-pc:~$ sudo apt-get update

以防万一,清除过时的源

wxl@wxl-pc:~$ sudo apt-get purge lxc-docker

验证下APT是从正确的库源下载应用的

wxl@wxl-pc:~$ apt-cache policy docker-engine

这里写图片描述
至此,可见已经配置好了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

安装 linux-image-extra

wxl@wxl-pc:~$ sudo apt-get install linux-image-extra-$(uname -r)

这里写图片描述

1.3.安装Docker(如果先决条件1,2步正确完成了)

更新源

wxl@wxl-pc:~$ sudo apt-get update

通过apt命令在线安装docker

wxl@wxl-pc:~$ sudo apt-get install docker-engine

开启docker的守护进程(Docker服务开启)

wxl@wxl-pc:~$ sudo service docker start

国际惯例,用一个Hello world的来测试安装成功

wxl@wxl-pc:~$ sudo docker run hello-world

本地本来没有Hello World镜像,通过Docker源获取到,并成功现实Hello world。
这里写图片描述
查看正在运行的容器

sudo docker ps -ls

这里写图片描述

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

注意需要重新启动计算机或者注销用户再登入,才能生效。这样就不需要使用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.6.如何卸载Docker

wxl@wxl-pc:~$ sudo apt-get purge docker-engine

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结束 查看log
wxl@wxl-pc:~$ docker logs -f reverent_saha

这里写图片描述

wxl@wxl-pc:~$ docker top reverent_saha

这里写图片描述

#返回JSON文档查看配置和状态信息
wxl@wxl-pc:~$ docker inspect reverent_saha
#通过特定JSON文档的元素查看特定的配置和状态信息,如IP
wxl@wxl-pc:~$ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' reverent_saha

开启/删除/当前的web应用容器

#关闭reverent_saha名称为的web应用容器

wxl@wxl-pc:~$ docker start reverent_saha
#删除reverent_saha名称为的web应用容器(注意,容器必须是stop状态)
wxl@wxl-pc:~$ docker rm reverent_saha

关闭web应用容器,通过docker ps -l 查看容器开启状态

wxl@wxl-pc:~$ docker stop reverent_saha
#开启reverent_saha名称为的web应用容器
wxl@wxl-pc:~$ docker ps -l

这里写图片描述

此时,在打开 http://localhost/ 已经无法链接,因为停止来python flask的web应用。

目录
相关文章
|
3天前
|
存储 监控 安全
【专栏】Docker Compose:轻松实现容器编排的利器
【4月更文挑战第27天】Docker Compose是款轻量级容器编排工具,通过YAML文件统一管理多容器应用。本文分三部分深入讨论其核心概念(服务、网络、卷和配置)、使用方法及最佳实践。从快速入门到高级特性,包括环境隔离、CI/CD集成、资源管理和安全措施。通过案例分析展示如何构建多服务应用,助力高效容器编排与管理。
|
3天前
|
存储 Kubernetes C++
【专栏】Kubernetes VS Docker Swarm:哪个容器编排工具更适合你?
【4月更文挑战第27天】对比Kubernetes和Docker Swarm:K8s在可扩展性和自动化方面出色,有强大社区支持;Swarm以简易用著称,适合初学者。选择取决于项目需求、团队技能和预期收益。高度复杂项目推荐Kubernetes,快速上手小项目则选Docker Swarm。了解两者特点,助力选取合适容器编排工具。
|
3天前
|
Cloud Native Linux 开发者
【Docker】Docker:解析容器化技术的利器与在Linux中的关键作用
【Docker】Docker:解析容器化技术的利器与在Linux中的关键作用
|
1天前
|
存储 虚拟化 数据中心
|
1天前
|
运维 Prometheus 监控
构建高效稳定的Docker容器监控体系
【4月更文挑战第29天】在微服务架构日益普及的当下,Docker作为轻量级容器的代表,被广泛应用于服务部署与管理。然而,随之而来的是复杂化的服务监控问题。本文旨在探讨如何构建一个高效且稳定的Docker容器监控体系,确保服务的高可用性。我们将从监控工具的选择、关键监控指标的确定,以及告警机制的设计等方面进行详细阐述,并提供一系列优化实践,以期为运维人员提供参考和指导。
|
2天前
|
运维 Serverless 应用服务中间件
Serverless 应用引擎产品使用之在Serverless应用引擎(SAE)中,在创建ALB时找不到对应的SAE容器如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
6 0
|
2天前
|
Java Maven Docker
基于docker容器化部署微服务
基于docker容器化部署微服务
5 0
|
2天前
|
网络协议 Java Docker
使用docker编排容器(下)
使用docker编排容器(下)
8 0
|
2天前
|
Java 应用服务中间件 nginx
使用docker编排容器(上)
使用docker编排容器
7 0
|
2天前
|
Prometheus 监控 Cloud Native
构建高效的Docker容器监控体系
【4月更文挑战第28天】 在微服务架构和容器化部署日益普及的今天,对容器进行有效的性能监控成为确保系统稳定性的关键。本文将深入探讨如何构建一个高效的Docker容器监控体系,覆盖从监控指标的选择、数据采集、存储到可视化展示的全流程。我们将分析现有监控工具的优势与局限,并提出一种综合使用Prometheus、Grafana和自定义监控脚本的解决方案,旨在为运维人员提供实时、准确的容器监控数据,帮助快速定位并解决潜在问题。
14 1