Docker基础

目录:

什么是docker 安装及配置加速器
docker思想
docker核心
docker解决问题
docker架构
基本命令
部署Java web应用
将应用打包成镜像
使用docker大概会用到的一些linux命令

1、什么是docker

Docker是一种新兴的虚拟化技术,能够一定程度上的代替传统虚拟机。
安装:https://docs.docker.com/engine/install/centos/

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

Docker基础_第1张图片
Docker基础_第2张图片
配置加速器

这里额外添加了docker的生产环境核心配置cgroup

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://82m9ar63.mirror.aliyuncs.com"],
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

进入阿里云:https://www.aliyun.com/ 并登录
找到容器镜像服务
Docker基础_第3张图片
点击进入
Docker基础_第4张图片
将加速器地址复制至docker的settings中
Docker基础_第5张图片
加速器配置完成

2、docker思想

集装箱

把货物想象成程序,目前我们要把程序部署到一台新的机器上,可能会启动不起来,比如少一些配置文件什么的或者少了什么数据,有了docker的集装箱可以保证我们的程序不管运行在哪不会缺东西。

标准化

运输方式 存储方式 API接口

隔离

最底层的技术时linux一种内核的限制机制,叫做LXC,LXC是一种轻量级的容器虚拟化技术.最大效率的隔离了进程和资源。

3、docker核心

镜像:集装箱,鲸鱼上面的那些东西

镜像的本质就是一个文件系统,它是基于分层的概念来实现的,底层使用了Docker联合文件系统Union File
System,它是实现Docker镜像的技术基础,是一种轻量级的高性能分层文件系统,支持将文件系统中的修改进行提交和层层叠加,这个特性使得镜像可以通过分层实现和继承。同时支持将不同目录挂载到同一个虚拟文件系统下。
下面几层都是只读的,只有最上层是可写的

Docker基础_第6张图片
仓库:超级码头

Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库同样的,Docker 仓库也有公有和私有的概念。公有的 Docker 仓库名字是 Docker Hub。Docker Hub
提供了庞大的镜像集合供使用。这些镜像可以是自己创建,或者在别人的镜像基础上创建。Docker 仓库是 Docker 的分发部分。

容器:运行程序的地方

Docker 容器和文件夹很类似,一个Docker容器包含了所有的某个应用运行所需要的环境每一个 Docker 容器都是从 Docker 镜像创建的。Docker 容器可以运行、开始、停止、移动和删除。每一个 Docker
容器都是独立和安全的应用平台,Docker 容器是 Docker 的运行部分。

4、docker解决问题

统一标准
● 应用构建
○ Java、C++、JavaScript
○ 打成软件包
○ .exe
○ docker build … 镜像
● 应用分享
○ 所有软件的镜像放到一个指定地方 docker hub
○ 安卓,应用市场
● 应用运行
○ 统一标准的 镜像
○ docker run
● …
资源隔离
● cpu、memory资源隔离与限制
● 访问设备隔离与限制
● 网络隔离与限制
● 用户、用户组隔离限制
● …

5、docker架构

Docker基础_第7张图片
● Docker_Host:
○ 安装Docker的主机
● Docker Daemon:
○ 运行在Docker主机上的Docker后台进程
● Client:
○ 操作Docker主机的客户端(命令行、UI等)
● Registry:
○ 镜像仓库
○ Docker Hub
● Images:
○ 镜像,带环境打包好的程序,可以直接启动运行
● Containers:
○ 容器,由镜像启动起来正在运行中的程序

交互逻辑:装好Docker,然后去 软件市场 寻找镜像,下载并运行,查看容器状态日志等排错

6、基本命令

Docker基础_第8张图片
docker hub:https://hub.docker.com/
下载镜像(这里下载nginx):镜像名:版本名(标签)

docker pull nginx  #下载最新版

docker pull nginx:1.20.1 #下载指定版本号的

docker pull redis  #下载最新
docker pull redis:6.2.4 #下载指定版本号的

redis = redis:latest #都是最新版

查看所有镜像:

## 下载来的镜像都在本地
docker images  #查看所有镜像

删除镜像:

#删除镜像 (可以根据版本号或者id去删除)
docker rmi 镜像名:版本号/镜像id

启动容器:
【docker run 设置项 镜像名 】 镜像启动运行的命令(镜像里面默认有的,一般不会写)

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

