Java项目常见基础问题汇总
- 在 Feign 的实现下,我们只需创建一个接口并使用注解的方式来配置它
- RESTful API 与 SOAP、GraphQL 等其他 API 设计方式各有优劣,发者应根据具体业务需求选择合适的架构
- Dubbo开始于电商系统,大公司
- 在OSI网络通信模型中,RPC跨越了传输层和应用层
- OpenRestry(一个Nginx集成工具)的安装与使用
- Druid是面向海量数据的、用于实时查询与分析的OLAP存储系统,時序數據庫。
- Elastic-Job是当当网推出的分布式任务调度框架,用于解决分布式任务的协调调度问题,保证任务不重复不遗漏地执行
- Nexus是Sonatype公司发布的一款强大的仓库(Repository)管理软件,常被用来搭建Maven私服,因此也被称为“Maven仓库管理器”。
- Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。
- OpenAI 官方宣布正式开源多Agent编排框架 Swarm!
- echarts是百度开发团队制作,开源交给apache基金管理,用来制作图表的JavaScript库。
- Element-UI 是由饿了么前端团队开发的一套基于 Vue.js 的桌面端组件库。提供了一整套 UI 组件,使开发者能够快速构建现代化的 Web 界面。Element-UI 在设计和交互上都有着高水准的表现,广泛应用于企业级应用和后台管理系统中。
- MapGIS 软件是地理信息系统(Geographic Information System,GIS)专业的工具软件之一
- Drools规则引擎的主要思想是将应用程序中的业务决策部分分离出来,并使用预定义的语义模块编写业务决策(业务规则),由用户或开发者在需要时进行配置、管理。 需要注意的是规则引擎并不是一个具体的技术框架,而是指的⼀类系统,即业务规则管理系统。
- Ottter是由阿里开源的一个数据同步产品,它的最初的目的是为了解决跨国异地机房双A架构,两边可写的场景,开发时间从2011年7月份一直持续到现在,目前阿里巴巴B2B内部的本地/异地机房的同步需求基本全上了Otter。Otter基于数据库增量日志解析,支持mysql/oracle数据库进行同步,在最新的v4.2.13已经支持mysql5.7以及阿里云提供的RDS数据库(使用RDS童鞋的福音) //较少
- Quartz是一个框架,是SpringBoot御用的定时任务框架,有三大核心部分组成,分别是Job,Trigger、Scheduler。 //较少
- Nacos是一个开源的动态服务发现、配置和服务管理平台,由阿里巴巴开发和维护。
Nacos支持多种注册中心和配置管理器,包括Spring Cloud Discovery、Dubbo、Kubernetes和Apache ServiceComb等。Nacos提供了REST、gRPC和Java SDK等多种API,使得开发人员可以轻松地与Nacos进行交互
- git是一个分布式的代码版本管理软件。而gitlab上传的项目都是不开源的,属于企业内部的代码,你也是需要企业内部得个人账号才可以登录进去,和同事进行并行开发,提高工作效率。
- Skywalking是一款分布式的系统 性能监视工具,专为微服务、云原生架构和基于容器(Docker、K8s、Mesos)架构而设计。SkyWalking是一款 观察性的分析平台和应用性能管理系统,提供了分布式追踪、性能指标分析、应用服务依赖分析、可视化一体化等解决方案。
- Zuul是来自 Netflix 的基于 JVM 的路由器和服务器端负载均衡器。
- ①Hystrix是一个用于处理分布式系统的延迟和容错的开源库,可以保证一个服务出现故障时,不会导致整个系统出现雪崩效应,以提高分布式系统弹性;
②作为“断路器”,在一个服务出现故障时,可以通过短路器监控,返回一个可以处理的响应结果,保证服务调用线程不会长时间被占用,避免故障蔓延。
- XSS又叫CSS(Cross Site Script)跨站脚本攻击是指恶意攻击者往Web页面里插入恶意Script代码,当用户浏览该页之时,嵌入其中Web里面的Script代码会被执行,从而达到恶意攻击用户的目的。
- Token 的中文意思是"令牌"。主要用来身份验证。比传统的身份验证方法,Token 有扩展性强,安全性高的特点,非常适合用在 Web 应用或者移动应用上。
它是服务端生成的字符串,作为客户端进行请求的一个标识。
- jwt是token的一种实现方式,它将用户信息加密到token里,服务器不保存任何用户信息。服务器通过使用保存的密钥验证token的正确性,只要正确即通过验证。
- WAF与常规防火墙的区别在于,WAF能够过滤特定Web应用程序的内容,而常规防火墙则充当服务器之间的安全门。通过检查HTTP流量,它可以防止源自Web应用程序安全漏洞的攻击,例如SQL注入、跨站点脚本,文件包含和安全性错误配置
- CORS,全称为“跨域资源共享”(Cross-Origin Resource Sharing),是一种机制,它使用额外的 HTTP 头来告诉浏览器允许一个网页从另一个域(不同于该网页所在的域)请求资源。这样可以在服务器和客户端之间进行安全的跨域通信。
- filter也称之为过滤器,它是javaWeb三大组件之一(Servlet程序、Listener监听器、Filter过滤器)作用:既可以对请求进行拦截,也可以对响应进行处理。
- Cluster:数据库集群
- easy-captcha是生成图形验证码的Java类库,支持gif、中文、算术等类型,可用于Java Web、JavaSE等项目。
- Undertow 是一个高性能、灵活且轻量级的Java Web 服务器和 Servlet 容器 //较少
- javax.validation是一套JavaBean参数校验的标准,它定义了很多常用的校验注解,
- Lombok是一个通过注解以达到减少代码的Java库,如通过注解的方式减少get,set方法,构造方法等。
- Java的sel4j是一个日志门面框架,它提供了一种简单的方式来在应用程序中记录日志。它允许开发人员在应用程序中使用统一的日志接 口,而不用关心具体的日志实现。通过使用sel4j,开发人员可以在应用程序中使用不同的日志实现,如Logback、Log4j等,而不需要修改应用程序的代码 //较少
- Logback是一个用于Java应用程序的日志框架 //较少
- Hutool是一个Java工具包类库,对文件、流、加密解密、转码、正则、线程、XML等JDK方法进行封装,组成各种Util工具类 //10w