day02 -- docker

1.docker的介绍

Docker 是一个开源的应用容器引擎,基于 Go语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低
Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。
镜像:将应用所需的函数库、依赖、配置等与应用一起打包得到的就是镜像(模板)
容器:为每个镜像的应用进程创建的隔离运行环境就是容器(实例)
镜像仓库:存储和管理镜像的地方就是镜像仓库,DockerHub是目前最大的镜像仓库,其中包含各种常见的应用镜像

2.docker的安装

2.1 卸载旧版本

sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine

2.2 设置Docker仓库

yum-utils 提供了 yum-config-manager ,并且 device mapper 存储驱动程序需要 device-mapper-persistent-data 和 lvm2

sudo yum install -y yum-utils

截图如下:
在这里插入图片描述

官方docker仓库

sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

华为源

sudo yum-config-manager --add-repo https://mirrors.huaweicloud.com/docker-ce/linux/centos/docker-ce.repo
sudo sed -i 's+download.docker.com+mirrors.huaweicloud.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo

阿里docker仓库

sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
sudo sed -i 's+download.docker.com+mirrors.aliyun.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo

清华docker仓库

sudo yum-config-manager --add-repo https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/centos/docker-ce.repo

腾讯源

yum-config-manager --add-repo=https://mirrors.cloud.tencent.com/docker-ce/linux/centos/docker-ce.repo

建议使用国内源等

2.3 安装 Docker Engine-Community

yum install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin

在这里插入图片描述
2.4 配置docker hub加速器(国内源)

sudo vi /etc/docker/daemon.json

修改内容如下:

{  "registry-mirrors": [  "https://registry.docker-cn.com","http://hub-mirror.c.163.com","https://hub.geekery.cn","https://dockerpull.com","https://docker.m.daocloud.io","https://docker.mirrors.ustc.edu.cn"]  
}

加载配置,启动Docker服务,查看镜像是否配置成功

sudo systemctl daemon-reload  
sudo systemctl start docker
sudo docker info

在输出信息中,你应该能看到Registry Mirrors部分,并且列出了你添加的镜像源地址
在这里插入图片描述
在这里插入图片描述

2.5 设置docker开机自启

systemctl enable docker

也有停止(stop),重启(restart),检查状态(status)命令

2.6 创建mysql容器

docker run -d --name mysql -p 3306:3306 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=12345678 mysql

在这里插入图片描述
在这里插入图片描述

3.docker的常见命令

所有命令都可以通过--help进行查看

3.1 命令解读

docker run -d --name mysql -p 3306:3306 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=12345678 mysql

命令解释

docker run :创建并运行一个容器
-d 是让容器在后台运行
--name mysql :给容器起个名字,必须唯一
-p 3306:3306 :设置端口映射
-e KEY=VALUE :是设置环境变量
mysql :指定运行的镜像名称

镜像命名规范
镜像名称一般分两部分组成:[repository]:[tag]
其中repository就是镜像名,tag是镜像的版本
在没有指定tag时,默认是latest,代表最新版本的镜像
常见命令图
在这里插入图片描述
详见官方文档

3.2 镜像命令

可以从 Docker Hub 网站来搜索镜像,Docker Hub 网址

3.2.1 查看镜像 – docker images
docker images

在这里插入图片描述

3.2.2 仓库拉取镜像 – docker pull
docker pull 镜像名称

例:拉取nginx

docker pull nginx

在这里插入图片描述

3.2.3 保存镜像文件 – docker save
docker save -o 文件名.tar 镜像名称

例:将nginx镜像保存到本地

docker save -o nginx.tar nginx:latest
3.2.4 加载镜像文件 – docker load
docker load -i 镜像文件

注:镜像文件中的镜像在docker中没有拉取才能成功加载进去,否则需要删除镜像后,再把外部的镜像加载进去

docker load -i nginx.tar

在这里插入图片描述

3.2.5 构建镜像 --docker build

需要自己编写Dockerfile文件,实例参照自定义镜像

