当前位置: 首页 > article >正文

【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 的未来:从微服务到云原生的演进

 <前文回顾>

点击此处查看 合集 https://blog.csdn.net/foyodesigner/category_12907601.html?fromshare=blogcolumn&sharetype=blogcolumn&sharerId=12907601&sharerefer=PC&sharesource=FoyoDesigner&sharefrom=from_link

<今日更新>

一、引子:Spring Boot 的“前世今生”

Spring Boot 这玩意儿,从诞生到现在,已经成了 Java 开发界的“扛把子”。你说它是个框架吧,它又像个“工具箱”,里头啥都有,随用随取。你说它是个“工具箱”吧,它又像个“保姆”,帮你把那些繁琐的配置都搞定了。反正就是,用了 Spring Boot,你就跟“开了挂”似的,开发效率蹭蹭往上涨。

不过,这玩意儿也不是一成不变的。从最早的“单体应用”到现在的“微服务”,Spring Boot 一直在“进化”。今儿个咱就唠唠,Spring Boot 的未来是啥样的,咋从微服务走向云原生。

二、微服务:Spring Boot 的“第一春”

微服务这玩意儿,说白了就是把一个大的应用拆成一堆小的服务。每个服务都独立运行,互相之间通过 API 通信。这样一来,应用就变得“灵活”了,哪儿出问题修哪儿,不用“一刀切”。

1. Spring Boot 咋支持微服务?

Spring Boot 天生就适合搞微服务。为啥这么说呢?因为它把那些繁琐的配置都搞定了,你只需要关注业务逻辑就行。比如,你想搞个 RESTful API,只需要这么写:

Java Code

@RestController

public class MyController {

    @GetMapping("/hello")

    public String hello() {

        return "Hello, World!";

    }

}

就这么几行代码,一个简单的 RESTful API 就搞定了。你要是用别的框架,光配置就得写半天。

2. Spring Cloud:微服务的“全家桶”

Spring Boot 虽然适合搞微服务,但光靠它还不够。你还得解决服务发现、负载均衡、配置管理等问题。这时候,Spring Cloud 就派上用场了。

Spring Cloud 是 Spring 家族里的一个“全家桶”,里头啥都有。比如,你想搞服务发现,可以用 Eureka[1];想搞负载均衡,可以用 Ribbon[2];想搞配置管理,可以用 Config[3]。

举个例子,你想用 Eureka 搞服务发现,只需要这么配置:

Yml Code

spring:

  application:

    name: my-service

eureka:

  client:

    service-url:

      defaultZone: http://localhost:8761/eureka/

然后启动应用,服务就自动注册到 Eureka 上了。

3. 微服务的坑

微服务虽然好,但也有坑。最大的坑就是“分布式系统的复杂性”。你说你拆了一堆服务,结果服务之间互相调用,出了问题都不知道是哪儿出的。这不就跟“拆东墙补西墙”似的,越拆越乱。

另外,微服务的部署也是个问题。你说你拆了一堆服务,结果每个服务都得单独部署,运维成本蹭蹭往上涨。这不就跟“搬起石头砸自己的脚”似的,越搞越累。

三、云原生:Spring Boot 的“第二春”

云原生这玩意儿,说白了就是把应用搬到云上,利用云计算的特性,提高应用的弹性和可扩展性。Spring Boot 作为 Java 开发界的“扛把子”,自然也得跟上这个潮流。

1. 容器化:Docker 和 Kubernetes

云原生的第一步就是容器化。容器化说白了就是把应用打包成一个“集装箱”,里头啥都有,随用随取。Docker[4] 是容器化的“扛把子”,Kubernetes[5] 是容器编排的“扛把子”。

Spring Boot 天生就适合搞容器化。为啥这么说呢?因为它把那些繁琐的配置都搞定了,你只需要关注业务逻辑就行。比如,你想把 Spring Boot 应用打包成 Docker 镜像,只需要这么写:

dockerfile Code

FROM openjdk:11-jre-slim

COPY target/my-app.jar /app/my-app.jar

ENTRYPOINT ["java", "-jar", "/app/my-app.jar"]

然后运行 docker build 命令,镜像就搞定了。

2. 服务网格:Istio

