【微服务】Docker

一、Docker基础

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

2、如何解决开发、测试、生产环境有差异的问题:Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行。

3、docker是一个快速交付应用、运行应用的技术;启动、移除都可以通过一行命令完成,方便快捷。

4、docker和虚拟机的区别:

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

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
5、docker架构

①镜像:Docker将应用程序及其所需的依赖、函数库、环境、配置等文件打包在一起,称为镜像。
②容器:镜像中的应用程序运行后形成的进程就是容器,只是Docker会给容器做隔离,对外不可见。
③DockerHub: DockerHub是一个Docker镜像的托管平台。这样的平台称为Docker Registry,
④docker架构(CS)
在这里插入图片描述

二、安装docker

企业部署一般都是采用Linux操作系统,而其中又数CentOS发行版占比最多,因此我们在CentOS下安装Docket。安装docker的条件,Centos7,至少3.10及以上的版本。

1、卸载docker
以防之前安装过docker导致版本混乱,首先在客户端尝试卸载docker

yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-selinux \
                  docker-engine-selinux \
                  docker-engine \
                  docker-ce

在这里插入图片描述

2、安装docker
安装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-ce为社区免费版本。稍等片刻,docker即可安装成功。

3、启动docker

Docker应用需要用到各种端口,逐一去修改防火墙设置。非常麻烦,因此建议大家直接关闭防火墙!

启动docker前,一定要关闭防火墙后!!

启动docker前,一定要关闭防火墙后!!

启动docker前,一定要关闭防火墙后!!

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

通过命令启动docker:

systemctl start docker  # 启动docker服务

systemctl stop docker  # 停止docker服务

systemctl restart docker  # 重启docker服务

然后输入命令,可以查看docker版本:

docker -v

4、配置镜像:docker官方镜像仓库网速较差,我们需要设置国内镜像服务:

参考阿里云的镜像加速文档:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://koxqhw57.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

三、Docker基本操作

在这里插入图片描述
如何记住Docker命令:docker --help
在这里插入图片描述

四、容器相关操作

在这里插入图片描述

eg:创建一个nginx容器

docker run --name containerName -p 80:80 -d nginx
//docker run :创建并运行一个容器
//--name:给容器起一个名字,比如叫做mn
//-p︰将宿主机端口与容器端口映射,冒号左侧是宿主机端口,右侧是容器端口
//-d:后台运行容器
//nginx:镜像名称,例如nginx

在这里插入图片描述
在浏览器访问主机号:80,如下情况部署成功:
在这里插入图片描述
通过docker logs mn查看日志:
在这里插入图片描述
eg:进入Nginx容器,修改HTML文件内容

docker exec -it mn bash
//docker exec:进入容器内部,执行一个命令
//-it:给当前进入的容器创建一个标准输入、输出终端,允许我们与容器交互
//mn:要进入的容器的名称
//bash:进入容器后执行的命令,bash是一个linux终端交互命令

五、数据卷

将容器与数据分离,解耦合,方便操作容器内数据,保证数据安全.
数据卷操作基本语法如下:

docker volume [COMMAND]
//docker volume命令是数据卷操作,根据命令后跟随的command来确定下一步的操作:
//create 创建一个volume
//inspect 显示一个或多个volume的信息
//ls 列出所有的volume删除未使用的volume
//prune 删除一个或多个指定的volume
//rm 删除一个或者多个指定的volume

六、Dockerfile自定义镜像

1、镜像结构
在这里插入图片描述
2、Dockerfile是一个文本文件,其中包含一个个的指令,用指令俩说明执行什么操作来构建镜像,每一个指令都会形成一个layer
在这里插入图片描述

若依微服务架构采用Docker部署Nacos,可以显著简化配置管理和提高环境一致性。下面将详细介绍如何进行这一过程。 ### 步骤一:准备前提条件 首先你需要准备好一些基础工具和服务: - 安装 DockerDocker Compose 环境; - 获取最新的 若依框架 微服务版本以及 Nacos 配置文件等资源; ### 步骤二:拉取镜像并启动 Nacos 你可以通过官方提供的 `docker-compose.yml` 文件快速开始,也可以手动操作命令行来完成这一步骤: ```bash # 使用阿里云官方镜像源加速下载 nacos 的 docker image,并命名为最新版 docker pull registry.cn-hangzhou.aliyuncs.com/nacos/nacos-server:latest # 启动单机模式下的 nacos (适用于测试) docker run --name=nacos -e MODE=standalone -p 8848:8848 -d registry.cn-hangzhou.aliyuncs.com/nacos/nacos-server ``` 对于生产环境,则建议按照集群方式搭建以保证高可用性和容错能力。 ### 步骤三:修改应用配置指向远程注册中心 接下来调整若依项目的 Spring Cloud 或者 Spring Boot 应用程序属性文件(application.properties 或 application.yml),使得它们能够连接到刚安装好的 Nacos 实例作为服务发现组件及配置管理器: #### 示例application.yml片段: ```yaml spring: cloud: nacos: discovery: server-addr: localhost:8848 # 修改为你实际部署了 nacos 的主机地址和端口组合 config: server-addr: localhost:8848 ``` 记得替换其中的server-addr为真实的服务器IP和开放的服务监听端口号! ### 步骤四:构建与推送自定义镜像至仓库(可选) 如果你希望更方便地迁移项目或将此设置应用于其他机器上,考虑创建包含所有依赖项的应用容器化方案会是一个不错的选择。利用 Dockerfile 构建应用程序特定的操作系统映像之后上传到私有或公共存储库如 Docker Hub 中去供后续引用。 以上就是关于“若依微服务docker部署nacos”的基本步骤介绍啦!如果有不清楚的地方欢迎继续提问~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值