13-Docker

作者: XAbo | 来源:发表于2022-01-14 12:22 被阅读0次

一、基础

Docker命令 Docker架构

启动:

systemctl start docker

守护进程重启:

systemctl daemon-reload

重启docker服务:

systemctl restart docker / service docker restart

关闭:

docker service docker stop / docker systemctl stop docker

二、镜像

镜像原理 镜像加速器

搜索镜像

$ docker search 镜像名称

下载镜像

$ docker pull 镜像名

查看宿主机上的镜像

$ docker images

删除镜像

$ docker rmi 镜像ID/标签

三、容器

查看当前运行的容器

$ docker ps

查看所有容器

$ docker ps -a

删除容器

$ docker rm 容器ID

创建容器

$ docker create -it centos:latest
$ docker create -it --name tomcat01 centos:latest

启动容器

$ docker exec -it 容器ID/容器NAME /bin/bash
$ docker exec -it 容器ID/容器NAME bash

创建\启动\进入容器

$ docker run -it centos:latest /bin/bash

指定了端口号

$ docker run -it -p 7001:8001 centos:latest /bin/bash

使用 -P 标记时,Docker 会随机映射一个 49000~49900 的端口

$ docker run -it -P --name tomcat03 centos:latest /bin/bash
#开启端口号 firewall-cmd --zone=public --add-port=5671/tcp --permanent
firewall-cmd --zone=public --add-port=15671/tcp --permanent
#重启防火墙(不重启以上的设置是不会生效的): firewall-cmd --reload

关闭容器:

docker stop 容器ID或容器名

重启容器:

docker restart 容器ID或容器名 :不管容器是否启动,直接重启容器。
docker restart 参数-t:关闭容器的限时,如果超时未能关闭则用kill强制关闭,默认值10s,这个时间用于容器的自己保存状态

四、数据卷

数据卷

配置数据卷

docker run -v 宿主机目录:容器内目录
数据卷容器 配置数据卷容器

五、部署应用

部署MySql 部署Tomcat

部署Spring Boot项目:
摘抄:Docker部署SpringBoot项目 - 简书 (jianshu.com)

  • 编写Dockerfile文件
# 基础镜像使用java
FROM java:8
# 作者
MAINTAINER eangulee <eangulee@gmail.com>
# VOLUME 指定了临时文件目录为/tmp。
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
VOLUME /tmp 
# 将jar包添加到容器中并更名为app.jar
ADD demo-0.0.1-SNAPSHOT.jar app.jar 
# 运行jar包
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
  • 部署文件
    在服务器新建一个docker文件夹,将maven打包好的jar包和Dockerfile文件复制到服务器的docker文件夹下。
  • 制作镜像 :docker build -t springbootdemo4docker .
  • 启动容器 : docker run -d -p 8080:8085 springbootdemo4docker
Dockerfile 关键字

六、服务编排

摘抄:Docker教程及完整讲义(入门级)_三月江东的博客-CSDN博客_docker 教程

Docker Compose 是一个编排多容器分布式部署的工具,提供命令集管理器化应用的完整开发期,包括服务构建,启动和停止。
使用步骤:

  • 利用 Dockerfile 定义运行环境镜像
  • 使用 docker-compose.yml 定义组成应用的各服务
  • 运行 docker-compose up 启动应用

安装Docker Compose

#Compose 目前已经完全支持Linux、MAC OS、Windows,在安装Compose之前,需要先安装Docker。下面以编译好的二进制包方式安装在Linux中
curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-'uname -s'-'uname -m' -o /usr/local/bin/docker-compose
#设置文件可执行权限
chmod +x /usr/local/bin/docker-compose
#查看版本信息
docker-compose -version

卸载Docker Compose

#二进制包方式安装的,删除二进制文件即可
rm /usr/local/bin/docker-compose

案例:使用docker compose编排nginx+springboot项目
1.创建docker-compose目录

mkdir ~/docker-compose
cd ~/docker-compose

2.编写docker-compose.yml文件

version: '3'
services:
  nginx:
   iamge: nginx
   ports:
    - 80:80
   links:
    - app
   volumes:
    - ./nginx/conf.d:/etc/nginx/conf.d
   app:
     image: app
     expose:
       - "8080"

3.创建./nginx/conf.d目录

mkdir -p ./nginx/conf.d

4.在./nginx/conf.d目录下编写crisp.conf文件

server {
    listen 80;
    acess_log off;
    location / {
        proxy_pass https://app:8080;
    }
}

5.在~/docker-compose目录下 使用dockers-compose 启动容器

docker-compose up

七、私有仓库

1.拉取私有仓库镜像

docker pull registry

2.启动私有仓库容器

docker run -id --name=registry -p 5000:5000 registry

3.打开浏览器,输入地址https://私有仓库服务器ip:5000/v2/_catalog看到{"repositories":[]}表示私有仓库搭建成功
4.修改deamon.json

vim /etc/docker/daemon.json
#在上述文件中添加一个key,保存退出。
#此步用于让docker信任私有仓库地址
#注意将私有仓库服务器ip修改为自己私有仓库服务器真实ip
{"insecure-registries": ["私有仓库服务器ip:5000"]}

5.重启docker 服务

systemctl restart docker
docker start registry

6.标记镜像为私有仓库的镜像

docker tag centos:7 私有仓库服务器ip:5000/centos:7

7.上传标记的镜像

docker push 私有仓库服务器ip:5000/centos:7

8.从私有仓库拉取镜像

docker pull 私有仓库服务器ip:5000/centos:7

相关文章

网友评论

      本文标题:13-Docker

      本文链接:https://www.haomeiwen.com/subject/zreacrtx.html