Java Spring Boot 2.0实战Docker容器与架构原理,视频与课件,基于Linux环境

简介: Docker是最流行的开源容器引擎,Go语言开发,在互联网大规模集群、云计算、微服务等架构中广泛使用。本次课程一起学习Docker容器架构原理、如何基于Linux系统实战实战Docker容器,打包、发布、运行 Java Spring Boot 2.0应用。
Java Spring Boot 2.0实战Docker容器Linux与架构原理
内容摘要:Docker是最流行的开源容器引擎,Go语言开发,在互联网大规模集群、云计算、微服务等架构中广泛使用。本次课程一起学习Docker容器架构原理、如何基于Linux系统实战实战Docker容器,打包、发布、运行 Java Spring Boot 2.0应用。
Docker分布式架构,Docker是一套生态工具平台,包括客户端、服务端、仓库、集群工具等。
04fd0af036f68511d215c9e5daf6170adbe9c66f

如果你已经熟悉Docker的基本使用,可以直接从第7小节阅读,直接看Spring boot实战Docker的部分内容。

Docker 提供了两个版本:社区版 (CE) 和企业版 (EE)。
Docker 社区版 (CE) 是开发人员和小型团队开始使用 Docker 并尝试使用基于容器的应用的理想之选。
Docker CE 有两个更新渠道,即 stable 和 edge:
Stable 每个季度提供可靠更新;
Edge 每个月提供新功能更新。一般我们选择stable可以了,本文实战选择也是。
在2016年10月13日,杭州·云栖大会上,Docker与阿里云宣布达成战略合作,Docker的中国镜像仓库由阿里巴巴提供,国内开发者可以免费使用。
今天我们的演示也使用阿里云Docker仓库。我们选择的是Linux Ubuntu 16.04系统。
1、安装首先安装传输加密组件,然后来下载docker
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common
image

2: 安装阿里云docker 安全协议GPG证书
curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

3: 仓库写入软件源信息,选择stable版本
sudo add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
image

4: 更新资源列表,安装新版本Docker-CE,社区版本。
sudo apt-get -y update
sudo apt-get -y install docker-ce
image

5、检查Docker版本,是否成功安装
输入docker version命令,可以查看安装的Docker版本信息。
image

6、运行Docker Hello World
最简单的例子就是 Hello world,docker会从服务器拉去hello world镜像,并且在本地运行。
sudo docker run hello-world
image
Docker安装成功,并且可以执行最简单的镜像,入门例子。下面开始安装特殊的镜像,Mongodb作为例子。

7、Docker制作java Spring Boot 镜像

     新建Java Spring Boot项目,这里需要解除Maven自动构建Docker镜像,使用辅助插件。在项目里配置POM。

    推荐使用Linux 或者Mac OS可以安装docker,因为Maven构建Docker镜像需要Docker服务器支持。

 <!-- tag::plugin[] -->
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>dockerfile-maven-plugin</artifactId>
                <version>1.4.9</version>
                <configuration>
                    <repository>${docker.image.prefix}/${project.artifactId}</repository>
                </configuration>
            </plugin>

插件的XML配置

<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.2.3</version>
<configuration>
<imageName>${docker.image.prefix}/${project.artifactId}</imageName>
<dockerDirectory>src/main/docker</dockerDirectory>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>

创建重要的Dockerfile文件,用于打包镜像。基本是程序的主要运行参数信息。以及我们的java Spring Boot的Jar包。

FROM openjdk:8-jdk-alpine
VOLUME /tmp
ARG DEPENDENCY=target/dependency
COPY ${DEPENDENCY}/BOOT-INF/lib /app/lib
COPY ${DEPENDENCY}/META-INF /app/META-INF
COPY ${DEPENDENCY}/BOOT-INF/classes /app
ENTRYPOINT ["java","-cp","app:app/lib/*","hello.Application"]
Java Spring Boot 集成Docker插件的项目结构:

73f962a930c64bf30bf89466387a3369c05b1b7e

执行命令mvn install dockerfile:build。

构建并生成Docker镜像文件,可以选择上传到DockerHub服务器。

8、Docker搜索Spring Boot镜像

     我们也可以选择去Docker Hub拉去通用的镜像,比如MySQL、MongoDB、Redis、MQ等,

 使用Docker Search 关键字 即可,然后可以选择拉去需要的镜像,节约时间。

