Docker自定义镜像

server/2025/2/4 23:22:01/

Dockerfile自定义镜像

一:镜像结构

镜像是将应用程序及其需要的系统函数库、环境、配置、依赖打包而成。
我们以MySQL为例,来看看镜像的组成结构:

简单来说,镜像就是在系统函数库、运行环境基础上,添加应用程序文件、配置文
件、依赖文件等组合,然后编写好启动脚本打包在一起形成的文件。
我们要构建镜像,其实就是实现上述打包的过程。
 

1.2:Dockerfile语法

构建自定义的镜像时,并不需要一个个文件去拷贝,打包。
我们只需要告诉Docker,我们的镜像的组成,需要哪些BaseImage、需要拷贝什么
文件、需要安装什么依赖、启动脚本是什么,将来Docker会帮助我们构建镜像。
而描述上述信息的文件就是Dockerfile文件。
Dockerfile就是一个文本文件,其中包含一个个的指令(Instruction),用指令来说
明要执行什么操作来构建镜像。每一个指令都会形成一层Layer。

指令说明示例
FROM指定基础镜像FROM centos:6
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 reference | Docker Docs

1.3 案例一
基于Ubuntu镜像构建一个新镜像,运行一个java项目

        *新建一个空文件夹docker-demo
        *拷贝课前资料中的docker-demo.jar文件到docker-demo这个目录
        *拷贝课前资料中的jdk8.tar.gz文件到docker-demo这个目录
        *拷贝课前资料提供的Dockerfile到docker-demo这个目录
        *进入docker-demo

运行命令:docker build -t javaweb:1.0 .

最后访问:http://192.168.112.100:8090/hello,其中的ip改成你的虚拟机ip

1.4 案例二

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


虽然我们可以基于Ubuntu基础镜像,添加任意自己需要的安装包,构建镜像,但是
却比较麻烦。所以大多数情况下,我们都可以在一些安装了部分软件的基础镜像上做
改造。


例如,构建java项目的镜像,可以在已经准备了JDK的基础镜像基础上构建。


需求:基于java:8-alpine镜像,将一个Java项目构建为镜像


实现思路如下:

        *新建一个空的目录,然后在目录中新建一个文件,命名为Dockerfile
        *拷贝课前资料提供的docker-demo.jar到这个目录中
        *编写Dockerfile文件:
                基于java:8-alpine作为基础镜像
                将app.jar拷贝到镜像中
                暴露端口
                编写入口ENTRYPOINT
        内容如下:

FROM openjdk:8
COPY ./app.jar /tmp/app.jar
EXPOSE 8090
ENTRYPOINT java -jar /tmp/app.jar

        *使用docker build命令构建镜像
        *使用docker run创建容器并运行

Dockerfile的本质是一个文件,通过指令描述镜像的构建过程
Dockerfile的第一行必须是FROM,从一个基础镜像来构建
基础镜像可以是基本操作系统,如Ubuntu。也可以是其他人制作好的镜像,例如:
openjdk:8

二.Docker-Compose


5.1 DockerCompose简介

Docker Compose可以基于Compose文件帮我们快速的部署分布式应用,而无需手
动一个个创建和运行容器


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

version: "3.8"
services:
        mysql:
                image: mysql:5.7.25
                environment:
                        MYSQL_ROOT_PASSWORD: 123
                volumes:
                        - "/tmp/mysql/data:/var/lib/mysql"
                        - "/tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf"
        web:
                build: .
                ports:
                        - "8090:8090"
 

上面的Compose文件就描述一个项目,其中包含两个容器
        *mysql:一个基于mysql:5.7.25镜像构建的容器,并且挂载了两个目录

        *web:一个基于docker build临时构建的镜像容器,映射端口时8090
其实DockerCompose文件可以看做是将多个docker run命令写到一个文件,只是语
法稍有差异。

DockerCompose的详细语法参考官网:Compose file reference | Docker Docs

2.2 安装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

如果下载速度较慢,或者下载失败,使用课前资料提供的docker-compose文件
方式二:上传docker-compose文件到/usr/local/bin/目录。
修改文件权限:

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

1.3 部署微服务集群
1.3.1 数据库迁移

将cloud-demo涉及的相关sql导入到Linux上的mysql容器

5.3.2 阅读docker-compose.yml文件

