Dcoker学习笔记(一)

news2024/12/30 3:12:04

Dcoker学习笔记一

  • 一、 初识Docker
    • 1.1 简介
    • 1.2 虚拟机和docker的区别
    • 1.3 Docker架构
    • 1.4 安装Docker(Linux)
  • 二、 Dcoker基本操作
    • 2.1 镜像操作
    • 2.2 容器操作
      • 练习
    • 2.3 数据卷volume(容器数据管理)
      • 简介
      • 数据卷语法
      • 数据卷挂载
    • 2.4 自定义镜像
      • 2.4.1 镜像结构
      • 2.4.2 Dockerfile
    • 2.4 DockerCompose编排
      • 简介
    • 待续未完

一、 初识Docker

1.1 简介

Docker是一个快速交付应用,运行应用的技术:

Docker可以解决大型项目依赖关系复杂,不同组件依赖的兼容性问题

  • docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植的镜像
  • docker应用运行在容器中,使用沙箱机制,相互隔离

Docker如何解决开发、测试、生产环境有差异的问题

  • docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行

在这里插入图片描述

1.2 虚拟机和docker的区别

在这里插入图片描述

docker和虚拟机的差异:

  • docker是一个系统进程;虚拟机是在操作系统中的操作系统
  • docker体积小、启动速度快、性能好、虚拟机体积大、启动速度慢、性能一般

1.3 Docker架构

Docker架构主要有两个内容:镜像容器

镜像(Image):docker进应用程序及其所需依赖、函数库、环境、配置等文件打包在一起,称为镜像。

容器(Container):镜像中的应用程序运行后形成的进程就是容器,只是docker会给容器做隔离,对外不可见

怎么进行镜像共享?可以通过Docker Rrgistry进行镜像共享

DockerHub:docker镜像托管平台。这样的平台称为Docker Rrgistry

在这里插入图片描述

1.4 安装Docker(Linux)

首先需要大家虚拟机联网,安装yum工具

输入如下命令

yum install -y yum-utils \
           device-mapper-persistent-data \
           lvm2 --skip-broken

然后更新本地镜像源:

# 设置docker镜像源
yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    
sed -i 's/download.docker.com/mirrors.aliyun.com\/docker-ce/g' /etc/yum.repos.d/docker-ce.repo

yum makecache fast

然后输入命令进行安装:

yum install -y docker-ce

等待安装完成输入

docker-v

出现插图这表明安装成功

在这里插入图片描述

启动docker先关闭防火墙

# 关闭
systemctl stop firewalld
# 禁止开机启动防火墙
systemctl disable firewalld

启动、停止、重启docker命令

systemctl start docker  # 启动docker服务

systemctl stop docker  # 停止docker服务

systemctl restart docker  # 重启docker服务

二、 Dcoker基本操作

2.1 镜像操作

镜像名称规范:

镜像名称一般分成两部分组成:【repository】:【tag】在这里插入图片描述

操作命令
在这里插入图片描述

案例1:从dockerHub中拉取一个Nginx进行并查看

1.首先去镜像仓库搜索Nginx镜像,比如
DockerHub

2.复制命令

 docker pull nginx #默认拉取最新版本  

在这里插入图片描述

在这里插入图片描述

拉取完成后查看镜像版本

docker images

在这里插入图片描述

案例2:利用docker save将nginx镜像导出磁盘,然后再通过load加载回来

步骤一:利用docker xx --help命令查看docker save,将其打包

在这里插入图片描述
从上面我们可以看到,假如把nginx镜像打包成一个压缩文件的命令为:
docker save -o nginx.tar nginx:latest

接下来我们查看是否打包成功
在这里插入图片描述

可以看到已经成功了,
接下来我们把原来的镜像给删除掉:
docker rmi nginx:latest

在这里插入图片描述
然后我们进行load --help命令查看load 操作命令,并加载出来

在这里插入图片描述

可以看出命令为:

docker load -i nginx.tar

接下来查看是否加载完成
在这里插入图片描述

可以看出已经成功被加载完成了

2.2 容器操作

操作容器的命令

在这里插入图片描述

扩展:

docker logs -f [容器名称] #持续日志输出 

案例1:创建运行一个nginx容器

步骤一:去docker hub 查看nginx的容器运行命令

在这里插入图片描述
在这里插入图片描述
命令:
在这里插入图片描述
输入docker run --name mynginx -p 80:80 -d nginx

在这里插入图片描述
从上面可以看出,我们已经让该镜像成功运行起来了

接着我们访问宿主机的IP和端口