9、Docker拉去 Spring Boot 镜像

    在命令中输入sudo docker pull  springio/gs-spring-boot-docker 等待下载。

d08e9d62437c28fb1a9a592989a8943463820c01

10.Docker运行Spring Boot应用

   下载完毕以后,我们就可以技术来使用Docker运行我们的Spring Boot应用。使用命令:

sudo docker run -p 8080:8080 -t springio/gs-spring-boot-docker

cdc321b5a83aaca0c51088fdde48821b927818f5

如果没有错误,应该正常启动,端口是8080,我们这里访问http://localhost:8080/hello 可以看到简单的字符串 Hello Docker。

基本就完成了,大量的运维、部署工作可以通过Docker来完成,尤其是大规模集群,几百、上前台服务的情况。Docker简化的配置、统一部署的工作。

使用起来十分方便,除了我们自己特殊的应用打包,绝大部分的数据库、中间件等都有官方的Docker镜像。

参考:

http://maven.apache.org/install.html 

https://github.com/spring-guides/gs-spring-boot-docker 

https://docs.docker.com/ 

第17课:Spring Boot 2.0实战Docker容器与架构原理》资料:

视频: https://yq.aliyun.com/live/880

PPT:https://yq.aliyun.com/live/880

阿里巴巴Java群超过3000人
直播地址:Java技术进阶群
进群方式:钉钉扫码入群
image
阿里巴巴MongoDB群
image

相关文章
|
4月前
|
机器学习/深度学习 自然语言处理 监控
23_Transformer架构详解:从原理到PyTorch实现
Transformer架构自2017年Google发表的论文《Attention Is All You Need》中提出以来,彻底改变了深度学习特别是自然语言处理领域的格局。在短短几年内,Transformer已成为几乎所有现代大型语言模型(LLM)的基础架构,包括BERT、GPT系列、T5等革命性模型。与传统的RNN和LSTM相比,Transformer通过自注意力机制实现了并行化训练,极大提高了模型的训练效率和性能。
|
7月前
|
存储 监控 算法
园区导航系统技术架构实现与原理解构
本文聚焦园区导航场景中室内外定位精度不足、车辆调度路径规划低效、数据孤岛难以支撑决策等技术痛点,从架构设计到技术原理,对该系统从定位到数据中台进行技术拆解。
345 0
园区导航系统技术架构实现与原理解构
|
8月前
|
存储 消息中间件 canal
zk基础—2.架构原理和使用场景
ZooKeeper(ZK)是一个分布式协调服务,广泛应用于分布式系统中。它提供了分布式锁、元数据管理、Master选举及分布式协调等功能,适用于如Kafka、HDFS、Canal等开源分布式系统。ZK集群采用主从架构,具有顺序一致性、高性能、高可用和高并发等特点。其核心机制包括ZAB协议(保证数据一致性)、Watcher监听回调机制(实现通知功能)、以及基于临时顺序节点的分布式锁实现。ZK适合小规模集群部署,主要用于读多写少的场景。
|
9月前
|
机器学习/深度学习 算法 测试技术
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
本文探讨了基于图的重排序方法在信息检索领域的应用与前景。传统两阶段检索架构中,初始检索速度快但结果可能含噪声,重排序阶段通过强大语言模型提升精度,但仍面临复杂需求挑战
300 0
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
|
4月前
|
JavaScript Java 关系型数据库
基于springboot的项目管理系统
本文探讨项目管理系统在现代企业中的应用与实现,分析其研究背景、意义及现状,阐述基于SSM、Java、MySQL和Vue等技术构建系统的关键方法,展现其在提升管理效率、协同水平与风险管控方面的价值。
|
4月前
|
搜索推荐 JavaScript Java
基于springboot的儿童家长教育能力提升学习系统
本系统聚焦儿童家长教育能力提升,针对家庭教育中理念混乱、时间不足、个性化服务缺失等问题,构建科学、系统、个性化的在线学习平台。融合Spring Boot、Vue等先进技术,整合优质教育资源,提供高效便捷的学习路径,助力家长掌握科学育儿方法,促进儿童全面健康发展,推动家庭和谐与社会进步。