JavaWeb_SpringCloud微服务_Day3-Docker

初始Docker

介绍

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

  • 可以将程序及其依赖, 运行环境一起打包为一个镜像, 可以迁移到任意Linux操作系统
  • 运行时利用沙箱机制形成隔离容器, 各个应用互不干扰
  • 启动, 移除都可以通过一行命令完成, 方便快捷

Docker和虚拟机的差异

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

Docker架构

  • 镜像: 将应用程序及其依赖, 环境, 配置打包在一起
  • 容器: 镜像运行起来就是容器, 一个镜像可以运行多个容器
  • Docker架构:
    • 服务端: 接收命令或远程请求, 操作镜像或容器
    • 客户端: 发送命令或者请求到Docker服务端
  • DockerHub: 一个镜像托管的服务器, 类似的还有阿里云镜像服务, 统称为DockerRegistry

安装Docker

  1. 卸载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. 虚拟机联网,安装yum工具
    yum install -y yum-utils \
            device-mapper-persistent-data \
            lvm2 --skip-broken
    
  3. 更新本地镜像源:
    # 设置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
    
  4. 安装Docker:
    yum install -y docker-ce
    
    docker-ce为社区免费版本。
    -y是统统yes
  5. 启动Docker
    Docker应用需要用到各种端口, 逐一修改很麻烦, 直接关闭防火墙.
    # 关闭
    systemctl stop firewalld
    # 禁止开机启动防火墙
    systemctl disable firewalld
    
    通过命令启动docker:
    systemctl start docker  # 启动docker服务
    
    systemctl stop docker  # 停止docker服务
    
    systemctl restart docker  # 重启docker服务
    
    然后输入命令,可以查看docker版本:
    docker -v
    
  6. 配置镜像加速
    参考阿里云的镜像加速文档:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

Docker的基本操作

镜像操作

// 查看帮助文档
docker --help
// 列出镜像文件
docker images
// 删除镜像文件
docker rmi
// 拉取镜像文件
docker pull
// 推送镜像文件
docker push
// 保存镜像文件
docker save
// 加载镜像文件
docker load

容器操作

创建一个Nginx容器

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

  • docker run: 创建并允许一个容器
  • --name: 指定容器名称
  • -p: 指定端口映射
  • -d: 让容器后台允许

查看容器日志: docker logs
查看容器状态: docker ps

操作Nginx容器

docker exec -it mynginx bash

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

修改index内容:

# 进入nginx的html所在目录(通过官方文档查看)
cd /usr/share/nginx/html
# 修改内容
sed -i 's#Welcome to nginx#传智教育欢迎您#g' index.html
sed -i 's#<head>#<head><meta charset="utf-8">#g' index.html

查看容器状态:

  • docker ps
  • 添加-a参数查看所有状态的容器
    删除容器:
  • docker rm
  • 不能删除运行中的容器, 除非添加-f参数
    进入容器:
  • docker exec -it [容器名] [要执行的命令]
  • exec可以进入容器修改文件, 但是在容器内修改文件是不推荐的

数据卷(容器数据管理)

  • 介绍: 数据卷是一个虚拟目录, 指向宿主机文件系统中的某个目录
  • 作用: 将数据与容器分离, 解耦合, 方便存在容器内数据, 保证数据安全
    docker volume [command]
    
    // 创建一个volume
    create
    // 显示一个或多个volume的信息
    inspect
    // 列出所有的volume
    ls
    // 删除未使用的volume
    prune
    // 删除一个或多个指定的volume
    rm
    
  • nginx挂载, 通过数据卷挂载
    # 如果数据卷不存在, 会自动创建
    docker run --name nginx -p 80:80 -v html:/usr/share/nginx/html -d nginx
    
  • mysql挂载, 直接挂载在宿主机目录
    docker run \
    --name mysql \
    -e MYSQL_ROOT_PASSWORD=root \
    -p 3307:3306 \
    -v /tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf \
    -v /tmp/mysql/data:/var/lib/mysql \
    -d \
    mysql:5.7.25
    

Dockerfile自定义镜像

镜像结构

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

Dockerfile

  • 介绍: Dockerfile就是一个文本文件, 其中包含一个个的指令, 用指令来说明要执行什么操作来构建镜像. 每个指令都会形成一层Layer.
指令说明实例
from指定基础镜像from centos:7
env设置环境变量, 可在后面指令使用env key value
copy拷贝本地文件到镜像的指定目录copy ./mysql-5.7.rpm /tmp
run执行Linux的shell命令, 一般是安装过程的命令run yum install gcc
expose指定容器运行时监听的端口, 是给镜像使用者看的expose 8080
entrypoint镜像中应用的启动命令, 容器运行时调用entrypoint java -jar xx.jar
  • dockerfile-ubuntu
    # 指定基础镜像
    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
    
  • dockerfile-java8
    # 基于jdk8
    # 指定基础镜像
    FROM java:8-alpine
    
    COPY ./docker-demo.jar /tmp/app.jar
    # 暴露端口
    EXPOSE 8090
    # 入口,java项目的启动命令
    ENTRYPOINT java -jar /tmp/app.jar
    

Docker-Compose

下载安装

  • 下载
    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
    
  • Base自动补全命令
    # 补全命令
    curl -L https://raw.githubusercontent.com/docker/compose/1.29.1/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose
    
    // 如果这里出现错误,需要修改自己的hosts文件
    echo "199.232.68.133 raw.githubusercontent.com" >> /etc/hosts
    

快速入门

version: "3.2"