云原生的第二步就是服务网格。服务网格说白了就是在服务之间加一层“代理”,负责处理服务之间的通信。Istio[6] 是服务网格的“扛把子”。

Spring Boot 虽然适合搞微服务,但光靠它还不够。你还得解决服务之间的通信问题。这时候,Istio 就派上用场了。

举个例子,你想用 Istio 搞服务之间的通信,只需要这么配置:

Yml Code

apiVersion: networking.istio.io/v1alpha3

kind: VirtualService

metadata:

  name: my-service

spec:

  hosts:

  - my-service

  http:

  - route:

    - destination:

        host: my-service

        subset: v1

然后启动应用,服务之间的通信就自动交给 Istio 处理了。

3. 云原生的坑

云原生虽然好,但也有坑。最大的坑就是“复杂性”。你说你搞了一堆容器,结果容器之间互相调用,出了问题都不知道是哪儿出的。这不就跟“拆东墙补西墙”似的,越拆越乱。

另外,云原生的运维也是个问题。你说你搞了一堆容器,结果每个容器都得单独管理,运维成本蹭蹭往上涨。这不就跟“搬起石头砸自己的脚”似的,越搞越累。

四、Spring Boot 的未来:从微服务到云原生

Spring Boot 的未来是啥样的?说白了就是从微服务走向云原生。为啥这么说呢?因为云原生是未来的趋势,Spring Boot 作为 Java 开发界的“扛把子”,自然也得跟上这个潮流。

1. Spring Native:云原生的“新武器”

Spring Native 是 Spring 家族里的一个“新武器”,专门用来搞云原生。它能把 Spring Boot 应用编译成原生镜像,提高应用的启动速度和内存使用效率。

举个例子,你想用 Spring Native 搞原生镜像,只需要这么写:

bash

复制

mvn spring-boot:build-image

然后运行 docker run 命令,原生镜像就搞定了。

2. Spring Cloud Kubernetes:云原生的“全家桶”

Spring Cloud Kubernetes 是 Spring 家族里的一个“全家桶”,专门用来搞云原生。它能把 Spring Boot 应用和 Kubernetes 集成起来,提高应用的可扩展性和弹性。

举个例子,你想用 Spring Cloud Kubernetes 搞服务发现,只需要这么配置:

Yml Code

spring:

  cloud:

    kubernetes:

      discovery:

        all-namespaces: true

然后启动应用,服务就自动注册到 Kubernetes 上了。

3. 未来的坑

Spring Boot 的未来虽然光明,但也有坑。最大的坑就是“复杂性”。你说你搞了一堆云原生的东西,结果出了问题都不知道是哪儿出的。这不就跟“拆东墙补西墙”似的,越拆越乱。

另外,云原生的运维也是个问题。你说你搞了一堆云原生的东西,结果每个东西都得单独管理,运维成本蹭蹭往上涨。这不就跟“搬起石头砸自己的脚”似的,越搞越累。

专有名词解释

  1. Eureka:Spring Cloud 提供的一个服务发现组件,用于微服务架构中的服务注册与发现。
  2. Ribbon:Spring Cloud 提供的一个客户端负载均衡组件,用于微服务架构中的负载均衡。
  3. Config:Spring Cloud 提供的一个配置管理组件,用于微服务架构中的集中配置管理。
  4. Docker:一个开源的容器化平台,用于将应用打包成容器镜像。
  5. Kubernetes:一个开源的容器编排平台,用于管理容器化应用的部署、扩展和运维。
  6. Istio:一个开源的服务网格平台,用于管理微服务架构中的服务通信。
  7. Spring Native:Spring 家族中的一个项目,用于将 Spring Boot 应用编译成原生镜像,提高启动速度和内存使用效率。
  8. Spring Cloud Kubernetes:Spring 家族中的一个项目,用于将 Spring Boot 应用与 Kubernetes 集成,提高应用的可扩展性和弹性。

写在最后

身为一个中古程序猿,我有很多自己想做的事情,比如埋头苦干手搓一个低代码数据库设计平台(目前只针对写java的朋友),已经在找朋友内测了,比如很喜欢帮身边的朋友看看简历,讲讲面试技巧,毕竟工作这么多年,也做到过高管,有很多面人经历,意见还算有用,大家基本都能拿到想要的offer...

