Docker基本概念
统一标准
- 应用构建
Java、C++、JavaScript
打成软件包
.exe
docker build .... 镜像
- 应用分享
所有软件的镜像放到一个指定地方 docker hub
安卓,应用市场
- 应用运行
统一标准的 镜像
docker run
资源隔离
- cpu、memory资源隔离与限制
- 访问设备隔离与限制
- 网络隔离与限制
- 用户、用户组隔离限制
架构
- Docker_Host:
安装Docker的主机
- Docker Daemon:
运行在Docker主机上的Docker后台进程
- Client:
操作Docker主机的客户端(命令行、UI等)
- Registry:
镜像仓库
Docker Hub
- Images:
镜像,带环境打包好的程序,可以直接启动运行
- Containers:
容器,由镜像启动起来正在运行中的程序
交互逻辑
装好Docker,然后去 软件市场 寻找镜像,下载并运行,查看容器状态日志等排错
安装
centos下安装docker
其他系统参照如下文档
Install Docker Engine on CentOS | Docker Documentation
移除之前docker相关包
sudo yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-engine
配置yum源
sudo yum install -y yum-utils sudo yum-config-manager \ --add-repo \ http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装docker
sudo yum install -y docker-ce docker-ce-cli containerd.io #以下是在安装k8s的时候使用 yum install -y docker-ce-20.10.7 docker-ce-cli-20.10.7 containerd.io-1.4.6
启动
systemctl enable docker --now
配置加速
这里额外添加了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
Docker命令实战
常用命令
基础实战
去docker hub,找到nginx镜像
docker pull nginx #下载最新版 镜像名:版本名(标签) docker pull nginx:1.20.1 docker pull redis #下载最新 docker pull redis:6.2.4 ## 下载来的镜像都在本地 docker images #查看所有镜像 redis = redis:latest docker rmi 镜像名:版本号/镜像id
启动容器
启动nginx应用容器,并映射88端口,测试的访问
docker run [OPTIONS] IMAGE [COMMAND] [ARG...] 【docker run 设置项 镜像名 】 镜像启动运行的命令(镜像里面默认有的,一般不会写) # -d:后台运行 # --restart=always: 开机自启 docker run --name=mynginx -d --restart=always -p 88:80 nginx # 查看正在运行的容器 docker ps # 查看所有 docker ps -a # 删除停止的容器 docker rm 容器id/名字 docker rm -f mynginx #强制删除正在运行中的 #停止容器 docker stop 容器id/名字 #再次启动 docker start 容器id/名字 #应用开机自启 docker update 容器id/名字 --restart=always
修改容器内容
修改默认的index.html 页面
进容器内部修改
# 进入容器内部的系统,修改容器内容 docker exec -it 容器id /bin/bash
挂载数据到外部修改
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 "leifengyang" -m "首页变化" 341d81f7504f guignginx:v1.0
镜像传输
# 将镜像保存成压缩包 docker save -o abc.tar guignginx:v1.0 # 别的机器加载这个镜像 docker load -i abc.tar # 离线安装
推送远程仓库
推送镜像到docker hub;应用市场
docker tag local-image:tagname new-repo:tagname docker push new-repo:tagname
# 把旧镜像的名字,改成仓库要求的新版名字 docker tag guignginx:v1.0 leifengyang/guignginx:v1.0 # 登录到docker hub docker login docker logout(推送完成镜像后退出) # 推送 docker push leifengyang/guignginx:v1.0 # 别的机器下载 docker pull leifengyang/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
进阶实战
编写自己的应用
编写一个HelloWorld应用
示例代码: https://gitee.com/leifengyang/java-demo.git
将应用打包成镜像
编写Dockerfile将自己的应用打包镜像
以前
Java为例
- SpringBoot打包成可执行jar
- 把jar包上传给服务
- 服务器运行java -jar
现在
所有机器都安装Docker,任何应用都是镜像,所
docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0
有机器都可以运行
怎么打包-Dockerfile
FROM openjdk:8-jdk-slim LABEL maintainer=leifengyang COPY target/*.jar /app.jar ENTRYPOINT ["java","-jar","/app.jar"]
docker build -t java-demo:v1.0 .
启动容器
启动应用容器
分享镜像
# 登录docker hub docker login #给旧镜像起名 docker tag java-demo:v1.0 leifengyang/java-demo:v1.0 # 推送到docker hub docker push leifengyang/java-demo:v1.0 # 别的机器 docker pull leifengyang/java-demo:v1.0 # 别的机器运行 docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0
部署中间件
部署一个Redis+应用,尝试应用操作Redis产生数据
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