在这里插入图片描述
访问成功!

案例2:进入nginx容器,修改HTML文件内容,添加“chushay was best!”

步骤一:进入容器。进入到刚才创建的nginx容器命令

docker exec -it mynginx bash![在这里插入图片描述](https://img-blog.csdnimg.cn/6abf8bd70a1c44769d31d099aeca1a57.png)

然后我们去dockerhub找到nginx的路径

在这里插入图片描述

步骤二:进入nginx的HTML所在目录
/usr/share/nginx/html

cd /usr/share/nginx/html

步骤三:修改index.html的内容

sed -i 's#Welcome to nginx#chushay was best!#g' index.html

sed -i 's#<head>#<head><meta charset="utf-8">#g' index.html

修改之后,我们通过浏览器验证一下
在这里插入图片描述
我们可以看到已经修改成功!

总结:
在这里插入图片描述

练习

创建并运行一个Redis容器,并支持数据持久化

步骤一:到DdockerHub搜索Redis镜像
在这里插入图片描述

步骤二:查看Redis镜像文档中的帮助信息

拉取镜像:
docker pull redis

步骤三:利用docker run ,命令运行一个Redis容器

在这里插入图片描述

#docker run --name some-redis -d redis redis-server --appendonly yes
docker run --name myredis -p 6379:6379 -d redis redis-server --appendonly yes

在这里插入图片描述
从上图中我们可以看出Redis镜像已经启动称为容器,接下来我们通过Redis连接工具来测试一下

在这里插入图片描述

我们可以看到,连接成功!

接下来,进入容器
docker exec -it myredis bash

进入Redis客户端
redis-cli

注 :可以直接进入到redis-cli: docker exec -it myredis redis-cli

添加一个key

set num 666

接下来我们查看Redis,被成功的添加了
在这里插入图片描述

2.3 数据卷volume(容器数据管理)

在这里插入图片描述

简介

在这里插入图片描述

数据卷语法

在这里插入图片描述

实践小操:

1.创建一个名为html的数据卷:

docker volume create html
在这里插入图片描述

2.查看创建的数据卷:
docker volume ls
在这里插入图片描述
3.查看创建的数据卷路径:
docker volume inspect html
在这里插入图片描述

4.删除数据卷

删除未使用的卷
docker volume prune

删除指定的卷
docker volume rm [卷名]

总结
在这里插入图片描述

数据卷挂载

在这里插入图片描述

案例1:
创建一个nginx容器,修改容器内的html目录内的index.html内容

在这里插入图片描述

创建容器并挂载数据卷
docker run --name mynginx -p 80:80 -v html:/usr/share/nginx/html -d nginx

查看数据卷路径
在这里插入图片描述
进入该路径并查看数据卷
在这里插入图片描述

修改html内容:

vi index.html

总结:

在这里插入图片描述

案例2:
创建并运行一个MySQL容器,将宿主机目录直接挂载到容器

在这里插入图片描述

在这里插入图片描述

步骤一:拉取MySQL镜像

docker pull mysql

查看镜像
在这里插入图片描述
步骤二:创建目录

mkdir -p mysql/data

mkdir -p mysql/conf

步骤三:把MySQL配置文件传到mysql/conf目录下

在这里插入图片描述
步骤四:去DockerHub查阅资料,创建并运行MySQL容器:要求:

  • ①挂载/tmp/mysql/data到mysql容器内数据存储目录

  • ②挂载/tmp/mysql/conf/hmy.cnf到mysql容器配置文件

  • ③设置mysql密码

      docker run --name mysql -e MYSQL_ROOT_PASSWORD=654321 -p 3306:3306 -v /tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf -v /tmp/mysql/data:/var/lib/mysql -d mysql
    
docker run \ #启动
--name mysql \ #容器名称
-e MYSQL_ROOT_PASSWORD=654321 \  #mysql环境配置
-p 3306:3306 \                   #mysql端口配置      
-v /tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf \ #挂载/tmp/mysql/conf/hmy.cnf到mysql容器配置文件
-v /tmp/mysql/data:/var/lib/mysql \#挂载/tmp/mysql/data到mysql容器内数据存储目录
-d \                             #允许后台运行
mysql							 #镜像名称	

启动成功之后我们通过连接mysql数据库查看

在这里插入图片描述

2.4 自定义镜像

2.4.1 镜像结构

镜像概念:镜像是将应用程序及其需要的系统函数库、环境、配置、依赖打包而成的整体。

以mysql镜像为例解析镜像结构:
在这里插入图片描述

总结:

镜像是分层结构,每一层称为一个Layer

  • BaseImage层:包含基本的系统函数库、环境变量、文件系统
  • Entrypoint:入口,是镜像中应用启动的命令
  • 其他:在baseImage基础上添加依赖、安装程序、完成整个应用的安装和配置

2.4.2 Dockerfile

Dcokerfile就是一个文本文件,其中包含一个个指令,用来说明要执行什么操作来构建镜像。每一个指令都会形成一层Layer

在这里插入图片描述

更多指令语法

案例1:基于Ubuntu镜像构建一个新镜像,运行一个Java项目

步骤一:新建一个空文件夹docker-demo
步骤二:拷贝课件资料中的docker-demo.jar文件到docker-demo这个目录
步骤三:拷贝课前资料中的jdk8.tar.gz文件到docker-demo这个目录
步骤四:拷贝课前资料提供的Dockerfile到docker-demo这个目录
步骤五:进入docker-demo
步骤六:运行命令
docker build -t javaweb:1.0v .

步骤一:新建一个空文件夹docker-demo
在这里插入图片描述
步骤二:拷贝课件资料中的docker-demo.jar文件到docker-demo这个目
在这里插入图片描述

步骤三:拷贝课前资料中的jdk8.tar.gz文件到docker-demo这个目录
在这里插入图片描述
步骤四:拷贝课前资料提供的Dockerfile到docker-demo这个目录

在这里插入图片描述

dockerfile文件内容:

# 指定基础镜像
FROM ubuntu:16.04
# 配置环境变量,JDK的安装目录
ENV JAVA_DIR=/usr/local

# 拷贝jdk和java项目的包
COPY ./jdk8.tar.gz $JAVA_DIR/
COPY ./docker-demo.jar /tmp/app.jar

# 安装JDK
RUN cd $JAVA_DIR \
 && tar -xf ./jdk8.tar.gz \
 && mv ./jdk1.8.0_144 ./java8

# 配置环境变量
ENV JAVA_HOME=$JAVA_DIR/java8
ENV PATH=$PATH:$JAVA_HOME/bin

# 暴露端口
EXPOSE 8090
# 入口,java项目的启动命令
ENTRYPOINT java -jar /tmp/app.jar

步骤五:进入docker-demo

在这里插入图片描述
步骤六:运行命令
docker build -t javaweb:1.0v .

在这里插入图片描述

启动镜像:

docker run --name javaweb -p 8090:8090 -d javaweb:1.0v

在这里插入图片描述

访问成功!
在这里插入图片描述

案例2:基于Java:8-alpine镜像,将一个Java项目构建为镜像

实现思路如下:

  • ① 新建一个空的目录,然后在,目录中新建一个文件,命名为Dockerfile
  • ②拷贝课前资料提供的docker-demo.jar到这个目录中
  • ③编写Dockerfile文件:
    • a)基于Java:8-alpine作为基础镜像
    • b)将app.jar拷贝到镜像中
    • c)暴露端口
    • d)编写入口ENTRYPOINT
  • ④使用docker build命令构建镜像
  • ⑤使用docker run创建容器并运行