docker build -t 镜像名 Dockerfile目录
3.2.6 删除镜像 --docker rmi
docker rmi 镜像名称

例:删除nginx

docker rmi nginx

3.3 容器命令

3.3.1 查看容器状态

默认只查看运行中的容器状态,可加-a查看所有容器的状态

docker ps
3.3.2 格式输出
docker ps --format "table {{.Names}}\t{{.ID}}\t{{.Ports}}\t{{.Status}}\t{{.Image}}"
3.3.3 查看容器运行日志

默认后台运行,可加-f实现前台运行,ctrl+C退出

docker logs 容器名

在这里插入图片描述

3.3.4 进入容器
docker exec -it 容器名 bash

例:进入mysql容器,退出exit

 docker exec -it mysql bash

进入数据库

mysql -uroot -p

输入密码,即可进入数据库

3.3.5 停止容器
docker stop 容器名
3.3.6 启动容器
docker start 容器名
3.3.7 删除容器
docker rm 容器名

在这里插入图片描述

3.4 别名

实际上就是相当于设置快捷键

 vi ~/.bashrc

第一次打开会有默认的配置
在这里插入图片描述
也可以自己加进去

alias dps='docker ps --format "table {{.Names}}\t{{.ID}}\t{{.Ports}}\t{{.Status}}\t{{.Image}}"'

重新加载

source ~/.bashrc

在这里插入图片描述

4.docker数据卷与本地目录的挂载

4.1 数据卷挂载

在这里插入图片描述

数据卷是一个虚拟目录,它将宿主机目录映射到容器内目录,方便我们操作容器内文件,或者方便迁移容器产生的数据
挂载数据卷
在创建容器时,利用 -v 数据卷名:容器内目录完成挂载
容器创建时,如果发现挂载的数据卷不存在时,会自动创建
常见命令

# 查看数据卷
docker volume ls
# 删除数据卷
docker volume rm
# 查看数据卷详情
docker volume inspect
# 删除未使用的数据卷
docker volume prune

例:利用Nginx容器部署静态资源

  • 创建Nginx容器,修改nginx容器内的html目录下的index.html文件内容
  • 将静态资源部署到nginx的html目录

注:在执行docker run命令时,使用 -v 数据卷:容器内目录 可以完成数据卷挂载;当创建容器时,如果挂载了数据卷且数据卷不存在,会自动创建数据卷
1.将静态资源上传
在这里插入图片描述

2.创建容器

docker run -d \
--name nginx \
-p 80:80  \
-v html:/usr/share/nginx/html \
nginx

在这里插入图片描述
3.查看卷

docker volume ls
docker volume inspect html

在这里插入图片描述
只要本地文件系统的挂载文件变化对应的容器里的文件也会发送变化

4.2 本地目录挂载

与挂载数据卷类似,
挂载本地目录
在创建容器时,利用 -v 本地目录:容器内目录完成挂载
例如:
mysql容器的数据挂载
查看mysql容器,判断是否有数据卷挂载
基于宿主机目录实现MySQL数据目录、配置文件、初始化脚本的挂载(查阅官方镜像文档)

  1. 挂载/root/mysql/data到容器内的/var/lib/mysql目录
  2. 挂载/root/mysql/init到容器内的/docker-entrypoint-initdb.d目录,携带课前资料准备的SQL脚本
  3. 挂载/root/mysql/conf到容器内的/etc/mysql/conf.d目录,携带课前资料准备的配置文件

注:
本地目录必须以“/”或 “./” 开头,如果直接以名称开头,会被识别为数据卷而非本地目录

  • -v mysql : /var/lib/mysql 会被识别为一个数据卷叫mysql
  • -v ./mysql : /var/lib/mysql 会被识别为当前目录下的mysql目录
  1. 上传资源
  2. 创建容器
docker run -d --name mysql -p 3306:3306  -v /root/mysql/data:/var/lib/mysql -v /root/mysql/init:/docker-entrypoint-initdb.d -v /root/mysql/conf:/etc/mysql/conf.d --network heima -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=123456 mysql

