当前位置: 首页 > news >正文

Docker:快速部署

docker安装: ​‌​‬​⁠​‍‬​‍‬‬‌​‬‬‬​⁠​‍​​‌‬‌​​​​​​‌​​​​⁠​‍⁠‌安装Docker - 飞书云文档 (feishu.cn)

docker命令解读

docker run -d \
> --name mysql \
> -p 3306:3306 \
> -e TZ-Asia/Shanghai \
> -e MYSQL_ROOT_PASSWORD=123 \
> mysql:5.7

·    docker run:创建并运行一个容器,-d是让容器在后台运行

·    --name mysql :给容器起一个名字,必须唯一

·    -p 3307:3306:设置端口映射,宿主机端口映射到容器的端口

·    -e TZ-Asia/Shanghai 和 -e MYSQL_ROOT_PASSWORD=123:环境变量,由镜像的创建者定义,在Docker Hub Container Image Library | App Containerization中查询

·    mysql :5.7:指定运行的镜像的名字( 不写版本的话默认最新版本)

docker常见命令:

docker pull:从镜像仓库拉取到本地

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker pull nginx

docker images:查看所有的本地镜像

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
nginx        latest    605c77e624dd   2 years ago   141MB
mysql        latest    3218b38490ce   2 years ago   516MB

docker rmi:删除镜像

docker build:自定义镜像

