Java分布式微服务3——Docker

文章目录

  • Docker介绍
  • 安装Docker
  • Docker基础操作
    • Docker服务的启动
    • 镜像命令
    • 容器命令
      • 1. 从docker hub去查看Nginx容器的运行命令
      • 2. 查看所有容器状态
      • 3. 查看容器日志
      • 4. 进入Nginx容器执行命令,修改Html内容,添加“Hello World”
      • 5. 停止与开始容器
      • 6. 删除容器
    • 数据卷
      • 1. 为什么需要数据卷
      • 2. 数据卷的操作
      • 3. 数据卷的挂载
      • 4. 目录与文件挂载
  • Dockerfile自定义镜像
  • DockerCompose集群部署
  • 镜像仓库
    • 1.简化版镜像仓库
    • 2.带有图形化界面版本
    • 3.配置Docker信任地址

Docker介绍

大项目组件多,运行环境复杂

  • 每个组件需要的依赖和函数库可能版本不同,容易不兼容
  • 开发、测试、生产环境有差异,甚至操作系统都不一样

在这里插入图片描述
Docker可以在任何Linux机器上一键部署,一键移除

Docker与虚拟机区别
在这里插入图片描述

  • Docker直接用打包的系统函数库调用OS内核,性能较好,硬盘占用小,启动快
  • 虚拟机需要用函数库调用模拟的OS,指令经过Hypevisor转换后调用真正OS的内核,性能一般,硬盘占用大,启动慢

在这里插入图片描述
DockerRegistry: 镜像托管服务器,DockerHub、阿里云镜像

安装Docker

Docker安装和配置

Docker基础操作

Docker服务的启动

systemctl enable docker # 开机自启
service start docker

在命令后加上--help就能打开帮助文档

镜像命令

在这里插入图片描述
官方镜像拉取参考DockerHub网站
下面我们要:

  1. 拉取一个nginx镜像
  2. 查看镜像
  3. 将其保存成tar
  4. 删除dokcer中的nginx镜像
  5. 从tar中加载这个镜像
  6. 对这个镜像打标签说明这是我们开发的第一个版本
docker pull nginx[:tag] # 拉取镜像,不指定版本就自动拉取最新版,tag为latest
docker images # 查看镜像
docker save -o nginx.tar nginx:latest # 保存镜像到tar压缩文件,-o是output,后面跟要保存到的文件名
docker rmi nginx:latest# 删除镜像
docker load -i nginx.tar# 加载刚刚保存的镜像,-i是input,后面跟镜像压缩包文件名
docker tag nginx:latest mynginx:1.0 # 给一个镜像打标签为mynginx:1.0

容器命令

在这里插入图片描述
下面我们要:

1. 从docker hub去查看Nginx容器的运行命令

容器一开始是完全隔离的,端口映射就是暴露一个接口(可以理解成和宿主机之间接了条通道,只有宿主机能把请求给它)
容器端口一般取决于应用本身很少变化,宿主机端口可以任意指定可用的
具体怎么启动建议在DockerHub中搜索

docker run --name mynginx -p 80:80 -d nginx

在这里插入图片描述

2. 查看所有容器状态

默认只能查看到未被停止的,加-a能看到所有

docker ps

在这里插入图片描述

3. 查看容器日志

docker logs mynginx # 查看日志
docker logs -f mynginx # 持续跟踪显示日志,-f=follow

4. 进入Nginx容器执行命令,修改Html内容,添加“Hello World”

实际工作中不建议在容器内修改文件

  • docker exec: 进入容器内部,执行一个命令
  • -it = interaction terminal 给当前进入的容易创建一个标准输入输出终端
  • bash是这里进入容器后要执行的命令,它本身是一个指令处理器
docker exec -it mynginx bash

docker容器里有一套自己的简易文件系统
找到nginx的html页面并打开查看

cd /usr/share/nginx/html/
cat index.html

修改html内容

sed -i 's#Welcome to nginx#Hello World#g' index.html
sed -i 's#<head>#<head><meta charset="utf-8>#g' index.html

5. 停止与开始容器

docker stop mynginx
docker start mynginx

6. 删除容器

