栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

Docker(2)

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Docker(2)

DockerFile(构建镜像) DockerFile是什么?

Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。

【把脚本命令写在这个文件里面】

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

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

# 安装JDK	1. 进入java目录 2. 解压压缩包 3. 重命名
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
# 指定基础镜像
FROM java:8-alpine    #已经存在的基础镜像,快速搭建java8镜像【包含基础系统配置,以及jdk】


COPY ./docker-demo.jar /tmp/app.jar

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

FROM :指定基础镜像        示例:FROM centos:6

ENV:设置环境变量,可在后面指令使用        ENV key value

COPY:拷贝本地文件到镜像的指定目录        COPY ./mysql-5.7.rpm /tmp

RUN:执行linux的shell命令,一般是安装过程的命令        RUN yum install gcc

EXPOSE:指定容器运行时监听的端口        EXPOSE 8090

ENTRYPOINT:镜像中应用的启动命令,容器运行时调节        ENTRYPOINT java -jar xx.jar

DockerFile构建镜像指令

docker build -t javaweb:1.0 .

--tag, -t,镜像的名字及tag,通常name:tag或者name格式;可以在一次构建中为一个镜像设置多个tag

javaweb:1.0:镜像名:版本号

".":dockerfile所在的目录

DockerCompose DockerCompose是什么?

帮助我们快速创建和部署容器。

与Docker Run命令对比

PS:容器之间可以通过容器名互相访问!!!容器之间可以通过容器名互相访问!!!容器之间可以通过容器名互相访问!!!实际上是compose会创建docker虚拟网络,支持服务通过名称定位IP

安装 Docker Compose
# 下载docker-compose
sudo curl -L https://github.com/docker/compose/releases/download/1.21.2/docker-compose-$(uname -s)-$(uname -m) -o /usr/local/bin/docker-compose
# 赋予执行权限
sudo chmod +x /usr/local/bin/docker-compose

# 查看docker-compose版本
docker-compose -v
使用Docker-Compose

docker-compose up        创建并使用容器

docker-compose stop     停止服务

docker-compose top       查看所有正在运行的服务

docker-compose rm        删除所有没有运行的服务

docker-compose restart [服务] 重启指定服务

1. 创建docker-compose.yml文件

# 指定docker-compose版本

version: "3.2"

# 服务(容器)列表

services:

  # 容器名:通过compose创建容器时的容器名
  nacos:

    # 创建容器依赖的镜像
    image: nacos/nacos-server

    # 容器启动时的环境配置
    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

    #

    depends_on:

        - nacos
  orderservice:
    build: ./order-service

    depends_on:

        - nacos

  gateway:
    build: ./gateway
    ports:
      - "10010:10010"

    depends_on:

        - nacos

解释:

ports:端口映射:容器与真实机器的端口映射

volumes:数据卷挂载:创建容器时指定数据卷挂载

build:扫描目录,找到DockerFile文件,通过DockerFile创建镜像,并通过该镜像创建一个正在运行的容器

depends_on:用来表示一个容器A的创建依靠另一个容器B,所以会以先创建容器B,再创建容器A的顺序执行指令。

微服务无需对外提供端口,对外GateWay网关提供端口即可。

2. 编写第一步中需要用到的DockerFile文件

3. 修改微服务application.yml文件中的容器地址

(docker集群部署会通过服务名找到对应地址)

spring:
  datasource:
    #url: jdbc:mysql://localhost:3306/cloud-user?useSSL=false
    url: jdbc:mysql://mysql/cloud-user?useSSL=false # docker集群部署会通过服务名找到对应地址
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver

4. 复制.jar文件到DockerFile文件中指定位置

FROM java:8-alpine
COPY ./app.jar /tmp/app.jar   
ENTRYPOINT java -jar /tmp/app.jar

5. 执行docker-compose up -d命令

docker-compose up -d    
#在 docker-compose.yml 所在路径下执行该命令 Compose 就会自动构建镜像并使用镜像启动容器【创建并运行容器】

执行Docker-Compose存在的问题

执行服务的顺序问题,比如:当A、B服务依赖于C服务,当执行docker-compose.yml文件时,服务时同时启动的,C服务可能再A、B服务之后启动,那么这时候A、B服务就会出现问题。

解决:

depends_on:用来表示一个容器A的创建依靠另一个容器B,所以会以先创建容器B,再创建容器A的顺序执行指令。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/841765.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号