优秀是一种习惯!!!

Nginx使用问题 有更新!

2023-11-29

Nginx使用问题 一、nginx location @router 在Nginx中,@router是一个特殊的位置(location)。它通常在使用Nginx作为反向代理服务器时使用。@router位置定义了一个命名的位置块,用于处理不匹配其他location的请求。 一般情况下,Nginx的配置文件中会有一些具体的location规则,用来匹配特定的URL,并定义如何处理这些请求。但是如果没有任何location匹配请求的URL,或者没有指定特定的location规则,那么Nginx将会使用默认的规则来处理这些请求。而@router位置就是用来处理这种情况的。 在@router位置块中,你可以编写自定义的逻辑来处理未匹配的请求。通常情况下,@router位置会将请求转发给后端应用服务器处理,或者返回一个自定义的错误页面。 以下是一个使用@router的示例配置: location / { try_files $uri $uri/ @router; # 此处是其他location规则 ... } location @router { # 自定义逻辑处理未匹配的请求 proxy_pas....

JSP问题 有更新!

2023-11-29

JSP问题 一、SSM项目前后端不分离情况下,后端如何控制跳转到指定前端页面 在SSM项目前后端不分离的情况下,后端可以通过控制器方法返回视图名称的方式实现跳转到指定的前端页面。具体实现步骤如下: 1.在Spring MVC配置文件中配置视图解析器,例如使用InternalResourceViewResolver,可以指定前缀和后缀来定位视图。 <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/"/> <property name="suffix" value=".jsp"/> </bean> 2.在Controller类中编写处理请求的方法,该方法返回值为字符串类型,即指定跳转的视图名称。 @RequestMapping("/toPage") public String toPage() { return "pageName"; /....

类使用问题汇总 有更新!

2023-11-29

类使用问题汇总 一、如下内部类,如何在外部给类B中setTitle public class A{ private class B{ private String title; } } 类B只有public时才能 A.B b = a.new B();创建 只有当内部类 B 被声明为公共类时,才能在外部类 A 以外的地方创建 B 的实例。 因此,在外部给类 B 中的 title 属性赋值,需要先创建外部类 A 的实例,然后通过该实例创建内部类 B 的实例,并使用该实例来访问和设置 title 属性。以下是一个示例代码: public class A { public class B { private String title; public void setTitle(String title) { this.title = title; } public String getTitle() { return title; } } public static void main(String[] args) { A a = new A(); A.B b = a.new B(); b.s....

序列化问题汇总 有更新!

2023-11-29

序列化问题汇总 一、用Java将svg图片转图片流返回前端 在Java中,你可以使用第三方库Batik来将SVG图片转换为图片流,并将其返回给前端。以下是一个示例代码: import org.apache.batik.dom.svg.SVGDOMImplementation; import org.apache.batik.transcoder.TranscoderInput; import org.apache.batik.transcoder.TranscoderOutput; import org.apache.batik.transcoder.image.PNGTranscoder; import org.w3c.dom.DOMImplementation; import org.w3c.dom.Document; import org.w3c.dom.Element; import javax.xml.transform.TransformerFactory; import javax.xml.transform.dom.DOMSource; import javax.xml....

集合使用问题汇总 有更新!

2023-11-29

集合使用问题 一、Map数组去重 import java.util.Arrays; import java.util.HashMap; import java.util.Map; public class MapArrayDuplicateRemovalExample { public static void main(String[] args) { // 假设有一个Map数组 Map<String, Integer>[] mapArray = new HashMap[5]; // 初始化Map数组 for (int i = 0; i < mapArray.length; i++) { mapArray[i] = new HashMap<>(); } // 添加一些数据到Map数组中(包含重复的数据) mapArray[0].put("A", 1); mapArray[1].put("B", 2); mapArray[2].put("C", 3); mapArray[3].put("A", 1); mapArray[4].put("D", 4); // ....

网络问题汇总 有更新!

2023-11-29

网络问题汇总 一、http响应头包含些什么 HTTP响应头是HTTP协议中用于响应客户端请求的一部分,通常包含以下信息: 状态行:状态行包含三个部分,分别为HTTP版本、状态码和状态描述。常见的状态码有200(成功)、404(未找到)和500(服务器错误)等。 响应头字段:响应头字段是一个由键值对组成的列表,用于传递一些附加的响应信息,例如日期、内容类型、缓存策略、cookie等。常见的响应头字段有: Content-Type:指定响应正文的类型和字符集; Content-Length:指定响应正文的字节数; Cache-Control:指定缓存策略; Set-Cookie:设置Cookie; Location:重定向URL; Server:指定服务器软件的名称和版本号; 响应正文:响应正文是服务器返回给客户端的实际数据。响应正文的格式和内容根据不同的应用场景和协议规范而异。 HTTP响应头中的各个字段可以用于传递各种额外的信息,例如控制缓存、安全策略、站点隐私等。在实际应用中,合理地使用HTTP响应头可以提高应用程序的性能和安全性。 二、设备到通讯管理机采用MQTT协议合适吗 MQT....

Docker问题汇总 有更新!

2023-11-29

Docker问题汇总 一、查看docker中3000端口是否被占用 要查看 Docker 容器中的端口占用情况,可以使用以下命令来检查容器是否在使用 3000 端口: docker ps -a --filter "expose=3000" 该命令会列出所有的容器,并通过 --filter 参数筛选出暴露了 3000 端口的容器。如果有容器正在使用该端口,将会输出相关信息;如果端口没有被容器占用,则不会有任何输出。 另外,你也可以使用 docker port 命令查询正在运行的容器中特定端口的映射情况。以下是使用 docker port 命令检查容器中的 3000 端口映射的示例: docker ps -a docker port <container_id> 3000 首先使用 docker ps -a 列出所有容器,并找到你想要检查的容器的 ID。然后,将容器 ID 替换到 <container_id> 的位置,运行 docker port 命令来查看该容器中的 3000 端口映射情况。如果该端口被映射到主机上,输出结果会显示映射的 IP 地址和端口号;如....

Kafka使用问题 有更新!

2023-11-29

Kafka使用问题 一、死信队列 死信队列(Dead Letter Queue,简称DLQ)是一种消息中间件的特性,用于处理无法被消费者正确处理的消息。当消息无法被正常消费,并且不能被重新投递给消费者时,这些消息将被发送到死信队列中。 死信队列通常用于以下情况: 消息超时:如果消息在一定时间内没有被消费者处理,可以将其发送到死信队列中。这可能是由于消费者出现故障、网络延迟或消费者无法及时处理消息等原因导致的。 消息消费失败:当消息无法被消费者正确处理时,例如消费者无法解析消息格式、处理消息时发生异常等情况,可以将这些消息发送到死信队列中。 消息达到最大重试次数:有些消息中间件允许设置消息的最大重试次数,当消息达到最大重试次数仍然无法被正确处理时,将其发送到死信队列中。这可以避免消息在系统中无限循环重试,影响系统性能。 通过将无法被消费者处理的消息发送到死信队列,可以让开发人员对这些问题消息进行监控、分析和处理。通常,开发人员会通过监控死信队列中的消息来发现和解决系统中的问题,并对消息进行重新处理或者采取其他措施来确保消息能够被正确地处理。 需要注意的是,死信队列并不是一种绝对安全的解决....

Mybatis使用问题汇总 有更新!

2023-11-29

Mybatis使用问题 一、mybatis获取表数据返回map,用ArrayList<HashMap<String, Object>>接收,数据既有Double类型又有Integer类型,该如何返回相同的类型 在使用 MyBatis 获取表数据返回 Map 时,我们可以通过设置 typeHandler 来指定对应列的数据类型。默认情况下,MyBatis 会将数值型的数据统一解析成 Double 类型,所以需要指定相应的 typeHandler 才能让 MyBatis 返回正确的数据类型。 例如,假设我们的表中有一个字段 age,其中既有 Integer 类型的数据,又有 Double 类型的数据,我们希望在查询时能够返回与数据库中存储的数据类型一致的结果,可以按照以下步骤进行操作: 1.创建自定义的 typeHandler 类,继承 BaseTypeHandler,并指定泛型为 Object。 public class MyNumberTypeHandler extends BaseTypeHandler<Object> { @Override pu....

加密算法问题汇总 有更新!

2023-11-29

加密算法问题 一、base64加密后太长,解决办法? Base64是一种将二进制数据编码为ASCII字符的方法,它的编码结果通常会比原始数据长三分之一左右。因此,如果使用Base64对较大的二进制数据进行编码时,可能会导致编码结果过长。 针对这个问题,可以通过以下几种方式进行优化: 压缩数据:在进行Base64编码之前,先对原始数据进行压缩,可以使用一些常见的算法如Gzip或Deflate等。这样可以在一定程度上减少数据的长度,从而减少Base64编码结果的长度。 分片处理:如果需要将较大的数据进行加密,可以将数据分成若干个较小的块并分别进行Base64编码,然后再将编码结果拼接起来。这样虽然会增加一定的处理时间和代码复杂度,但是可以缩短总体编码结果的长度。 使用其他编码方式:除了Base64外,还有一些其他的编码方式可以将二进制数据编码为ASCII字符,例如Base32、Hexadecimal等。可以根据实际需求选择适合的编码方式。 需要注意的是,在实际应用中,对于较大的二进制数据,最好选择其他更为专业的加密方式,例如SHA算法或AES算法等,以确保数据的安全性和加密的效率。

Spring Cloud问题汇总 有更新!

2023-11-29

Spring Cloud问题汇总 一、Gateway Gateway是Spring Cloud生态中的一个微服务网关,它提供了统一的路由方式,可以将所有的微服务API通过一个入口暴露给外界。Gateway基于Spring 5,基于响应式编程模型构建,使用Spring WebFlux框架提供了Netty服务器。 Gateway主要功能如下: 路由转发:将请求发送到指定的微服务实例。 过滤器处理:使用过滤器处理每个请求,进行自定义逻辑,例如认证、重试等。 断路器处理:提供断路器机制,当某个服务实例出现故障或者负载过高时,可以对请求进行熔断,避免影响整个系统的稳定性。 支持多种协议:支持HTTP、WebSocket等多种协议。 动态路由:支持动态路由,可以根据配置文件动态增加、删除路由规则。 集成服务发现:与Eureka、Consul等服务注册中心集成,自动注册和注销服务实例。 负载均衡:支持负载均衡策略,可以在多个服务实例之间进行分发请求,提高系统的可用性和性能。 总体来说,Gateway是一个非常强大的微服务网关,可以帮助开发人员快速搭建微服务架构,并提供了很多丰富的功能,同时也是Spr....

检索问题汇总 有更新!

2023-11-29

检索问题汇总 一、fact检索 事实检索(Fact Retrieval)是一种信息检索技术,旨在从大规模语料库中提取特定的事实或答案。它与一般的文本检索不同,因为它专注于返回准确的、与查询相关的事实,而不仅仅是相关的文档或文章。 事实检索的目标是根据用户提出的查询,从结构化或非结构化数据中直接检索出最相关的事实。这些数据可以包括知识图谱、数据库、文本文档、网页等。事实检索技术通常需要通过自然语言处理和信息抽取等方法来理解查询和文本,并将其映射到潜在的事实表示形式。 以下是一些常见的事实检索任务: 简单事实检索:根据用户提出的简短查询,例如"谁是美国总统?"或"世界上最高的山峰是哪座?",返回明确的答案,如"乔治·华盛顿"和"珠穆朗玛峰"。 复杂事实检索:处理更复杂的查询,包括多个条件和关系。例如,"哪个演员获得过奥斯卡奖,并且出演了《阿甘正传》?"需要同时满足奥斯卡奖获得者和出演《阿甘正传》这两个条件,返回相关的演员姓名。 实体属性检索:查询特定实体的属性信息。例如,"马拉多纳的国籍是什么?"需要返回"阿根廷"作为答案。 事件时间线检索:根据关键词或实体,检索与特定事件相关的时间线信息....

性能调优问题汇总 有更新!

2023-11-29

性能调优问题汇总 一、java后台如何控制qps 要控制Java后台的QPS(每秒请求量),可以采取以下几种方法: 限流:使用限流算法(如令牌桶算法、漏桶算法)对请求进行限制,确保每秒只能处理一定数量的请求。可以利用开源框架,如Guava RateLimiter或者Spring Cloud Gateway中的限流组件来实现。 线程池管理:通过控制线程池的大小和工作队列长度,限制同时处理的请求数量。可以根据系统负载情况动态调整线程池参数。 缓存:对于一些计算复杂、数据量大且变化不频繁的请求,可以在处理后将结果缓存起来,并设置合适的过期时间,以减轻后端服务器的压力。 异步处理:对于一些耗时较长的请求,可以采用异步处理方式,将请求放入消息队列或者线程池中异步处理,这样可以提高系统的吞吐量。 升级硬件或扩展服务器:如果以上方法无法满足需求,可以考虑升级服务器硬件或者增加服务器的数量,以提高系统的处理能力。 需要根据具体的业务场景和系统需求选择合适的方法进行控制,综合考虑系统的性能、资源消耗和用户体验等因素。 二、

文件处理问题集合 有更新!

2023-11-29

文件处理问题集合 一、简单文件上传01 new FileUtils().upload(file, "/home/nginx/html/resource/", fileName); return Result.success("资源上传成功", resource); public void upload(MultipartFile file, String url, String fileName){ try{ if (file.isEmpty()){ System.out.println("文件为空!"); return; } copyFile(file.getInputStream(), url+fileName); } catch (IOException e) { e.printStackTrace(); } finally { deleteTempFile(file); } } public static boolean copyFile(InputStream is,String newPath){ OutputStream os = null; try { // 1K的数据....

RestAPI与RPC 有更新!

2023-11-28

Rest API与RPC REST API 和 RPC(Remote Procedure Call,远程过程调用)是两种常见的网络通信协议,它们有以下几点区别: 架构风格:REST 是一种基于客户端/服务器模型、无状态、可缓存的架构风格,而 RPC 是一种传统的客户端/服务器模型。 数据交换格式:REST API 通常使用 JSON 或 XML 格式来交换数据,而 RPC 可以使用多种数据格式,例如二进制流、JSON、XML 等。 接口设计:REST API 的接口设计通常基于资源,使用 HTTP 方法(GET、POST、PUT、DELETE 等)来对资源进行操作,而 RPC 的接口设计通常基于方法调用,使用类似于函数调用的方式来实现远程过程调用。 通信方式:REST API 通常基于 HTTP 协议实现,支持多种 HTTP 方法和状态码,而 RPC 可以使用多种传输协议,例如 TCP、UDP、HTTP、WebSocket 等。 总的来说,REST API 更加灵活和通用,可以使用多种编程语言和平台实现,而 RPC 更加高效和专用,通常用于内部系统之间的通信。选择何种协议应该基于实际需....

数据结构刷题 有更新!

2023-11-28

数据结构刷题 一、树 1、94. 二叉树的中序遍历 题目: 给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 示例1: 输入:root = [1,null,2,3] 输出:[1,3,2] 树中节点数目在范围 [0, 100] 内 -100 <= Node.val <= 100 进阶: 递归算法很简单,可以通过迭代算法完成吗? 解答: 方法一: 递归 /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { ....

SQL刷题Day01~Day06 有更新!

2023-11-28

SQL刷题 SQL入门题: Day01选择: 1、1757. 可回收且低脂的产品 题目: 表:Products Column NameType product_idint low_fatsenum recyclableenum product_id 是这个表的主键。 low_fats 是枚举类型,取值为以下两种 ('Y', 'N'),其中 'Y' 表示该产品是低脂产品,'N' 表示不是低脂产品。 recyclable 是枚举类型,取值为以下两种 ('Y', 'N'),其中 'Y' 表示该产品可回收,而 'N' 表示不可回收。写出 SQL 语句,查找既是低脂又是可回收的产品编号。 返回结果 无顺序要求 。查询结果格式如下例所示: Products表: product_idlow_fatsrecyclable 0YN 1YY 2NY 3YY 4NN Result表: product_id 1 3 只有产品 id 为 1 和 3 的产品,既是低脂又是可回收的产品。 解答:关于对称逻辑 方法一: select product_id from products where low_fats = ....

MySQL的RegExp 有更新!

2023-11-28

MySQL之正则表达式 一.介绍 正则表达式用来描述或者匹配符合规则的字符串。它的用法和like比较相似,但是它又比like更强大,能够实现一些很特殊的规则匹配;正则表达式需要使用REGEXP命令,匹配上返回"1"匹配不上返回"0",默认不加条件REGEXP相当于like '%%'。在前面加上NOT相当于NOT LIKE。 命令说明 ^在字符的开启处进行匹配 $在字符的末尾处进行匹配 .匹配任何字符(包括回车和新行) [….]匹配括号内的任意单个字符 [m-n]匹配m到n之间的任意单个字符,例如[0-9],[a-z],[A-Z] [^..]不能匹配括号内的任意单个字符 a*匹配0个或多个a,包括空,可以作为占位符使用. a+匹配一个或多个a,不包括空 a?匹配一个或0个a a1| a2匹配a1或a2 a{m}匹配m个a a{m,}匹配m个或者更多个a a{m,n}匹配m到n个a a{,n}匹配0到n个a (….)将模式元素组成单一元素,例如(do)*意思是匹配0个多或多个do 二 使用测试 ^ 在字符串开始处进行匹配 mysql> SELECT 'abc' REGEXP '^a'....

分布式中间件——ShardingSphere 有更新!

2023-11-28

分布式中间件——ShardingSphere 一、ShardingSphere介绍 1、Apache ShardingSphere Apache ShardingSphere是一个开源生态系统,允许您将任何数据库转换为分布式数据库系统,并通过分片、弹性扩展、加密功能等对其进行增强。该项目包括一个 JDBC、一个代理和 Sidecar(规划)。由于其面向插件的架构,功能可以随意灵活扩展。 几乎所有数据库都受支持,包括 MySQL、PostgreSQL、SQL Server、Oracle 数据库、MariaDB 或任何其他 SQL-92 数据库。Apache ShardingSphere 社区致力于通过插件增强现有数据库的计算和存储能力以及核心功能来提供生态系统和服务平台。 2、ShardingSphere JDBC 定位轻量级Java框架,在Java的JDBC层提供额外的服务。它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可以理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。 适用于任何基于JDBC的ORM框架,如 JPA、Hibernate、MyBat....

表结构设计之主键的选择(1)——避坑UUID 有更新!

2023-11-28

表结构设计之分布式的主键生成策略的选择(1)——避坑UUID UUID作为主键,再插入数据的时候对于系统的压力是非常大的。如在某个时间点时会出现磁盘的IO异常,导致应用经常出现高延迟。 UUID(全球唯一标识符 Universally Unique Identifier):00000000-0000-0000-0000-000000000000共8+4+4+4+12=32位,业界主要有5中UUID的生成机制: 5种UUID的生成机制 基于时间的UUID 能保证不同设备UUID是唯一的 在同一设备上生成UUID可能重复 利用时间戳 和 设备的具体特性生成唯一编号。 不同设备上因为其环境不同,可以保证UUID是唯一的。 但是在极端环境下:同一设备同一毫秒时间下它生成的UUID就可能会出现重复。因此,如果是超高并发的系统,这种情况还不少。 所以实际开发中不怎么使用基于时间的UUID DCE安全的UUID DCE(身份验证和安全服务) 涉及侵犯用户隐私 有损时间戳导致精度丢失 DCE即使用用户的某些特征(用户名、邮箱等相关的身份标识)来生成,欧美广泛抵制。 所以实际开发中不怎么使用DCE安全的....