0

0

提高云原生应用程序中 Java 性能的 roven 策略

心靈之曲

心靈之曲

发布时间:2024-12-09 20:21:10

|

856人浏览过

|

来源于dev.to

转载

提高云原生应用程序中 java 性能的 roven 策略

作为一名在云原生应用程序方面拥有多年经验的 java 开发人员,我了解到优化性能对于分布式环境中的成功至关重要。让我们探讨一下一直帮助我在云设置中增强 java 应用程序性能的五种策略。

容器化是云中 java 应用程序的游戏规则改变者。我总是首先将 jvm 配置为容器感知型。这可确保 java 运行时遵守容器编排平台设置的资源限制,防止意外的内存不足错误或 cpu 限制。

以下是我通常如何在容器中启动 java 应用程序的示例:

java -xx:+usecontainersupport -xx:maxrampercentage=75.0 -jar myapp.jar

此命令启用容器支持并将最大堆大小设置为容器内存限制的 75%。我发现这是一个很好的起点,但根据应用程序的特定需求进行监控和调整至关重要。

说到垃圾收集,我更喜欢对大多数云原生应用程序使用 g1 收集器。它在吞吐量和延迟之间提供了良好的平衡:

java -xx:+useg1gc -xx:g1newsizepercent=30 -xx:g1maxnewsizepercent=50 -xx:maxgcpausemillis=200 -jar myapp.jar

这些设置旨在将 gc 暂停时间控制在 200 毫秒以下,同时允许年轻代根据需要增长。

立即学习Java免费学习笔记(深入)”;

高效的数据序列化在云环境中至关重要,尤其是在处理微服务时。我已经放弃了 java 的内置序列化,转而采用性能更高的替代方案。 protocol buffers (protobuf) 因其出色的性能和跨语言支持而成为我的首选。

这是在 protobuf 中定义消息的简单示例:

syntax = "proto3";

message person {
  string name = 1;
  int32 age = 2;
  string email = 3;
}

这是我在 java 中通常使用它的方式:

person person = person.newbuilder()
    .setname("john doe")
    .setage(30)
    .setemail("john@example.com")
    .build();

byte[] bytes = person.tobytearray();

这种方法不仅比 java 序列化更快,而且产生的有效负载更小,这对于网络密集型应用程序是有利的。

异步编程是我看到性能显着改进的另一个领域。 java 的 completablefuture api 是处理并发操作的强大工具。以下是我如何使用它同时执行多个独立 api 调用的示例:

completablefuture<string> future1 = completablefuture.supplyasync(() -> callexternalapi1());
completablefuture<string> future2 = completablefuture.supplyasync(() -> callexternalapi2());

completablefuture<void> allof = completablefuture.allof(future1, future2);

allof.thenrun(() -> {
    string result1 = future1.join();
    string result2 = future2.join();
    processresults(result1, result2);
});

此模式允许应用程序并行进行多个 api 调用,从而显着缩短总体响应时间。

对于响应式编程,我经常转向 project reactor。它对于构建响应式、非阻塞应用程序特别有用。这是我如何使用 reactor 处理数据流的一个简单示例:

flux.fromiterable(getdatasource())
    .flatmap(this::processitem)
    .filter(result -> result.isvalid())
    .subscribe(this::saveresult);

此代码以非阻塞方式异步处理项目、过滤结果并保存它们。

优化数据库交互对于云原生应用程序至关重要。连接池是必须的,我在 hikaricp 上取得了巨大的成功。以下是我通常的配置方式:

hikariconfig config = new hikariconfig();
config.setjdbcurl("jdbc:mysql://localhost:3306/mydb");
config.setusername("user");
config.setpassword("password");
config.setmaximumpoolsize(10);
config.setminimumidle(5);
config.setidletimeout(300000);
config.setconnectiontimeout(10000);

hikaridatasource datasource = new hikaridatasource(config);

这些设置创建一个最多包含 10 个连接的池,并保持至少 5 个空闲连接准备就绪。空闲时间超过 5 分钟的连接将从池中删除。

缓存是另一个重要的优化。我经常在云环境中使用 redis 进行分布式缓存。这是一个使用 spring data redis 的简单示例:

@repository
public class userrepository {

    @autowired
    private redistemplate<string, user> redistemplate;

    public user findbyid(string id) {
        string key = "user:" + id;
        user user = redistemplate.opsforvalue().get(key);
        if (user == null) {
            user = finduserfromdatabase(id);
            redistemplate.opsforvalue().set(key, user, 1, timeunit.hours);
        }
        return user;
    }
}

此代码在查询数据库之前检查 redis 缓存,显着减少频繁访问数据的数据库负载。

歌者PPT
歌者PPT

歌者PPT,AI 写 PPT 永久免费

下载

分析和监控对于持续的性能优化至关重要。我发现集成 spring cloud sleuth 等分布式跟踪工具可以为跨微服务的应用程序行为提供宝贵的见解。

以下是我通常如何在 spring boot 应用程序中设置 sleuth:

@springbootapplication
@enablediscoveryclient
public class myapplication {

    public static void main(string[] args) {
        springapplication.run(myapplication.class, args);
    }

    @bean
    public sampler defaultsampler() {
        return sampler.always_sample;
    }
}

通过此设置,sleuth 会自动将跟踪和跨度 id 添加到日志中,从而更轻松地跟踪跨多个服务的请求。

为了更详细的性能分析,我经常转向 async-profiler。它提供低开销的 cpu 和分配分析,这对于识别性能瓶颈至关重要。以下是我通常的运行方式:

./profiler.sh -d 30 -f profile.html <pid>