在这里插入图片描述
3.连接数据库查看
在这里插入图片描述

5.自定义镜像

5.1 镜像结构

在这里插入图片描述

5.2 Dockerfile

在这里插入图片描述
在这里插入图片描述

# 基础镜像
FROM openjdk:11.0-jre-buster
# 设定时区
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# 拷贝jar包
COPY hm-service.jar /app.jar
# 入口
ENTRYPOINT ["java", "-jar", "/app.jar"]

例:
Java项目先打包(maven中package),在把打包后的jar包和Dockerfile上传到同一个目录下,在这个目录下再进镜像构建,创建容器

1. 上传资源

2. 构建镜像

docker build -t hmall .

3. 创建容器

docker run --name hmall --network heima -p 8080:8080 -d  hmall

在这里插入图片描述
在这里插入图片描述
参考博客:docker快速入门

6.容器网络互连

默认情况下,所有容器都是以bridge方式连接到Docker的一个虚拟网桥(docker0 172.17.0.1/16)上
在这里插入图片描述

6.1 相关命令

命令说明
docker network create创建网络
docker network ls查看所有网络
docker network rm删除指定网络
docker network prune清除未使用的网络
docker network connect使指定容器连接加入某网络
docker network disconnect使指定容器连接离开某网络
docker network inspect查看网络详情

加入自定义网络的容器才可以通过容器名互相访问,默认网络下容器间不能相互访问

6.2 案例

例:创建自定义网络,创建容器加入此网络

 docker network create cat
 docker network ls
docker run --name hmall -p 8080:8080 -d --network cat  hmall

注:容器名不能与现有的容器名重复
在这里插入图片描述

7.项目部署

部署前请先清空容器与镜像,防止创建时冲突
例:黑马商城

7.1 自定义网络

 docker network create catgod007

在这里插入图片描述

7.2 数据库容器部署

1.上传资源
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.创建容器

docker run -d --name mysql -p 3306:3306  -v /root/mysql/data:/var/lib/mysql -v /root/mysql/init:/docker-entrypoint-initdb.d -v /root/mysql/conf:/etc/mysql/conf.d --network catgod007 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=123456 mysql

在这里插入图片描述
也可以用数据库可视化工具查看数据库表是否都在

7.3 后端项目容器部署

1.资源上传
把hmall项目用idea打开,用maven中的package进行打包(会在与src同级的target目录中出现);把dockerfile和jar包上传
在这里插入图片描述

2.构建镜像

docker build -t hmall .

3.创建容器

docker run --name hmall --network catgod007 -p 8080:8080 -d  hmall

在这里插入图片描述

7.4 前端项目容器部署

1.上传资源
将资料提供的nginx.conf、html目录与容器挂载(nginx整个文件夹上传)
nginx的配置文件(nginx.conf)中的8080前域名要与后端部署的容器名保持一致(默认hmall)
2.创建容器

docker run -d \
--name nginx \
-p 18080:18080  \
-p 18081:18081  \
-v /root/nginx/html:/usr/share/nginx/html \
-v /root/nginx/nginx.conf:/etc/nginx/nginx.conf \
--network catgod007 \
nginx

在这里插入图片描述

7.5 最终展示

浏览器输入ip地址:18080

在这里插入图片描述

8.docker compose 部署容器

8.1 Docker Compose介绍

Docker Compose通过一个单独的docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器,帮助我们实现多个相互关联的Docker容器的快速部署
常见命令
在这里插入图片描述
上面的项目部署可以改成通过docker-compose.yml一键部署

version: "3"services:mysql:image: mysqlcontainer_name: mysqlports:- "3306:3306"environment:TZ: Asia/ShanghaiMYSQL_ROOT_PASSWORD: 123456volumes:- "./mysql/conf:/etc/mysql/conf.d"- "./mysql/data:/var/lib/mysql"- "./mysql/init:/docker-entrypoint-initdb.d"networks:- cat-nethmall:build: context: .dockerfile: Dockerfilecontainer_name: hmallports:- "8080:8080"networks:- cat-netdepends_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:- cat-net
networks:cat-net:name: catgod007