docker rm mynginx # 要先停止容器
docker rm -f mynginx # 强制删除

数据卷

1. 为什么需要数据卷

在这里插入图片描述
怎么修改容器中的文件呢?

  • 使用一个虚拟目录交给容器使用,实际上对应的是宿主机的一个真实目录。
  • 如果多个虚拟目录挂载在同一个真实目录上,还能完成文件共享
  • 就算容器被删了,文件还是在宿主机文件夹里
    在这里插入图片描述

2. 数据卷的操作

  1. 创建数据卷
docker volume create myvolume
  1. 列出所有数据卷
docker volume ls
  1. 查看数据卷详细信息
docker volume inspect myvolume

在这里插入图片描述

  1. 删除未使用的数据卷
docker volume prune
  1. 删除指定数据卷
docker volume rm myvolume

3. 数据卷的挂载

创建容器的时候通过-v参数将一个数据卷挂载到某个容器目录,如果没有这个数据卷会自动创建一个

docker run\--name mn\-v myvolume:/usr/share/nginx/html\ # 把myvolume数据卷挂载到容器内的/usr/share/nginx/html这个目录上-p 80:80\nginx

4. 目录与文件挂载

也可以直接把宿主机目录挂载到某个容器目录

在这里插入图片描述
挂载文件会直接覆盖容器内的文件

Dockerfile自定义镜像

分层方便迭代,只用改上面几层
在这里插入图片描述
在这里插入图片描述

DockerCompose集群部署

可以基于Compose文件快速部署分布式应用,无需手动逐个创建和运行容器
Compose文件是个文本文件夹,通过指令定义集群中每个容器如何运行,内容约等于多个docker run的集合
详情参考官网DockerCompose文档
在这里插入图片描述

安装dockerCompose

使用DockerCompose部署微服务
最好先自己部署好Nacos再一键部署其他微服务,否则找不到地方注册

镜像仓库

仓库也可以自己建私有仓库
搭建镜像仓库可以基于Docker官方提供的DockerRegistry来实现。

官网地址:https://hub.docker.com/_/registry

1.简化版镜像仓库

Docker官方的Docker Registry是一个基础版本的Docker镜像仓库,具备仓库管理的完整功能,但是没有图形化界面。

搭建方式比较简单,命令如下:

docker run -d \--restart=always \--name registry	\-p 5000:5000 \-v registry-data:/var/lib/registry \registry

命令中挂载了一个数据卷registry-data到容器内的/var/lib/registry 目录,这是私有镜像库存放数据的目录。

访问http://YourIp:5000/v2/_catalog 可以查看当前私有镜像服务中包含的镜像

2.带有图形化界面版本

使用DockerCompose部署带有图象界面的DockerRegistry,命令如下:

version: '3.0'
services:registry:image: registryvolumes:- ./registry-data:/var/lib/registryui:image: joxit/docker-registry-ui:staticports:- 8080:80environment:- REGISTRY_TITLE=私有仓库- REGISTRY_URL=http://registry:5000depends_on:- registry

3.配置Docker信任地址

我们的私服采用的是http协议,默认不被Docker信任,所以需要做一个配置:

# 打开要修改的文件
vi /etc/docker/daemon.json
# 添加内容:
"insecure-registries":["http://192.168.150.101:8080"]
# 重加载
systemctl daemon-reload
# 重启docker
systemctl restart docker

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

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

相关文章

synchronized原理

synchronized synchronized的用法参考Java中使用同步关键字synchronized需要注意的问题 - 小浩 - 博客园 synchronized是非公平锁 synchronized实现原理 16_深入JVM源码-monitor竞争_哔哩哔哩_bilibili 9 synchronized与锁 深入浅出Java多线程 (redspider.group) Java中…

springboot()—— swagger

零、一张图读懂swagger 懂了&#xff0c;这玩意就是用swagger搞出来的&#xff01; 就是一个后端开发自测的东西嘛&#xff01; 一、概念 存在即合理&#xff0c;我们看一下swagger诞生的原因&#xff1a;在前后端分离的架构中&#xff0c;前端新增一个字段&#xff0c;后端就…