① 新建一个空的目录,然后在,目录中新建一个文件,命名为Dockerfile
还是使用原来的文件目录

②拷贝课前资料提供的docker-demo.jar到这个目录中
还是使用原来的文件目录

③编写Dockerfile文件

# 指定基础镜像
FROM java:8-alpine
# 配置环境变量,JDK的安装目录
ENV JAVA_DIR=/usr/local

# 拷贝java项目的包
COPY ./docker-demo.jar /tmp/app.jar

# 暴露端口
EXPOSE 8090
# 入口,java项目的启动命令
ENTRYPOINT java -jar /tmp/app.jar

④使用docker build命令构建镜像

docker build -t javaweb:2.0v .

⑤使用docker run创建容器并运行
在这里插入图片描述

docker run --name web -p 8090:8090 -d javaweb:2.0v

访问:
在这里插入图片描述

总结:
在这里插入图片描述

2.4 DockerCompose编排

简介

Docker Compose是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Compose 是 Docker
公司推出的一个工具软件,可以管理多个 Docker 容器组成一个应用。你需要定义一个 YAML
格式的配置文件docker-compose.yml,写好多个容器之间的调用关系。然后,只要一个命令,就能同时启动/关闭这些容器

注:引用CSDN博主「山河亦问安」,原文链接点击查看原文,这也是一篇关于DockerCompose不错的文章,值得推荐!