# -d:后台运行
# --restart=always: 开机自启
docker run --name=mynginx   -d  --restart=always -p  88:80   nginx

Docker基础_第9张图片

查看正在运行的容器:

docker ps

查看所有:

docker ps -a

删除停止的容器:

docker rm  容器id/名字
docker rm -f mynginx   #强制删除正在运行中的

停止容器:

docker stop 容器id/名字

再次启动

docker start 容器id/名字

应用开机自启

docker update 容器id/名字 --restart=always

进入容器内部的系统,修改容器内容:

docker exec -it 容器id  /bin/bash

Docker基础_第10张图片

挂载数据到外部修改:

docker run --name=mynginx   \
-d  --restart=always \
-p  88:80 -v /data/html:/usr/share/nginx/html:ro  \
nginx

# 修改页面只需要去 主机的 /data/html

(提交修改)把自己修改好的镜像提交

docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]

docker commit -a "xiangchimidoufu"  -m "首页变化" 341d81f7504f guignginx:v1.0

镜像传输(适合离线安装)

# 将镜像保存成压缩包
docker save -o abc.tar guignginx:v1.0

# 别的机器加载这个镜像
docker load -i abc.tar


# 离线安装

推送远程仓库

# 把旧镜像的名字,改成仓库要求的新版名字
docker tag local-image:tagname new-repo:tagname
docker push new-repo:tagname
docker tag guignginx:v1.0 leifengyang/guignginx:v1.0
docker logout(推送完成镜像后退出)

登录到docker hub

docker login       

推送

docker push xiangchimidoufu/guignginx:v1.0

别的机器下载

docker pull xiangchimidoufu/guignginx:v1.0

查看日志:

docker logs 容器名/id   排错
docker exec -it 容器id /bin/bash
# docker 经常修改nginx配置文件
docker run -d -p 80:80 \
-v /data/html:/usr/share/nginx/html:ro \
-v /data/conf/nginx.conf:/etc/nginx/nginx.conf \
--name mynginx-02 \
nginx

#把容器指定位置的东西复制出来 
docker cp 5eff66eec7e1:/etc/nginx/nginx.conf  /data/conf/nginx.conf
#把外面的内容复制到容器里面
docker cp  /data/conf/nginx.conf  5eff66eec7e1:/etc/nginx/nginx.conf

7、部署Java web应用

Docker基础_第11张图片
将应用打包成镜像
以前:

Java为例
● SpringBoot打包成可执行jar
● 把jar包上传给服务
● 服务器运行java -jar

现在:

所有机器都安装Docker,任何应用都是镜像,所有机器都可以运行

打包-Dockerfile

FROM openjdk:8-jdk-slim
LABEL maintainer=leifengyang

COPY target/*.jar   /app.jar

ENTRYPOINT ["java","-jar","/app.jar"]

将文件夹上传到linux部署的服务器上:

scp -r 要上传的文件夹的路径 要上传到的服务器名称:及路径

Docker基础_第12张图片
上传成功:
Docker基础_第13张图片

构建:

docker build -t java-demo:v1.0 .

启动容器:

docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0 

分享镜像:

# 登录docker hub
docker login

#给旧镜像起名
docker tag java-demo:v1.0  xiangchimidoufu/java-demo:v1.0

# 推送到docker hub
docker push xiangchimidoufu/java-demo:v1.0

# 别的机器
docker pull xiangchimidoufu/java-demo:v1.0

# 别的机器运行
docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0 

部署中间件:

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

#redis使用自定义配置文件启动

docker run -v /data/redis/redis.conf:/etc/redis/redis.conf \
-v /data/redis/data:/data \
-d --name myredis \
-p 6379:6379 \
redis:latest  redis-server /etc/redis/redis.conf

8、使用docker大概会用到的一些linux命令

Docker基础_第14张图片
Docker基础_第15张图片
Docker基础_第16张图片
Docker基础_第17张图片
Docker基础_第18张图片
Docker基础_第19张图片
Docker基础_第20张图片
Docker基础_第21张图片
Docker基础_第22张图片
Docker基础_第23张图片
Docker基础_第24张图片
Docker基础_第25张图片

你可能感兴趣的:(笔记,docker,容器,linux)