【PDF密码】PDF文件不能打印,为什么?

正常的PDF文件是可以打印的&#xff0c;如果PDF文件打开之后发现文件不能打印&#xff0c;我们需要先查看一下自己的打印机是否能够正常运行&#xff0c;如果打印机是正常的&#xff0c;我们再查看一下&#xff0c;文件中的打印功能按钮是否是灰色的状态。 如果PDF中的大多数功…

Python-OpenCV 图像的基础操作

图像的基础操作 获取图像的像素值并修改获取图像的属性信息图像的ROI区域图像通道的拆分及合并图像扩边填充图像上的算术运算图像的加法图像的混合图像的位运算 获取图像的像素值并修改 首先读入一副图像&#xff1a; import numpy as np import cv2# 1.获取并修改像素值 # 读…

安全狗V3.512048版本绕过

安全狗安装 安全狗详细安装、遇见无此服务器解决、在windows中命令提示符中进入查看指定文件夹手动启动Apache_安全狗只支持 glibc_2.14 但是服务器是2.17_黑色地带(崛起)的博客-CSDN博客 安全狗 safedogwzApacheV3.5.exe 右键电脑右下角安全狗图标-->选择插件-->安装…

在win10上安装Docker desktop,并在docker中安装mysql

操作步骤: 安装docker 去 官网 下载安装软件;选择windows 2. 依次点击安装; 安装完成后无需登录,直接启动即可; 如果有提示需要更新wsl,执行以下命令更新: wsl --update wsl --status 查看状态 验证一下 适用命令:docker run hello-world 设置国内镜像 docker安装mysql…

不懂录音转文字转换器如何使用?来掌握这几个方法吧

作为一名忙碌的职场人士&#xff0c;我每天都要参加各种会议。我发现自己经常会错过会议的一些重要信息&#xff0c;利用录音记录又要费时间去听再转录&#xff0c;实在令我很头疼。直到我开始使用录音转文字这个工具&#xff0c;它简直像魔法一样。只要将需要转换的音频上传就…

建议收藏!独立站新手容易踩的5个坑,你中了吗?

接过很多独立站商户咨询&#xff0c;发现大家很容易踩几个坑&#xff0c;也是大家问的比较多的。 今天把印象最深的5个坑分享给大家&#xff0c;希望大家可以少踩坑&#xff0c;并且结合建议对以下几个方面进行优化&#xff0c;至少能保证你的独立站做到及格线上线&#xff01…

进程与线程、线程创建、线程周期、多线程安全和线程池(ThreadPoolExecutor)

目录 进程与线程线程和进程的区别是什么&#xff1f;线程分两种&#xff1a;用户线程和守护线程线程创建四种方式run()和start()方法区别&#xff1a;为什么调用 start() 方法时会执行 run() 方法&#xff0c;为什么不能直接调用 run() 方法&#xff1f;Runnable接口和Callable…

【Android】在AndroidStudio开发工具运行Java程序

在Android Studio开发工具中&#xff0c;Android系统开始就是用java语言开发的&#xff0c;还可以java代码来写程序&#xff0c;控制台&#xff0c;桌面应用&#xff0c;还可以写可调用的模块&#xff0c;这里讲一下创建Java程序步骤&#xff0c;方便入门java语言开发。 新建一…

初识网络(JavaEE初阶系列9)

目录 前言&#xff1a; 1.网络的发展史 1.1独立模式 1.2网络互联 1.3局域网LAN 1.4广域网WAN 2.网络通信基础 2.1IP地址 2.2端口号 3.认识协议 3.1协议分层 3.2分层的作用 3.3TCP/IP五层&#xff08;或四层&#xff09;模型 3.4OSI七层模型 3.5网络设备所在分层 …

快速排序和qsort函数详解详解qsort函数

&#x1f495;是非成败转头空&#xff0c;青山依旧在&#xff0c;几度夕阳红&#x1f495; 作者&#xff1a;Mylvzi 文章主要内容&#xff1a;快速排序和qsort函数详解 前言&#xff1a; 我们之前学习过冒泡排序&#xff0c;冒泡排序尽管很方便&#xff0c;但也存在一些局限性…