Compose文件是一个文本文件,在文件中通过定义集群中的每个容器如何运行

docker-compose格式:
在这里插入图片描述

version: "3.8"				//compose版本

service:
  mysql: 					//容器名称
  	images: mysql:5.7.25 	//镜像名称
  	environment: 			//环境名称
  	  MYSQL_ROOT_PASSWORD: 654321
  	volumes: 				//数据卷
  	  - /tmp/mysql/data:/var/lib/mysql
  	  - /tpm/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cof
  web:
  	build: .   				//从当前目录构建镜像
  	ports:     				//暴露端口
  	  - 8090: 8090  

CentOS7安装DockerCompose:

Linux下需要通过命令下载:

# 安装
curl -L https://github.com/docker/compose/releases/download/1.23.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

出现下图,表示安装成功
在这里插入图片描述

修改文件权限

# 修改权限
chmod +x /usr/local/bin/docker-compose

查看docker-compose版本

docker-compose --version

在这里插入图片描述
安装成功!

待续未完

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

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

相关文章

【Git】Git基础命令操作速记

【Git】Git基础命令操作速记 文章目录 【Git】Git基础命令操作速记1. 初始化1.1 设置用户名和邮箱1.2 初始化仓库 2. 基础命令2.1 add和commit2.2 reset2.3 查看日志2.4 删除/找回本地仓库文件2.5 找回暂存区文件2.6 diff命令(找不同) 3. 分支命令3.1 查看分支3.2 创建分支3.3 …

深度学习之基于YoloV5的火灾检测系统

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 火灾检测系统基于YoloV5的介绍 火灾检测是一项重要的安全任务&#xff0c;它旨在及时发现和报警火灾风险。基于深度…

postgresql|数据库|提升查询性能的物化视图解析

前言&#xff1a; 我们一般认为数字的世界是一个虚拟的世界&#xff0c;OK&#xff0c;但我们其实有些需求是和现实世界一模一样的&#xff0c;比如&#xff0c;数据库尤其是关系型数据库&#xff0c;希望在使用的数据库能够更快&#xff08;查询速度&#xff09;&#xff0c;…

《008.Springboot+vue之自习室选座系统》

[火]《008.Springbootvue之自习室选座系统》 项目简介 [1]本系统涉及到的技术主要如下&#xff1a; 推荐环境配置&#xff1a;DEA jdk1.8 Maven MySQL 前后端分离; 后台&#xff1a;SpringBootMybatisredis; 前台&#xff1a;vueElementUI; [2]功能模块展示&#xff1a; 前端…

云端生成式 AI – 基于 Amazon EKS 的 Stable Diffusion 图像生成方案

Stable Diffusion 是当下生成式 AI 领域最受欢迎的开源多模态语言-图像模型&#xff0c;由于其易用的接口和良好的使用体验&#xff0c;受到了开源社区和广大设计行业从业者的追捧。Stable Diffusion 模型版本正在快速迭代&#xff0c;并带动了各行各业的生产力变革。目前市场上…

vmware16.1.2安装 windows7后 VMVMware tools 灰色 需要手动安装操作详情

问题1&#xff1a; 问题描述&#xff1a; 在Windows7镜像安装完成后&#xff0c;安装"VMware Tools"时出现&#xff1a;安装程序无法继续&#xff0c;需要将操作系统更新到SP1.2 重新安装后也没办法解决。 证明问题没有出在操作系统上&#xff1b;那么&#xff0c…

RISC Zero的Bonsai证明服务

1. 引言 Bonsai为通用ZKP网络&#xff0c;其支持任意链、任意协议、以及任意应用&#xff0c;利用ZKP来扩容、隐私和互操作。Bonsai的目标是为每条链都提供无限计算的能力。 借助Bonsai&#xff0c;可仅需数天的开发&#xff0c;即可实现对以太坊、L1链、Cosmos app链、L2 ro…

Mybatis-Plus使用Wrapper自定义SQL

文章目录 准备工作Mybatis-Plus使用Wrapper自定义SQL注意事项目录结构如下所示domain层Controller层Service层ServiceImplMapper层UserMapper.xml 结果如下所示&#xff1a;单表查询条件构造器单表查询&#xff0c;Mybatis-Plus使用Wrapper自定义SQL联表查询不用&#xff0c;My…

Java进击框架:Spring-数据存取(七)

Java进击框架&#xff1a;Spring-数据存取&#xff08;七&#xff09; 前言事务管理声明式事务管理 DAO支持JDBC的数据访问使用JdbcTemplate控制数据库连接JDBC批处理操作封装 SQL 语句中的参数 使用R2DBC进行数据访问对象关系映射(ORM)数据访问HibernateJPA XML模式 前言 参考…