注:

  • docker-compose.yml主要分为项目(Project)与服务(Services)
  • 服务相关参数与docker构建容器差不多,部分如下:
    • depends_on ;依赖,及前端依赖后端,后端依赖数据库

8.2 案例:一键部署项目

1.上传docker-compose.yml到/root
在这里插入图片描述

2.清空容器和镜像
在这里插入图片描述
在这里插入图片描述

3.通过docker-compose.yml部署容器

docker compose up -f ./docker-compose.yml -p catgod007 -d

docker-compose.yml在当前目录下,可省略-f ./docker-compose.yml
-p catgod007指定名字,不指定默认root
-d后台运行

docker compose up -d

在这里插入图片描述
在这里插入图片描述

4.通过浏览器进行访问
浏览器输入ip地址:18080
在这里插入图片描述
感谢大家的支持,关注,评论,点赞!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/56854.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

●day 35 动态规划part01

第九章 动态规划part01 动态规划的类别 理论基础 动态规划下五步曲: 1、确定dp数组(dp table)以及下标的含义 2、确定递推公式 3、dp数组如何初始化 4、确定遍历顺序 5、打印dp数组 代码随想录 斐波那契数 代码随想录 动态规划5部曲 cla…

高级语言源程序转换为可执行目标文件

将高级语言源程序转换为可执行目标文件的过程通常包括以下几个主要步骤: ​ 1. 预处理(Preprocessing): 由谁完成预处理器(cpp)操作处理源代码中的预处理指令(如宏定义、文件包含、条件编译等&…

Linux——动态卷的管理

确保已经设置了对应的动态卷的驱动(provisioner 制备器)基于动态驱动创建对应的存储类创建PVC (PVC 将会自动根据大小、访问模式等创建PV)Pod的spec 中通过volumes 和 volumemounts 来完成pvc 的绑定和pvc对应pv的挂载删除pod 不…

Linux网络编程(七)-TCP协议客户端及代码实现

1.TCP的客户端代码流程简述 这一章将为大家讲解Socket通信中客户端的实现过程,还是先上图,请大家了解客户端的步骤 可以看到,相比服务端,客户端的步骤简单的很多。事实上这种情况比较多,比如一个服务端会有多个客户端…

JMeter模拟并发请求

PostMan不是严格意义上的并发请求工具,实际是串行的,如果需要测试后台接口并发时程序的准确性,建议采用JMeter工具。 案例:JMeter设置20个并发卖票请求,查看后台是否存在超卖的情况 方式一:一共10张票&…

TrickMo 安卓银行木马新变种利用虚假锁屏窃取密码

近期,研究人员在野外发现了 TrickMo Android 银行木马的 40 个新变种,它们与 16 个下载器和 22 个不同的命令和控制(C2)基础设施相关联,具有旨在窃取 Android 密码的新功能。 Zimperium 和 Cleafy 均报道了此消息。 …

编写一个通用的i2c控制器驱动框架

往期内容 I2C子系统专栏: I2C(IIC)协议讲解-CSDN博客SMBus 协议详解-CSDN博客I2C相关结构体讲解:i2c_adapter、i2c_algorithm、i2c_msg-CSDN博客内核提供的通用I2C设备驱动I2c-dev.c分析:注册篇内核提供的通用I2C设备驱动I2C-dev.…

时空数据时序预测模型: HA、VAR、GBRT、GCN、DCRNN、FCCF、ST-MGCN

HA (Historical Average) HA (Historical Average,历史平均模型) 是一种基础的时间序列预测方法,通常用于预测具有周期性或季节性规律的数据。它通过计算历史上同一时间段的平均值来预测未来值,假设数据会遵循某种周期性的变化模式。以下是对…

智能家居的“眼睛”:计算机视觉如何让家更智能

引言 在不远的未来,当我们走进家门,灯光自动亮起,空调已经调至最舒适的温度,甚至音乐也播放着我们最喜欢的歌曲。 这一切,都得益于智能家居系统的发展。而在这个系统中,计算机视觉技术扮演着至关重要的角色…

SpringBoot车辆管理系统:构建与优化

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示: 图4-1系统工作原理…

群晖通过 Docker 安装 MySQL

1. 打开 Docker 应用,并在注册表搜索 MySQL 2. 下载 MySQL 镜像,并选择版本 3. 在 Docker 文件夹中创建 MySQL,并创建子文件夹 4. 设置权限 5. 选择 MySQL 映像运行,创建容器 6. 配置 MySQL 容器 6.1 使用高权限执行容器 6.2 启…

scrapy 爬虫学习之【中医药材】爬虫

本项目纯学习使用。 1 scrapy 代码 爬取逻辑非常简单,根据url来处理翻页,然后获取到详情页面的链接,再去爬取详情页面的内容即可,最终数据落地到excel中。 经测试,总计获取 11299条中医药材数据。 import pandas as…

idea 2023 配置 web service

前言 能在网上查到的资料,都是比较老的,搞了一上午才配置好了环境 因此记录一下,服务你我他 我的环境: java 1.8,Idea2023.1 配置web service 服务端 直接新建一个java新项目 下载插件 添加框架支持 启动项目 配置web service 客户端 新建项目,下载三个插件的步骤和上面服务…

JMeter之mqtt-jmeter 插件介绍

前言 mqtt-jmeter插件是JMeter中的一个第三方插件,用于支持MQTT(Message Queuing Telemetry Transport)协议的性能测试。MQTT是一种轻量级的发布/订阅消息传输协议,广泛应用于物联网和传感器网络中。 一、安装插件 mqtt-jmeter项目…

【Hive】6-Hive函数、运算符使用

Hive函数、运算符使用 Hive内置运算符 概述 整体上,Hive支持的运算符可以分为三大类:关系运算、算术运算、逻辑运算。 官方参考文档:https://cwiki.apache.org/confluence/display/Hive/LanguageManualUDF 也可以使用下述方式查看运算符的…

2024年AI 制作PPT新宠儿,3款神器集锦,让你的演示与众不同

咱们今儿聊聊最近超火的AI做PPT的工具。这年头,谁不想省事儿,少熬夜加班,多享受享受生活啊?所以,AI开始帮咱们搞定做PPT这种费时的活儿,我自然得好好研究研究。今天,我就给大家详细说说三款很火…

Linux下的进程解析(level 2)

目录 引言 pid解析 /proc 系统调用 fork :创建子进程 执行流分析 父子进程谁先运行 引言 在当今的信息技术时代,操作系统作为计算机系统的核心组件,承担着资源管理、任务调度等重要职责。Linux作为一种开源、高性能的操作系统&#xf…

第11篇:网络安全协议

目录 引言 11.1 安全套接字层(SSL)和传输层安全(TLS)协议 11.1.1 SSL/TLS 的工作原理 11.1.2 SSL/TLS 的应用场景 11.2 虚拟专用网(VPN)和 IP 安全协议(IPSec) 11.2.1 VPN 的工…

《深度学习》OpenCV EigenFaces算法 人脸识别

目录 一、EigenFaces算法 1、什么是EigenFaces算法 2、原理 3、实现步骤 1)数据预处理 2)特征提取 3)构建模型 4)识别 4、优缺点 1)优点 2)缺点 二、案例实现 1、完整代码 运行结果&#xff…

9.存储过程安全性博客大纲(9/10)

存储过程安全性博客大纲 引言 在数据库系统中,存储过程是一种预先编写好的SQL代码集合,它被保存在数据库服务器上,可以通过指定的名称来调用执行。存储过程可以包含一系列的控制流语句,如IF条件语句、WHILE循环等,使…