docker save:将镜像打包成一个压缩文件

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker save -o nginx.tar nginx:latest
[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# ll
total 2167864
-rw-r--r-- 1 root root           0 Jul  5 20:54 ??ՙ?n?
-rw------- 1 root root   145902080 Sep 30 16:37 nginx.tar

docker load:将压缩文件解压成镜像

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker load -i nginx.tar
2edcec3590a4: Loading layer [==================================================>]  83.86MB/83.86MB
e379e8aedd4d: Loading layer [==================================================>]     62MB/62MB
b8d6e692a25e: Loading layer [==================================================>]  3.072kB/3.072kB
f1db227348d0: Loading layer [==================================================>]  4.096kB/4.096kB
32ce5f6a5106: Loading layer [==================================================>]  3.584kB/3.584kB
d874fd2bc83b: Loading layer [==================================================>]  7.168kB/7.168kB
Loaded image: nginx:latest

docker push:将镜像推送到镜像仓库

docker run:创建并运行容器

docker stop:停止容器的进程

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker stop nginx
nginx

docker start:启动容器的进程

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker start nginx
nginx

docker ps:查看当前容器的运行状态

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker ps
CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                NAMES
3f490131959f   nginx     "/docker-entrypoint.…"   2 minutes ago   Up 4 seconds   0.0.0.0:80->80/tcp   nginx

docker rm:删除容器

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker rm mysql
mysql

docker logs:查看容器日志(停下使用Ctrl+C)

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker logs -f nginx

docker exec:进入容器内部

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker exec -it nginx bash
root@3f490131959f:/# 

命令的别名:

进入编辑模式

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# vi ~/.bashrc

自定义命令别名

alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'
alias dps='docker ps --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"'
alias dis='docker images'

使别名生效

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# source ~/.bashrc

数据卷:

数据卷(volume)是一个虚拟目录。是容器内目录宿主机目录之间的映射桥梁

创建数据卷:/var/lib/docker/volume/html/_data

以利用nginx容器部署静态资源为例

相关命令:

docker run -v:挂载数据卷

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker run -d \
> --name nginx \
> -p 80:80 \
> -v html:/usr/share/nginx/html \     #挂载数据卷
> nginx

docker volume create :创建数据卷

docker volume ls:查看所有数据卷

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker volume ls

docker volume rm:删除指定数据卷

docker volume inspect :查看某个数据卷详情

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker volume inspect html
[{"CreatedAt": "2024-10-01T16:49:55+08:00","Driver": "local","Labels": null,"Mountpoint": "/var/lib/docker/volumes/html/_data","Name": "html","Options": null,"Scope": "local"}
]

docker volume prune :清除数据卷

docker inspect:查看容器是否有数据卷挂载

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker inspect mysql

连接Docker容器中的mysql时要注意端口在防火墙和阿里云是否可见

数据挂载:

基于宿主目录实现mysql数据目录,配置文件,初始化脚本的挂载

挂载/root/mysql/data到容器内的/var/lib/mysql

挂载/root/mysql/init到容器内的/docker-entrypoint-initdb.d目录

挂载/root/mysql/conf到容器内的/etc/mysql/conf.d目录

在执行docker run命令时,使用-v 本地目录:容器内目录可以完成本地目录的挂载

[root@iZ2vcduzd0jmjyj0gisbvzZ mysql]# docker run -d \
> --name mysql \
> -p 3307:3306 \
> -e MYSQL_ROOT_PASSWORD=123 \
> -v /root/mysql/data:/var/lib/mysql \
> -v /root/mysql/init:/docker-entrypoint-initdb.d \
> -v /root/mysql/conf:/etc/mysql/conf.d \
> mysql

自定义镜像:

 镜像结构:层(Layer)

镜像分层的好处:相同的层不用重复下载,节省了空间

Dockerfile:

Dockerfile就是一个文本文件,其中包含多条指令(instruction),用指令来说明要执行什么操作来构建镜像。将来Docker可以根据Dockerfile来构建镜像。

常见指令如下:

编写好Dockerfile之后使用以下docker命令创建自己的镜像

docker build -t myImage:1.0 .

· -t:是指定镜像名,格式为repository:tag的格式,不指定tag时,默认为latest

· .: 是指定Dockerfile所在目录,如果就在当前目录,则指定为"."

Docker网络互联:

默认,所有容器都是以bridge方式连接到Docker的一个虚拟网桥上:

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker inspect dd
"IPAddress": "172.17.0.4",
[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker inspect mysql
"IPAddress": "172.17.0.3",

加入自定义网络的容器才可以通过容器名相互访问,Docker的网络操作命令如下:

创建自有网络:

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker network create demo

查看所有网络:

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker network ls

将指定容器添加到网络:

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker network connect demo mysql

查看网络:

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker inspect demo

创建容器时将其添加到网络:

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker run -d \
> --name dd \
> -p 8080:8080 \
> --network demo \
> docker-demo

nginx 

[root@iZ2vcduzd0jmjyj0gisbvzZ ~]# docker run -d \
> --name dd \
> -p 18080:18080 \
> -p 18081:18081 \
> -v /root/hmsc/nginx/html:/usr/share/nginx/html \
> -v /root/hmsc/nginx/nginx.conf:/ect/nginx/nginx.conf \
> --network demo \
> docker-demo

DockerCompose:

Docker Compose通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的应用容器,帮助实现多个相互关联的Docker容器的快速部署

注:使用docker compost之前先安装docker compost

 使用命令行部署mysql

#使用命令行创建Docker容器
docker run -d \
--name mysql \
-p 3306:3306 \
-e TZ=Asia/Shanghai \
-e MYSQL_ROOT_PASSWORD=123 \
-v ./mysql/data:/var/lib/mysql \
-v ./mysql/conf:/etc/mysql/conf.d \
-v ./mysql/init:/docker-entrypoint-initdb.d \
--network demo \
mysql

使用DockerCompose部署mysql 

#使用yml指定DockerConpose部署的Docker容器
version: "3.8"
services:mysql:image: mysqlcontainer_name: mysqlports:- "3306:3306"environment:TZ: Asia/ShanghaiMYSQL_ROOT_PASSWORD: 123volumes: - "./mysql/conf:/etc/mysql/conf.d"- "./mysql/data:/var/lib/mysql"- "./mysql/init:/docker-entrypoint-initdb.d"network:- hmall

使用DockerCompose创建一系列Docker容器

compose.yml文件

version: "3.8"services:mysql:image: mysqlcontainer_name: mysqlports:- "3306:3306"environment:TZ: Asia/ShanghaiMYSQL_ROOT_PASSWORD: 123volumes:- "./mysql/conf:/etc/mysql/conf.d"- "./mysql/data:/var/lib/mysql"- "./mysql/init:/docker-entrypoint-initdb.d"networks:- hm-nethmall:build: context: .dockerfile: Dockerfilecontainer_name: hmallports:- "8080:8080"networks:- hm-net#后端对应的数据库depends_on:- mysqlnginx:image: nginxcontainer_name: nginxports:- "18080:18080"- "18081:18081"volumes:- "./nginx/nginx.conf:/etc/nginx/nginx.conf"- "./nginx/html:/usr/share/nginx/html"#前端依赖于后端depends_on:- hmallnetworks:- hm-net
#统一定义网络名称
networks:hm-net:name: hmall

 

使用docker compost命令来指定compost文件来构建docker容器

docker compost up \
-f . \
-p hmsc \
-d

http://www.lryc.cn/news/458325.html

相关文章:

  • 如何指定this的值
  • 自动化分析背后,一站式数据分析平台!
  • 掌握 WPF 开发:基础、数据绑定与自定义控件
  • PostgreSQL:生成-唯一主键id
  • Swift添加自定义字体
  • Springboot 整合 Java DL4J 实现企业门禁人脸识别系统
  • SSTI模板注入+CTF实例
  • iPhone 16 Pro 拆解揭秘:设计改进与维修便利性
  • Java项目实战II养老||基于Java+Spring Boot+MySQL的社区智慧养老监护管理平台设计与实现(源码+数据库+文档)
  • 利用FnOS搭建虚拟云桌面,并搭建前端开发环境(二)
  • 【Python】Qwen-VL-7B box
  • echarts按需引入解决项目大小问题
  • 天气预报echarts
  • Kafka-初识
  • Redis的主要的特性和优势 ?
  • yolov5-7.0模型DNN加载函数及参数详解(重要)
  • StringEntity 用于将字符串内容作为 HTTP 请求实体(请求体)
  • 校园系统校园小程序 论坛校园圈系统失物招领、闲置二手、跑腿外卖等校园圈子系统应该具备有哪些功能
  • [AWS云]kafka调用和创建
  • 查看 Excel 应用程序中已打开的 Excel 文件的完整路径
  • 学习 RocketMQ 单机部署、消息发送、消息接收
  • 【计算机网络】CDN
  • 数据结构:插入排序
  • Nginx反向代理配置与负载均衡配置
  • axios 前端与 Django 后端的 POST 交互
  • 数据结构常用术语
  • Flask 轻松上手:从零开始搭建属于你的Web应用
  • [MyBatis-Plus]快速入门
  • 单例模式和读者写者问题
  • 内网wordpress更换IP后无法访问的解决办法