services:
  nacos:
    image: nacos/nacos-server:1.2.0
    environment:
      MODE: standalone
    ports:
      - "8848:8848"
  mysql:
    image: mysql:5.7.25
    environment:
      MYSQL_ROOT_PASSWORD: 123
    volumes:
      - "$PWD/mysql/data:/var/lib/mysql"
      - "$PWD/mysql/conf:/etc/mysql/conf.d/"
  userservice:
    build: ./user-service
  orderservice:
    build: ./order-service
  gateway:
    build: ./gateway
    ports:
      - "10010:10010"
  • 开启: docker-compose up
  • 关闭: docker-compose down
  • docker-compose可以使用服务名来代替地址
  • 标签<fileName><fileName>可以用来指定jar的名称

Docker镜像仓库

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

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

简化版镜像仓库

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 可以查看当前私有镜像服务中包含的镜像

带有图形化界面版本

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

version: '3.0'
services:
  registry:
    image: registry
    volumes:
      - ./registry-data:/var/lib/registry
  ui:
    image: joxit/docker-registry-ui:static
    ports:
      - 8080:80
    environment:
      - REGISTRY_TITLE=传智教育私有仓库
      - REGISTRY_URL=http://registry:5000
    depends_on:
      - registry

配置Docker信任地址

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

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

来源

黑马程序员. SpringCloud微服务

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套针对Java开发微服务框架,该框架提供了一系列功能和组件,用于帮助开发者更轻松地构建和管理微服务架构。 该框架的源码是指该框架的具体实现代码,通过阅读源码,开发者可以深入了解框架的设计思想和实现细节,有助于更好地理解和使用该框架。 javaweb_cloud_elevue_pro微服务框架旗舰版源码的特点主要包括以下几点: 1. 模块化设计:源码采用模块化设计,将整个框架拆分成多个独立的模块,每个模块负责不同的功能,有利于代码的组织和维护。 2. 弹性扩展:框架采用了微服务架构,可以很方便地进行系统扩展,支持动态添加和移除服务实例,以适应不同的业务需求。 3. 高可用性:框架提供了集群和负载均衡的支持,可以提高系统的可用性和性能。 4. 分布式事务管理:源码包含了分布式事务管理的实现,可以保证系统在多节点环境下的数据一致性。 5. 可靠消息传递:框架提供了消息队列和分布式任务调度的功能,可以确保消息的可靠传递和任务的可靠执行。 6. 监控和管理:框架提供了丰富的监控和管理功能,可以对系统进行实时监控和管理,方便开发者进行故障排查和性能调优。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套成熟的微服务框架实现代码,通过研究源码,开发者可以更好地理解和使用该框架,提高开发效率和系统稳定性。 ### 回答2: javaweb_cloud_elevue_pro微服务框架是一款功能强大的微服务开发框架,是javaweb_cloud_elevue_pro产品家族中的旗舰版。 该框架的源码提供了一套完整的微服务解决方案,包含了丰富的功能模块和技术组件,可用于构建高性能、稳定可靠的分布式系统。 源码中包含了一系列核心组件,如服务注册与发现、负载均衡、熔断降级、分布式配置中心等,这些组件可以快速搭建起一个具有高可用性和可伸缩性的微服务架构。 此外,框架的源码还提供了一套易用的开发工具和开发规范,使开发者能够快速上手并高效地开发微服务应用。开发者可以根据自己的业务需求,选择合适的组件和模块进行使用,从而实现个性化的定制和扩展。 与其他微服务框架相比,javaweb_cloud_elevue_pro微服务框架的源码具有以下特点: 1. 高性能:框架使用了一系列优化的算法和技术,能够实现高效的请求处理和资源利用,保证系统的稳定和可靠。 2. 可扩展:源码提供了丰富的扩展接口和插件机制,开发者可以根据自己的需求进行个性化的扩展和定制。 3. 易用性:框架的源码结构清晰,文档详细,附带了示例和教程,使开发者能够快速理解和掌握框架的使用方法。 4. 社区支持:javaweb_cloud_elevue_pro框架拥有一个活跃的社区,开发者可以在社区中获取帮助、交流经验,并参与框架的改进和贡献。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码提供了一个完整的微服务解决方案和一套易用的开发工具,可帮助开发者快速构建高性能、稳定可靠的分布式系统。它是微服务领域中的佼佼者,值得开发者深入研究和使用。 ### 回答3: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套用于构建微服务架构的开源代码。该框架旨在提供一种简单、高效的方式来搭建和管理分布式系统。 该框架基于Java语言,采用了云计算、分布式计算和微服务架构的设计理念,提供了一套完整的解决方案来构建和管理分布式应用。 该框架具有以下特点: 1. 架构灵活:框架提供了一套灵活的架构设计,可以根据业务需求进行扩展和定制。 2. 模块化设计:框架采用模块化设计,各个微服务模块之间可以独立部署和调用,实现了高内聚、低耦合的分布式系统。 3. 高可用性:框架支持负载均衡、容错和故障恢复等机制,保证了系统的高可用性和容错性。 4. 弹性扩展:框架支持水平扩展,可以根据需求动态增加或减少服务实例,实现了系统的弹性扩展和负载均衡。 5. 服务治理:框架提供了服务注册与发现、负载均衡、熔断器等功能,实现了对微服务的有效治理和管理。 6. 高性能:框架采用了高性能、高并发的设计和优化策略,提升了系统的性能和扩展能力。 总体而言,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套功能强大、灵活可扩展的微服务架构代码,可帮助开发人员快速构建和管理分布式系统。无论是在企业级应用程序还是在云计算环境中,该框架都能提供优秀的支持,并具有较高的性能和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Y_cen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值