我深刻意识到,能自由做自己喜欢的事情是有多么不容易,又是多么有成就感。所以我拉了两三个志同道合的好友,开了一间公司,继续朝着“自由”的目标前进。

当下呢,我们希望有更多的朋友能够参与到产品的测试中来,体验并且给出更好的建议。未来可能会在博客po更多关于我们产品的内容,包括使用场景、说明、课程等,希望能对大家有所帮助。

另外,想整个花活儿,每天花个1-2小时,来帮助我素未谋面的老朋友们看看简历,提提意见啥的,纯属为爱发电。我在线时间不固定,但是不要米,咱就别要自行车儿了呗~如果您有兴趣,可以点击文章底部卡片一起交流(人工回复,比较慢,请担待)。

最后,请大家持续关注我们的博客,未来还有很多栏目,一起发掘~!

(来呀~↓↓↓~老铁)

相关文章:

【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 的未来:从微服务到云原生的演进

<前文回顾> 点击此处查看 合集 https://blog.csdn.net/foyodesigner/category_12907601.html?fromshareblogcolumn&sharetypeblogcolumn&sharerId12907601&sharereferPC&sharesourceFoyoDesigner&sharefromfrom_link <今日更新> 一、引子&…...

beego文件上传

1file.go 2html代码 3路由设置 beego.Router("/file/Upload", &controllers.FileUploadController{}, "post:Upload") 注意 1&#xff0c;得新建个upload文件夹 2&#xff0c;路由设置严格区分大小写。 biiego文件下载上传代码 github 觉得不错Star下...

2025-04-05 吴恩达机器学习5——逻辑回归(2):过拟合与正则化

文章目录 1 过拟合1.1 过拟合问题1.2 解决过拟合 2 正则化2.1 正则化代价函数2.2 线性回归的正则化2.3 逻辑回归的正则化 1 过拟合 1.1 过拟合问题 欠拟合&#xff08;Underfitting&#xff09; 模型过于简单&#xff0c;无法捕捉数据中的模式&#xff0c;导致训练误差和测试误…...

基于Python的图书借阅推荐系统设计与实现

【Python】基于Python的图书借阅推荐系统设计与实现 &#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 本项目基于Python语言和Django框架开发&#xff0c;旨在为用户提供一个高可靠、高便捷的图…...

数字与数学——常见面试算法题

目录 数字统计问题 符号统计 阶乘0的个数 溢出问题 整数反转 回文数 进制问题 七进制数 进制转换 数组实现加法 数组实现整数加法 字符串实现加法 二进制加法 幂运算 求2的幂 求3的幂 求4的幂 辗转相除法&#xff08;之前博客有过详细推导&#xff09; https…...

Lua:第1-4部分 语言基础

1 Lua语言入门 1.1 程序段 我们将 Lua 语言执行的每一段代码&#xff08;例如&#xff0c;一个文件或交互模式下的一行&#xff09;称为一个程序段 &#xff08; Chunk &#xff09; &#xff0c;即一组命令或表达式组成的序列 。 1.2 一些词法规范 Lua 语言中的标识符&#…...

2024版idea使用Lombok时报找不到符号

今天在springboot项目中使用Lombok的Builder注解&#xff0c;启动时居然报了找不到符号的错&#xff0c;如下图 于是开始了漫长的寻找之路&#xff0c;首先去settings->Plugins中看自己的Lombok插件是否启动&#xff0c;发现确实是如此&#xff0c;然后看网上的教程去加上这…...

python中的sort使用

目录 sort()使用 排序处理 升序由小到大排序&#xff1a; sort与sorted 总结 降序由大到小排序&#xff1a; key 参数详解 按字符串长度升序排序 按字符串第二个字符排序 sort()使用 list.sort(keyNone, reverseFalse) 功能&#xff1a;对列表原地排序&#xff08;直接…...

构建macOS命令速查手册:基于Flask的轻量级Web应用实践

构建macOS命令速查手册&#xff1a;基于Flask的轻量级Web应用实践 一、项目概述 本文介绍一个基于Flask框架开发的macOS命令速查Web应用。该应用通过结构化的命令数据存储和响应式前端设计&#xff0c;为用户提供便捷的命令查询体验&#xff0c;具备以下特点&#xff1a; 六…...

APP的兼容性测试+bug定位方法

