java应用性能优化思路(一)

1.动静分离,将静态资源交给nginx管理,动态请求交给我们开发的应用程序处理;

2.为数据库表常用查询字段添加索引;

3.如果查询的sql语句还打印在控制台,需将日志级别提高到info或error;

复制代码
logging:
  level:
    com.atguigu.gulimall: error

4.使用jvisualvm查看内存、gc回收,看是否有优化的空间,如调大分配给jvm的内存

复制代码
-Xmx1024m -Xms1024m -Xmn512m

其中:

  1. -Xms 为jvm启动时分配的内存,比如-Xms200m,表示分配200M
  2. -Xmx 为jvm运行过程中分配的最大内存,比如-Xms500m,表示jvm进程最多只能够占用500M内存
  3. -Xmn512m 设置年轻代大小512m

5.查看业务逻辑代码,如果代码中存在循环中查询数据库的,则需进行优化,查询数据库涉及到io操作,而循环与数据库进行交互,则产生大量io,会降低性能。此时需结合实际情况,看查库的操作能否只调用一次,然后对查询出来的数据使用stream流的filter进行过滤。

相关推荐
best_virtuoso6 分钟前
PostgreSQL CTE与临时表的概念与区别
数据库·postgresql
点心快奔跑1 小时前
超详细Windows系统MySQL 安装教程
数据库·windows·mysql
超级苦力怕1 小时前
【超详细】Redis下载教程 (Win/Linux)
数据库
codervibe1 小时前
MySQL 命令行连接与企业级远程访问实践(含故障排查与安全策略)
数据库·后端
workflower1 小时前
测试套件缩减方法
数据库·单元测试·需求分析·个人开发·极限编程
Cikiss2 小时前
图解 MySQL JOIN
数据库·后端·mysql
员大头硬花生2 小时前
六、InnoDB引擎-架构-结构
数据库·mysql·oracle
程序新视界3 小时前
在MySQL中,是否可以使用UUID作为主键?
数据库·后端·mysql
晓py3 小时前
InnoDB 事务日志机制全流程详解|从 SQL 到崩溃恢复的完整旅程
数据库·sql·oracle
白帽子黑客杰哥3 小时前
湖湘杯网络安全技能大赛参与形式
数据库·web安全·渗透测试·安全演练·湖湘杯·实战演练