目标检测算法 - YOLOv1

文章目录 1. 作者简介2. 目标检测综述3. YOLOv1算法3.1 预测阶段3.2 预测阶段后处理3.3 训练阶段 YOLO的全称是you only look once&#xff0c;指只需要浏览一次就可以识别出图中的物体的类别和位置。 YOLO是目标检测模型。目标检测是计算机视觉中比较简单的任务&#xff0c;用…

10-26 maven配置

打开idea 打开setting 基于Idea创建idea项目 加载jar包&#xff1a;(一般需要自己去手动加入&#xff0c;本地仓库是没有的)

【HarmonyOS】HarmonyOS备案获取公钥和指纹

【关键字】 HarmonyOS应用、鸿蒙应用、元服务、应用备案 HarmonyOS应用在华为云等平台进行应用备案时&#xff0c;平台需要提供用公钥和签名指纹的信息&#xff0c;Android可以直接通过keystore或jks签名文件进行签名信息获取&#xff0c;HarmonyOS签名方式与Android不同&…

LangChain之关于RetrievalQA input_variables 的定义与使用

最近在使用LangChain来做一个LLMs和KBs结合的小Demo玩玩&#xff0c;也就是RAG&#xff08;Retrieval Augmented Generation&#xff09;。 这部分的内容其实在LangChain的官网已经给出了流程图。 我这里就直接偷懒了&#xff0c;准备对Webui的项目进行复刻练习&#xff0c;那么…

Spring Cloud - 手写 Gateway 源码,实现自定义局部 FilterFactory

目录 一、FilterFactory 分析 1.1、前置知识 1.2、分析源码 1.2.1、整体分析 1.2.2、源码分析 1.3、手写源码 1.3.1、基础框架 1.3.2、实现自定义局部过滤器 1.3.3、加参数的自定义局部过滤器器 一、FilterFactory 分析 1.1、前置知识 前面的学习我们知道&#xff0c…

云服务器搭建flink集群

文章目录 1.集群配置2.修改集群配置3. 访问Web UI4. 提交作业方式5.Yarn部署模式配置5.1 会话模式部署&#xff08;Session Mode&#xff09;5.2 单作业模式(Per-job Mode)5.3 应用模式部署&#xff08;推荐&#xff09;5.3.1 上传HDFS提交&#xff08;推荐&#xff09; 5.4 历…

SpringCloudAlibaba——Sentinel

Sentinel也就是我们之前的Hystrix&#xff0c;而且比Hystrix功能更加的强大。Sentinel是分布式系统的流量防卫兵&#xff0c;以流量为切入点&#xff0c;从流量控制、流量路由、熔断降级等多个维度保护服务的稳定性。 Sentinel采用的是懒加载&#xff0c;这个接口被访问一次&a…

爬取Elastic Stack采集的Nginx内容

以下是一个简单的Go语言爬虫程序&#xff0c;用于爬取Elastic Stack采集的Nginx内容。请注意&#xff0c;这只是一个基本的示例&#xff0c;实际使用时可能需要根据具体情况进行修改和扩展。 package mainimport ("fmt""net/http""io/ioutil" )…

高效接口重试机制的实现

实现一个高效的接口重试机制对于保证系统的稳定性和可靠性至关重要。在面对网络不稳定、服务端故障或者高负载的情况下&#xff0c;接口重试机制能够确保请求的成功执行&#xff0c;同时也需要保证在重试过程中不会造成额外的负担或不必要的延迟。本文将为您介绍高效接口重试机…

工业相机基本知识理解:靶面尺寸、像元尺寸、分辨率

1、靶面尺寸&#xff1a;由Sensor对角线长度表示&#xff0c;单位英寸&#xff0c;这里的1英寸16mm 2、像元尺寸&#xff1a;单个感光元件的大小&#xff0c;一般都是正方形&#xff0c;边长单位um 3、分辨率&#xff1a; Sensor长边像元数 Sensor短边像元数&#xff0c;俗称像…

220v插座led指示灯维修

由于220v是交流电&#xff0c;有反向电压的情况&#xff0c;而led反向通电的时候电阻无穷大&#xff0c;所以分压也无穷大&#xff0c;220v一导通就击穿&#xff0c;即使加了很大的电阻也没用&#xff0c;串联电阻只能作用于二极管正向的时候。 目前有两种方案&#xff1a; 方…