version: "3.2"
services:
        nacos:
               image: nacos/nacos-server:1.4.1
                environment:

                        MODE: standalone
                ports:
                        - "8848:8848"
        mysql:
                image: mysql:8.0.30
                environment:
                        MYSQL_ROOT_PASSWORD: 123456
                volumes:
                        - "/tmp/mysql/data:/var/lib/mysql"
                        - "/tmp/mysql/conf/my.cnf:/etc/mysql/conf.d/my.cnf"
                ports:
                        - "3306:3306"
                userservice:
                        build: ./user-service
                        depends_on:
                                - nacos
                                - mysql
                        ports:
                                - "8081:8081"
                orderservice:
                        build: ./order-service
                        depends_on:
                                - nacos
                                - mysql
                        ports:
                                - "8080:8080"
                gateway:
                        build: ./gateway
                        depends_on:
                                - nacos
                                - mysql
                        ports:
                                - "10010:10010"

5.3.3 将项目打包

<build><finalName>app</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>

配置文件:

# 所有连接mysql的地方都要修改为mysql的容器名称(需要添加端口号)
# 所有连接nacos的地方都要修改为nacos的容器名称(需要添加端口号)


http://www.ppmy.cn/server/165008.html

相关文章

使用大语言模型在表格化网络安全数据中进行高效异常检测

论文链接 Efficient anomaly detection in tabular cybersecurity data using large language models 论文主要内容 这篇论文介绍了一种基于大语言模型&#xff08;LLMs&#xff09;的创新方法&#xff0c;用于表格网络安全数据中的异常检测&#xff0c;称为“基于引导式提示…

笔试-业务逻辑4

应用 小明在玩一个数字加减游戏&#xff0c;输入4个正整数&#xff1a;s、t、a、b&#xff0c;其中s>1&#xff0c;b<105&#xff0c;a!b。只使用加法或者减法&#xff0c;使得st。 每回合&#xff0c;小明用当前的数字&#xff0c;加上或减去一个数字&#xff1b;目前有…

基于微信小程序的酒店管理系统设计与实现(源码+数据库+文档)

酒店管理小程序目录 目录 基于微信小程序的酒店管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员模块的实现 (1) 用户信息管理 (2) 酒店管理员管理 (3) 房间信息管理 2、小程序序会员模块的实现 &#xff08;1&#xff09;系统首页 &#xff…

[Java基础]开发工具Idea

安装工具 IDE: 称为集成开发环境, 把代码编写,编译,执行等功能综合在一起的工具 卸载 控制面板->卸载程序->卸载->勾选清空配置->确认卸载 下载/安装 官网下载: IntelliJ IDEA – the Leading Java and Kotlin IDE 默认安装: 旗舰版安装无需任何勾选, 傻瓜安装…

QT知识点复习

1.qt核心机制 对象树、信号和槽、事件机制 2.对象树的作用 优化了内存回收机制。子对象实例化的时候&#xff0c;被父对象放对象树上&#xff0c;父对象释放内存&#xff0c;子对象也释放内存 3.信号和槽的作用 实现多个组件之间的通讯 4.信号和槽的几种连接方式 1.UI界面提…

第五十八节 k8s1.30.x 安装Redis集群

一、环境准备 1.1 准备k8s集群 cat /etc/hosts --- 192.168.80.31 lyc-80-31 192.168.80.32 lyc-80-32 192.168.80.33 lyc-80-33系统版本Rocky linux 8.10 docker版本 26.1.3 k8s版本 v1.31.3集群已免密互信&#xff0c;初始化配置一设置&#xff0c;k8s集群已安装 1.2 准…

神经网络和深度学习

应用 类型 为什么近几年飞速发展 数据增长&#xff0c;算力增长&#xff0c;算法革新 逻辑回归 向量化 浅层神经网络(Shallow neural network) 单条训练数据前向传播计算表达式 batch训练数据前向传播计算表达式 反向传播计算表达式 参数随机初始化 不能全部设为0 原因是同一…

排查定位jar包大文件

解压 JAR 包&#xff1a; mkdir jar_contents unzip your-jar-file.jar -d jar_contents统计各文件大小&#xff1a; du -ah jar_contents | sort -rh | head -n 20这会列出 JAR 包中最大的文件或目录&#xff0c;方便你定位大文件。 方法 2&#xff1a;使用 jar 工具查看文件…