兼容性问题定位 一、为什么会有兼容性问题&#xff1f;二、APP兼容性测试场景三、常见的一些兼容性bug0. 引言1. 常见兼容性bug&#xff08;1&#xff09;界面性问题&#xff08;2&#xff09;内存不足&#xff08;3&#xff09;网络问题&#xff08;4&#xff09;权限问题 通过…...

开源 PDF.js 文件编辑操作

一、PDF.js PDF.js 是 Mozilla 基金会推出的一个使用 HTML5 构建的 PDF 阅读器&#xff0c;它完全使用 JavaScript 编写。作为 Firefox 浏览器的默认 PDF 查看器&#xff0c;PDF.js 具有强大的兼容性和稳定性。它不仅支持 PDF 文件的查看和渲染&#xff0c;还提供了丰富的交互…...

云资源合规基线:确保云环境安全与合规的完整指南

1. 引言 随着越来越多的企业将其IT基础设施迁移到云端,确保云资源的安全性和合规性变得至关重要。云资源合规基线是一套最佳实践和标准,旨在帮助组织维护安全、高效且符合法规要求的云环境。本文将深入探讨云资源合规基线的各个方面,为IT管理者和安全专业人士提供全面的指导。…...

#SVA语法滴水穿石# (005)关于 问号表达式(condition ? expr1 : expr2)

在 SystemVerilog 断言(SVA)中,问号表达式(condition ? expr1 : expr2)的语法和逻辑与 C 语言的三元条件运算符完全一致。它根据条件选择执行 expr1 或 expr2,常用于动态选择信号、序列或属性。 1. 基本语法 // 格式: condition ? true_expression : false_expressi…...

操作系统、虚拟化技术与云原生及云原生AI简述

目录 操作系统基础 操作系统定义 操作系统的组成 操作系统的分类 Linux操作系统特性 虚拟化技术 概述 CPU虚拟化 内存虚拟化 I/O虚拟化 虚拟化技术 虚拟化平台管理工具 容器 容器与云原生&#xff1a;详细介绍 容器的特点 什么是云原生&#xff1f; 云原生的特点 容器与云原生的…...

springcouldalibaba5大组件

springcouldalibaba5大组件 Spring Cloud Alibaba 简介 Spring Cloud Alibaba 是阿里巴巴提供的一站式微服务解决方案&#xff0c;基于 Spring Cloud 框架&#xff0c;集成了阿里巴巴的分布式中间件技术。它通过简单的注解和少量配置&#xff0c;就能将 Spring Cloud 应用连接…...

opencv中mat深拷贝和浅拷贝

1. 浅拷贝&#xff08;Shallow Copy&#xff09; 特点&#xff1a; 共享数据内存&#xff0c;新对象和原对象指向同一块内存数据。 修改任一对象的数据会影响另一个对象&#xff08;因为内存共享&#xff09;。 高效&#xff08;仅复制矩阵头信息&#xff0c;不复制实际数据&…...

深入理解 C++ 三大特性之一 继承

欢迎来到干货小仓库!!! 今日的Commit 是明日的 Releasse&#xff0c;用持续交付的心态活成终身迭代的版本。 1.继承的定义 1.1定义格式 1.2继承关系和访问限定符 1.3继承基类成员访问方式的变化 类成员/继承方式public继承protected继承private继承基类的public成员派生类的…...

类 和 对象 的介绍

对象的本质是一种新的数据类型。类是一个模型&#xff0c;对象是类的一个具体化实例。为类创建实例也就是创建对象。 一、类&#xff08;class&#xff09; 类决定一个对象将是什么样的&#xff08;有什么属性、功能&#xff09;。类和变量一样&#xff0c;有名字。 1.创建类 …...

`use_tempaddr` 和 `temp_valid_lft ` 和 `temp_prefered_lft ` 笔记250405

use_tempaddr 和 temp_valid_lft 和 temp_prefered_lft 笔记250405 以下是 Linux 系统中与 IPv6 临时隐私地址相关的三个关键参数 use_tempaddr、temp_valid_lft 和 temp_prefered_lft 的详细说明及协作关系&#xff1a; &#x1f4dc; 参数定义与功能 参数作用默认值依赖关…...

LeetCode详解之如何一步步优化到最佳解法:20. 有效的括号