此命令会分析应用程序 30 秒并生成 html 报告,然后我可以分析该报告以识别代码中的热点

根据我的经验,实施这些策略可以显着提高云原生 java 应用程序的性能。然而,重要的是要记住,性能优化是一个持续的过程。我不断监控应用程序性能、分析数据并进行迭代改进。

我还没有提到的一个方面是负载测试的重要性。在云环境中,了解应用程序在各种负载条件下的行为至关重要。我通常使用 apache jmeter 或 gadling 等工具来模拟不同的负载场景。

这是加特林模拟的一个简单示例:

class mysimulation extends simulation {
  val httpprotocol = http
    .baseurl("http://my-app.com")
    .acceptheader("application/json")

  val scn = scenario("my scenario")
    .exec(http("request_1")
      .get("/api/users"))
    .pause(5)
    .exec(http("request_2")
      .get("/api/products"))

  setup(
    scn.inject(rampusers(100).during(10.seconds))
  ).protocols(httpprotocol)
}

此模拟在 10 秒内增加了 100 个用户,向两个不同的端点发出请求。通过分析结果,我可以识别性能瓶颈并确保应用程序可以处理预期负载。

云原生应用程序的另一个重要考虑因素是弹性。断路器是防止微服务架构中发生级联故障的好方法。我经常使用 resilience4j 来实现此目的。以下是我通常如何实现断路器的示例:

circuitbreaker circuitbreaker = circuitbreaker.ofdefaults("mycircuitbreaker");

supplier<string> decoratedsupplier = circuitbreaker
    .decoratesupplier(circuitbreaker, this::dosomething);

string result = try.ofsupplier(decoratedsupplier)
    .recover(throwable -> "hello from recovery").get();

此代码使用断路器包装了潜在不稳定的操作,如果电路开路,则回落到默认值。

最后,我一直很注重资源的利用。在云环境中,资源的有效利用可以显着影响性能和成本。我使用 kubernetes 的资源请求和限制等工具来确保每个容器获得所需的资源,而不会过度配置。

以下是我如何在 kubernetes 部署中定义资源约束的示例:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-app
spec:
  replicas: 3
  template:
    spec:
      containers:
      - name: my-app
        image: my-app:latest
        resources:
          requests:
            cpu: 100m
            memory: 128Mi
          limits:
            cpu: 500m
            memory: 512Mi

此配置可确保 my-app 的每个实例至少保证 100 毫核 cpu 和 128 mib 内存,但不会使用超过 500 毫核 cpu 或 512 mib 内存。

总之,优化云原生应用程序中的 java 性能是一项多方面的挑战,需要关注应用程序设计和部署的各个方面。通过专注于容器化、高效数据处理、异步编程、数据库优化和持续监控,我们可以构建在云环境中表现良好的 java 应用程序。请记住,成功的关键是持续改进 - 始终进行测量、分析和优化。


我们的创作

一定要看看我们的创作:

投资者中心 | 投资者中央西班牙语 | 智能生活 | 时代与回响 | 令人费解的谜团 | 印度教 | 精英开发 | js学校


我们在媒体上

科技考拉洞察 | 时代与回响世界 | 投资者中央媒体 | 令人费解的谜团 | 科学与时代媒介 | 现代印度教

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

160

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

spring boot框架优点
spring boot框架优点

spring boot框架的优点有简化配置、快速开发、内嵌服务器、微服务支持、自动化测试和生态系统支持。本专题为大家提供spring boot相关的文章、下载、课程内容,供大家免费下载体验。

139

2023.09.05

spring框架有哪些
spring框架有哪些

spring框架有Spring Core、Spring MVC、Spring Data、Spring Security、Spring AOP和Spring Boot。详细介绍:1、Spring Core,通过将对象的创建和依赖关系的管理交给容器来实现,从而降低了组件之间的耦合度;2、Spring MVC,提供基于模型-视图-控制器的架构,用于开发灵活和可扩展的Web应用程序等。

408

2023.10.12

Java Spring Boot开发
Java Spring Boot开发

本专题围绕 Java 主流开发框架 Spring Boot 展开,系统讲解依赖注入、配置管理、数据访问、RESTful API、微服务架构与安全认证等核心知识,并通过电商平台、博客系统与企业管理系统等项目实战,帮助学员掌握使用 Spring Boot 快速开发高效、稳定的企业级应用。

73

2025.08.19

Java Spring Boot 4更新教程_Java Spring Boot 4有哪些新特性
Java Spring Boot 4更新教程_Java Spring Boot 4有哪些新特性

Spring Boot 是一个基于 Spring 框架的 Java 开发框架,它通过 约定优于配置的原则,大幅简化了 Spring 应用的初始搭建、配置和开发过程,让开发者可以快速构建独立的、生产级别的 Spring 应用,无需繁琐的样板配置,通常集成嵌入式服务器(如 Tomcat),提供“开箱即用”的体验,是构建微服务和 Web 应用的流行工具。

150

2025.12.22

Java Spring Boot 微服务实战
Java Spring Boot 微服务实战

本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。

271

2025.12.24

Spring Boot企业级开发与MyBatis Plus实战
Spring Boot企业级开发与MyBatis Plus实战

本专题面向 Java 后端开发者,系统讲解如何基于 Spring Boot 与 MyBatis Plus 构建高效、规范的企业级应用。内容涵盖项目架构设计、数据访问层封装、通用 CRUD 实现、分页与条件查询、代码生成器以及常见性能优化方案。通过完整实战案例,帮助开发者提升后端开发效率,减少重复代码,快速交付稳定可维护的业务系统。

33

2026.02.11

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 850人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号