LeetCode详解系列的总目录&#xff08;持续更新中&#xff09;&#xff1a; LeetCode详解之如何一步步优化到最佳解法&#xff1a;前100题目录&#xff08;更新中...&#xff09;-CSDN博客 LeetCode详解系列的上一题链接&#xff1a; LeetCode详解之如何一步步优化到最佳解法…...

学习笔记,DbContext context 对象是保存了所有用户对象吗

DbContext 并不会将所有用户对象保存在内存中&#xff1a; DbContext 是 Entity Framework Core (EF Core) 的数据库上下文&#xff0c;它是一个数据库访问的抽象层它实际上是与数据库的一个连接会话&#xff0c;而不是数据的内存缓存当您通过 _context.Users 查询数据时&…...

【2020】【论文笔记】基于二维光子晶体的光控分光比可调Y——

前言 类型 太赫兹 + 分束器 太赫兹 + 分束器 太赫兹+分束器 期刊 红外与毫米波学报 红外与毫米波学报 红外与毫米波学报 作者 姜宗丹 , 李培丽 ,...

Mydumper备份数据库

介绍&#xff1a; MyDumper是一个MySQL逻辑备份工具。它有2个工具&#xff1a; mydumper负责导出 MySQL 数据库的一致备份myloader从 mydumper 读取备份&#xff0c;连接到目标数据库并导入备份。 这两个工具都使用多线程功能。 下载链接&#xff1a; https://github.com/m…...

BN测试和训练时有什么不同, 在测试时怎么使用?

我们来彻底搞懂 Batch Normalization&#xff08;BN&#xff09; 在训练和测试阶段的区别&#xff0c;以及 测试时怎么用。 &#x1f9e0; 一句话总结&#xff1a; 训练时&#xff1a;使用 当前 mini-batch 的均值和方差 测试时&#xff1a;使用 整个训练集估计的“滑动平均均值…...

JavaWeb 课堂笔记 —— 02 JavaScript

本系列为笔者学习JavaWeb的课堂笔记&#xff0c;视频资源为B站黑马程序员出品的《黑马程序员JavaWeb开发教程&#xff0c;实现javaweb企业开发全流程&#xff08;涵盖SpringMyBatisSpringMVCSpringBoot等&#xff09;》&#xff0c;章节分布参考视频教程&#xff0c;为同样学习…...

多GPU训练

写在前面 限于财力不足&#xff0c;本机上只有一个 GPU 可供使用&#xff0c;因此这部分的代码只能够稍作了解&#xff0c;能够使用的 GPU 也只有一个。 多 GPU 的数据并行&#xff1a;有几张卡&#xff0c;对一个小批量数据&#xff0c;有几张卡就分成几块&#xff0c;每个 …...

Java面试黄金宝典33

1. 什么是存取控制、 触发器、 存储过程 、 游标 存取控制 定义&#xff1a;存取控制是数据库管理系统&#xff08;DBMS&#xff09;为保障数据安全性与完整性&#xff0c;对不同用户访问数据库对象&#xff08;如表、视图等&#xff09;的权限加以管理的机制。它借助定义用户…...

如何在 Linux 上安装 Python

本指南介绍如何在Linux机器上安装 Python。Python 已成为开发人员、数据科学家和系统管理员必不可少的编程语言。它用于各种应用&#xff0c;包括 Web 开发、数据科学、自动化和机器学习。 本综合指南将引导您完成在 Linux 系统上安装Python的过程&#xff0c;涵盖从基本包管理…...

系统与网络安全------Windows系统安全(6)

资料整理于网络资料、书本资料、AI&#xff0c;仅供个人学习参考。 共享文件夹 发布共享文件夹 Windows共享概述 微软公司推出的网络文件/打印机服务系统 可以将一台主机的资源发布给其他主机共有 共享访问的优点 方便、快捷相比光盘 U盘不易受文件大小限制 可以实现访问…...

解决 Spring Boot 返回日期格式问题

springboot项目有个属性这样注解 DateTimeFormat(pattern "yyyy-MM-dd") private Date createTime; 表中是 create_time datetime DEFAULT NULL 只使用了 DateTimeFormat 注解来处理输入格式&#xff0c;但没有配置输出格式。返回给前端还是 createTime: "2…...