前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[错误信息详细示例 ]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
ClickHouse
...恢复数据。 四、代码示例 下面是一个简单的ClickHouse查询示例: sql SELECT event_date, SUM(event_count) as total_event_count FROM events GROUP BY event_date; 这个查询语句会统计每天的事件总数,并按照日期进行分组。虽然ClickHouse在查询速度上确实是个狠角色,但当我们要对付海量数据的时候,还是得悠着点儿,注意优化查询策略。就拿那些不必要的JOIN操作来说吧,能省则省;还有索引的使用,也得用得恰到好处,才能让这个高性能的家伙更好地发挥出它的实力来。 五、总结 ClickHouse是一款功能强大的高性能数据库系统,它为我们提供了构建高可用性架构的可能性。不过呢,实际操作时咱们也要留心,挑对数据库系统只是第一步,更关键的是,得琢磨出一套科学合理的架构设计方案,还得写出那些快如闪电的查询语句。只有这样,才能确保系统的稳定性与高效性,真正做到随叫随到、性能杠杠滴。
2023-06-13 12:31:28
558
落叶归根-t
Netty
...代,大量的数据交换和信息传递是必不可少的,而网络通信协议就是这一过程中至关重要的桥梁。其实呢,Netty是个超级厉害的网络应用框架,它干起活来异步事件驱动,效率贼高。别看它就一个框架,本事可大了去了,不仅能轻松应对TCP、UDP这些协议,还自带各种贴心高级功能。比如,像咱们体检时的心跳检测,还有数据传输过程中的重传机制,都是人家Netty手到擒来的小技能。今天,我们就来聊聊如何在Netty中实现客户端连接池。 二、什么是客户端连接池? 客户端连接池是一种在应用程序启动时预先建立一批连接,并将这些连接存储在一个池子中,然后应用程序在需要的时候从这个池子中获取一个可用的连接来发送请求的技术。这种方式能够超级有效地缩短新建连接的时间,让整个系统的运行表现和反应速度都像火箭一样嗖嗖提升。 三、在Netty中如何实现客户端连接池? 实现客户端连接池的方式有很多,我们可以使用Java内置的并发工具类ExecutorService或者使用第三方库如HikariCP等。这里我们主要讲解一下如何使用Netty自带的Bootstrap来实现客户端连接池。 四、使用Bootstrap创建连接池 首先,我们需要创建一个Bootstrap对象: java Bootstrap b = new Bootstrap(); b.group(new NioEventLoopGroup()) // 创建一个新的线程池 .channel(NioSocketChannel.class) // 使用NIO Socket Channel作为传输层协议 .option(ChannelOption.SO_KEEPALIVE, true) // 设置Keepalive属性 .handler(new ChannelInitializer() { @Override public void initChannel(SocketChannel ch) throws Exception { ch.pipeline().addLast(new HttpClientCodec()); // 添加编码解码器 ch.pipeline().addLast(new HttpObjectAggregator(65536)); // 合并Http报文 ch.pipeline().addLast(new HttpResponseDecoder()); ch.pipeline().addLast(new HttpRequestEncoder()); ch.pipeline().addLast(new MyHandler()); // 添加自定义处理程序 } }); 在这个例子中,我们创建了一个新的线程池,并设置了NIO Socket Channel作为传输层协议。同时呢,我们还贴心地塞进来一些不可或缺的通道功能选项,比如那个Keepalive属性啦,还有些超级实用的通道处理器,就像HTTP的编码解码小能手、聚合器大哥、解码器小弟和编码器老弟等等。 接下来,我们可以使用bootstrap.connect(host, port)方法来创建一个新的连接。不过呢,如果我们打算创建多个连接的话,直接用这个方法就不太合适啦。为啥呢?因为这样会让我们一个个手动去捯饬这些连接,那工作量可就海了去了,想想都头疼!所以,我们需要一种方式来批量创建连接。 五、批量创建连接 为了批量创建连接,我们可以使用ChannelFutureGroup和allAsList()方法。ChannelFutureGroup是一个接口,它的实现类代表一组ChannelFuture(用于表示一个连接的完成状态)。我们可以将所有需要创建的连接的ChannelFuture都添加到同一个ChannelFutureGroup中,然后调用futureGroup.allAsList().awaitUninterruptibly();方法来等待所有的连接都被成功创建。 六、使用连接池 当我们有了一个包含多个连接的ChannelFutureGroup之后,我们就可以从中获取连接来发送请求了。例如: java for (Future future : futureGroup) { if (!future.isDone()) { // 如果连接还没有被创建 continue; } try { final SocketChannel ch = (SocketChannel) future.get(); // 获取连接 // 使用ch发送请求... } catch (Exception e) { e.printStackTrace(); } } 七、总结 总的来说,通过使用Bootstrap和ChannelFutureGroup,我们可以很方便地在Netty中实现客户端连接池。这种方法不仅可以大大提高系统的性能,还可以简化我们的开发工作。当然啦,要是你的需求变得复杂起来,那估计你得进一步深入学习Netty的那些门道和技巧,这样才能妥妥地满足你的需求。
2023-12-01 10:11:20
85
岁月如歌-t
转载文章
...表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。 SparkGraphX快速入门 1、图(GraphX) 1.1、基本概念 图是由顶点集合(vertex)及顶点间的关系集合(边edge)组成的一种数据结构。 这里的图并非指代数中的图。图可以对事物以及事物之间的关系建模,图可以用来表示自然发生的连接数据,如:社交网络、互联网web页面 常用的应用有:在地图应用中找到最短路径、基于与他人的相似度图,推荐产品、服务、人际关系或媒体。 2、术语 2.1、顶点和边 一般关系图中,事物为顶点,关系为边 2.2、有向图和无向图 在有向图中,一条边的两个顶点一般扮演者不同的角色,比如父子关系、页面A连接向页面B; 在一个无向图中,边没有方向,即关系都是对等的,比如qq中的好友。 GraphX中有一个重要概念,所有的边都有一个方向,那么图就是有向图,如果忽略边的方向,就是无向图。 2.3、有环图和无环图 有环图是包含循环的,一系列顶点连接成一个环。无环图没有环。在有环图中,如果不关心终止条件,算法可能永远在环上执行,无法退出。 2.4、度、出边、入边、出度、入度 度表示一个顶点的所有边的数量 出边是指从当前顶点指向其他顶点的边 入边表示其他顶点指向当前顶点的边 出度是一个顶点出边的数量 入度是一个顶点入边的数量 2.5、超步 图进行迭代计算时,每一轮的迭代叫做一个超步 3、图处理技术 图处理技术包括图数据库、图数据查询、图数据分析和图数据可视化。 3.1、图数据库 Neo4j、Titan、OrientDB、DEX和InfiniteGraph等基于遍历算法的、实时的图数据库; 3.2、图数据查询 对图数据库中的内容进行查询 3.3、图数据分析 Google Pregel、Spark GraphX、GraphLab等图计算软件。传统的数据分析方法侧重于事物本身,即实体,例如银行交易、资产注册等等。而图数据不仅关注事物,还关注事物之间的联系。例如& 本篇文章为转载内容。原文链接:https://blog.csdn.net/qq_41851454/article/details/80388443。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-07-30 14:45:06
181
转载
转载文章
...表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。 前言 最近在打游戏的时候经常会遇到断网的情况,每次都需要切出去切换wifi,很烦人,所以就写了个用Python自动切换可用的wifi来减少困扰。 几个系统命令 这次我们是使用python中的os模块来模拟命令行来执行命令切换wifi,所以在写程序之前,可以先了解一下几个命令。 查看当前wifi:netsh wlan show interfaces查看所有wifi:netsh wlan show profiles连接wifi:netsh wlan connect name="wifi名称" 思路 这次我们写的程序的主要思路如下: 1.获取当前wifi2.测试当前wifi能否ping通百度3.如果能ping通则等待5s后继续测试4.如果ping不通则在能够连接的wifi中随机选择一个来连接 代码 获取当前wifi import osimport subprocessdef get_current_wifi():cmd = 'netsh wlan show interfaces'p = subprocess.Popen(cmd,stdin=subprocess.PIPE,stdout=subprocess.PIPE,stderr=subprocess.PIPE,shell=True)ret = p.stdout.read()index = ret.find("SSID")if index > 0:return ret[index:].split(':')[1].split('\r\n')[0].strip()else:return None 这里我们使用subprocess.Popen函数来模拟执行命令行命令,并通过read()方法得到命令行的结果,接着对结果进行分析可以得到当前的wifi。 测试能否ping通 def check_ping(ip, count=1, timeout=1000):cmd = 'ping -n %d -w %d %s > NUL' % (count, timeout, ip)res = os.system(cmd)return 'ok' if res == 0 else 'failed' 这里我们首先构建了一个cmd命令来ping我们自己传递过来的ip地址,然后使用os.system()函数执行该命令,如果返回值为0则ping通,否则失败。 自动切换wifi import randomdef auto_switch_wifi(wifiList):wifi = random.choice(wifiList)cmd = 'netsh wlan connect name={}".format(wifi)res = os.system(cmd)return 'ok' if res == 0 else 'failed' 在auto_switch_wifi()函数中,我们接收一个可用的wifi列表,然后再列表中随机选择一个wifi进行切换,如果成功则返回ok。 到这里我们的几大基本模块已经写完了,下面上完整代码。 __ coding:utf-8 __import osimport timeimport subprocessimport randomdef check_ping(ip, count=1, timeout=1000):cmd = 'ping -n %d -w %d %s > NUL' % (count, timeout, ip) 通过os.system()方法执行命令response = os.system(cmd)return 'ok' if response == 0 else 'failed'def get_current_wifi():cmd = 'netsh wlan show interfaces'p = subprocess.Popen(cmd,stdin=subprocess.PIPE,stdout=subprocess.PIPE,stderr=subprocess.PIPE,shell=True)ret = p.stdout.read()index = ret.find('SSID')if index > 0:return ret[index:].split(':')[1].split('\r\n')[0].strip()def auto_switch_wifi(wifiList):wifi = random.choice(wifiList)cmd = 'netsh wlan connect name="%s"' % wifires = os.system(cmd)return 'ok' if res == 0 else 'failed'def main(): 百度ipipTest = '61.135.169.121' 可以切换的wifiwifiList = ['HUAWEI-5DD8']while True:current_wifi = get_current_wifi()print "当前的wifi为:", current_wifiif check_ping(ipTest, 2) != 'ok':print "联网失败,正在切换wifi"if auto_switch_wifi(wifiList) == 'ok':print "切换成功"print "-" 40else:continuetime.sleep(5)else:print "可以成功联网"print '-' 40time.sleep(5)if __name__ == "__main__":main() 总结 人生苦短,我用python!代码还有可以完善的地方,如果想要扩展更多功能的童鞋可以自己探索哈! 本篇文章为转载内容。原文链接:https://blog.csdn.net/qq_34377830/article/details/82497457。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2024-01-14 10:28:12
81
转载
c#
...2. SQL语句编写错误 即使数据本身没有问题,如果SQL语句的语法有误,也会导致插入失败。 四、解决方案 对于上述问题,我们可以采取以下几种解决方案: 1. 数据验证 在插入数据之前,我们应该先对数据进行验证,确保其类型、格式和数量都符合预期。可以使用C的条件语句或异常处理机制来进行数据验证。 csharp public void InsertData(string name, int age) { if (string.IsNullOrEmpty(name)) { throw new ArgumentException("Name cannot be null or empty."); } // 更多的数据验证... using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); string sql = "INSERT INTO Customers (Name, Age) VALUES (@name, @age)"; SqlCommand command = new SqlCommand(sql, connection); command.Parameters.AddWithValue("@name", name); command.Parameters.AddWithValue("@age", age); command.ExecuteNonQuery(); } } 2. 使用参数化查询 为了防止SQL注入攻击,我们应该使用参数化查询而不是直接拼接SQL语句。这样一来,我们不仅能确保数据库的安全无虞,还能有效防止由于胡乱拼接字符串引发的SQL语句语法错误,让一切运行得更加顺畅、不出岔子。 csharp public void InsertData(string name, int age) { using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); string sql = "INSERT INTO Customers (Name, Age) VALUES (@name, @age)"; SqlCommand command = new SqlCommand(sql, connection); command.Parameters.AddWithValue("@name", name); command.Parameters.AddWithValue("@age", age); command.ExecuteNonQuery(); } } 3. 错误处理 无论我们的代码多么严谨,都无法完全避免所有的错误。因此,我们应该为可能发生的错误做好准备,比如捕获并处理异常。 csharp public void InsertData(string name, int age) { try { // 插入数据... } catch (Exception ex) { Console.WriteLine("An error occurred: {0}", ex.Message); } } 五、总结 总的来说,封装SqlHelper类时遇到插入数据的问题并不罕见,但只要我们了解了出现问题的原因,并采取适当的解决措施,就可以有效地规避这些问题。记住,好的编程习惯和技术技巧是我们成功的关键,所以,让我们从现在开始,努力提升自己的编程技能吧!
2023-06-22 20:26:47
409
素颜如水_t
Gradle
...过特定的任务配置(如示例中的fatJar任务),可以将应用本身以及所有运行时需要的依赖库一起打包到同一个jar文件中。这样生成的jar文件包含了运行应用程序所需的所有内容,因此可以直接运行,无需额外提供依赖库,极大地简化了部署流程和环境配置。
2023-06-09 14:26:29
408
凌波微步_
转载文章
...表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。 1、Aptana Studio AptanaStudio 是一个基于 Eclipse 的集成式 Web 开发环境,其最广为人知的是它非常强悍的 JavaScript 编辑器和调试器。它是一个“开放网络的开源开发工具”,在实践中,它意味着它更多的是专门的 web 开发高级 IDE。 AptanaStudio 可以支持多种 AJAX 和 JavaScript 工具箱,包括 JavaScript 编辑和调试。此外,Aptana还吸收了 Radrails 项目,添加了非常强大的 RubyonRails 支持。它还有功能完备的 iPhone 集成开发功能,以及支持 Adobe 公司的 AIR 开发环境。 开源协议: GPL 2、BlueGriffon BlueGriffon 是一个所见即所得编辑器,由 Gecko 提供支持,Mozilla Firefox 中包含相同的渲染引擎。它是现在已经停止更新的 HTML 编辑器 Nvu 的衍生品,支持 HTML5 以及 CSS 的现代组件。 BlueGriffon 可用于大多数主要平台,包括 Windows 7、8 和 10,OS X >= 10.8,Ubuntu 16.04 32 位和64 位,支持简体中文。软件开源,用户使用手册是收费的。 开源协议:GPLv2 3、Firebug Firebug 是 Firefox 下的一款开发类插件,现属于 Firefox 的五星级强力推荐插件之一。它集 HTML 查看和编辑、Javascript 控制台、网络状况监视器于一体,是开发 JavaScript、CSS、HTML 和 Ajax 的得力助手。 Firebug 从各个不同的角度剖析 Web 页面内部的细节层面,给 Web 开发者带来很大的便利。 开源协议:BSD 4、Adobe Brackets Brackets 是 Adobe 的开源 HTML/CSS/JavaScript 集成开发环境。Brackets 当前为 Mac、Windows 以及 Linux (Debian/Ubuntu) 提供最新稳定版的二进制发布。 Brackets 是一个轻量级,但功能强大的文本编辑器。 它将可视化工具集成到编辑器中,以便在不影响创作过程的情况下获得所需的帮助。 开源协议:MIT 本文转自:https://www.oschina.net/ 更多内容请点击查看原文 本篇文章为转载内容。原文链接:https://blog.csdn.net/cocacola456/article/details/53432970。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-02-12 17:23:46
138
转载
Nacos
...会自动检测用户的登录信息,并将其存储在本地的配置文件中。当你改了密码之后,Nacos这个小家伙就会屁颠屁颠地用新密码去打开配置文件。不过呢,配置文件里还记着旧密码,这下旧密码就不管用了,于是乎,服务也就启动不了啦,就像你拿着过期的钥匙开不了新锁一样。 四、解决方案 知道了问题的原因,我们就可以开始寻找解决办法了。首先,我们需要知道Nacos在哪里保存了用户的登录信息。这通常可以在Nacos的配置文件中找到。在本文中,我们将假设你的Nacos使用的是MySQL作为其数据存储。 在Nacos的配置文件application.properties中,我们可以看到以下内容: css spring.datasource.url=jdbc:mysql://localhost:3306/nacos?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC spring.datasource.username=nacos spring.datasource.password=nacos 这里可以看到,Nacos的登录信息(用户名和密码)被保存在了MySQL数据库中,其中数据库的名字为nacos,用户名和密码分别为nacos。因此,我们需要先在MySQL中更新这两个用户的信息。 五、操作步骤 接下来,我们就来具体介绍一下如何在MySQL中更新Nacos的登录信息。 1. 登录到MySQL服务器,然后选择名为nacos的数据库。 python mysql -u root -p use nacos; 2. 修改用户名和密码。在这个例子中,我们将用户名改为new-nacos,密码改为new-nacos-password。 sql update user set password='new-nacos-password' where username='nacos'; update user set authentication_string='MD5(new-nacos-password)' where username='new-nacos'; 3. 最后,我们需要刷新MySQL的权限表,以便让Nacos能够正确地识别新的用户名和密码。 bash flush privileges; 六、测试验证 完成上述步骤后,我们就可以尝试重新启动Nacos服务了。要是顺顺利利的话,你现在应该已经成功登录到Nacos的控制台了,而且你改的新密码也妥妥地生效啦! 七、总结 总的来说,Nacos修改密码后服务无法启动的问题并不难解决,只需要我们按照正确的步骤进行操作就可以了。不过,你要知道,每个人的环境和配置都是独一无二的,所以在实际动手操作时,可能会遇到些微不同的情况。如果你在尝试上述步骤的过程中遇到了任何问题,欢迎随时向我提问,我会尽我所能为你提供帮助。
2023-06-03 16:34:08
184
春暖花开_t
Gradle
...咱们会手把手,用超级详细的实例代码和接地气的探讨方式,一步步带你玩转Gradle项目中的依赖管理和打包技巧,包你学得明明白白、稳稳妥妥。 1. 初始化Gradle项目 首先,我们需要创建一个新的Gradle项目。这里我们采用的是初始化一个简单的Java项目为例: bash mkdir my_project cd my_project gradle init --type java-application 这将在当前目录下生成一个基本的Gradle Java应用项目结构,其中build.gradle文件就是我们用来配置项目依赖的地方。 2. 添加依赖到build.gradle文件 2.1 添加本地库依赖 如果你有一个本地的JAR包需要添加为依赖,可以如下操作: groovy dependencies { implementation files('libs/my-local-library.jar') } 上述代码意味着Gradle在编译和打包时会自动将'libs/my-local-library.jar'包含进你的项目中。 2.2 添加远程仓库依赖 通常情况下,我们会从Maven Central或JCenter等远程仓库获取依赖。例如,要引入Apache Commons Lang库,我们可以这样做: groovy repositories { mavenCentral() // 或者 jcenter() } dependencies { implementation 'org.apache.commons:commons-lang3:3.9' } 在这里,Gradle会在mavenCentral仓库查找指定groupId(org.apache.commons)、artifactId(commons-lang3)和version(3.9)的依赖,并将其包含在最终的打包结果中。 3. 理解依赖范围 Gradle中的依赖具有不同的范围,如implementation、api、runtime等,它们会影响依赖包在不同构建阶段是否被包含以及如何传递给其他模块。例如: groovy dependencies { implementation 'com.google.guava:guava:29.0-jre' // 只对本模块编译和运行有效 api 'junit:junit:4.13' // 不仅对本模块有效,还会暴露给依赖此模块的其他模块 runtime 'mysql:mysql-connector-java:8.0.25' // 只在运行时提供,编译阶段不需 } 4. 执行打包并验证依赖 完成依赖配置后,我们可以通过执行gradle build命令来编译并打包项目。Gradle会根据你在build.gradle中声明的依赖进行解析和下载,最后将依赖与你的源码一起打包至输出的.jar或.war文件中。 为了验证依赖是否已成功包含,你可以解压生成的.jar文件(或者查看.war文件中的WEB-INF/lib目录),检查相关的依赖库是否存在。 结语 Gradle的依赖管理机制使得我们在打包项目时能轻松应对各种复杂场景下的依赖问题。掌握这项技能,可不只是提升开发效率那么简单,更能像给项目构建上了一层双保险,让其稳如磐石,始终如一。在整个捣鼓配置和打包的过程中,如果你能时刻把握住Gradle构建逻辑的脉络,一边思考一边调整优化,你就会发现Gradle这家伙在应对个性化需求时,展现出了超乎想象的灵活性和强大的力量,就像一个无所不能的变形金刚。所以,让我们带着探索和实践的热情,深入挖掘Gradle更多的可能性吧!
2024-01-15 18:26:00
435
雪落无痕_
Kibana
...查原因(举例说明) 示例1:查询语句分析 json GET /my_index/_search { "query": { "match_all": {} }, "size": 5000 } 上述代码是一个简单的match_all查询,试图从my_index中获取5000条记录。如果您的索引数据量巨大,这样的查询将会消耗大量资源,导致Discover页面加载缓慢。此时,可以尝试优化查询条件,比如添加时间范围过滤、字段筛选等。 示例2:检查Elasticsearch性能指标 借助Elasticsearch的监控API,我们可以获取节点、索引及查询的性能指标: bash curl -X GET 'localhost:9200/_nodes/stats/indices,query_cache?human&pretty' 通过观察查询缓存命中率、分片分配状态以及CPU、内存使用情况,可以帮助我们判断是否因ES集群性能瓶颈导致Discover加载慢。 4. 解决策略与实践 策略1:优化查询条件与DSL 确保在Discover页面使用的查询语句高效且有针对性。例如,使用range查询限定时间范围,使用term或match精确匹配特定字段,或利用bool查询进行复杂的组合条件过滤。 策略2:调整Elasticsearch集群配置 - 增加硬件资源,如提升CPU核数、增加内存大小。 - 调整索引设置,如合理设置分片数量和副本数量,优化refresh interval以平衡写入性能与实时性需求。 - 启用并适当调整查询缓存大小。 策略3:优化Kibana配置 在Kibana.yml配置文件中,可以对discover页面的默认查询参数进行调整,如设置默认时间范围、最大返回文档数等,以降低一次性加载数据量。 5. 结论与探讨 解决Kibana Discover页面加载数据慢或空白的问题,需要结合实际情况,从查询语句优化、Elasticsearch集群调优以及Kibana自身配置多方面着手。在实际操作的过程中,我们得像个福尔摩斯那样,一探究竟,把问题的根源挖个底朝天。然后,咱们得冷静分析,理性思考,不断尝试各种可能的优化方案,这样才能够让咱们的数据分析之路走得更加顺风顺水,畅通无阻。记住,每一次的成功优化都是对我们技术理解与应用能力的一次锤炼和提升!
2023-08-21 15:24:10
299
醉卧沙场
VUE
...ue // 异步组件示例 const AsyncComponent = () => import('./AsyncComponent.vue'); export default { components: { AsyncComponent } } 上述代码中,AsyncComponent只有在被渲染到视图时才会被真正加载。此外,路由懒加载也是提升Vue应用性能的重要手段。 4. 性能工具的使用与监控 Vue DevTools的威力 最后,Vue DevTools是一款强大的开发者工具,它可以帮助我们深入洞察Vue应用内部的工作原理,定位性能瓶颈。比如,咱们可以通过“组件树”这个小工具,瞅瞅哪些组件被渲染得过于频繁,有点儿劳模转世的感觉;再者呢,利用“性能分析器”这位高手,好好查查哪些生命周期钩子耗时太长,像蜗牛赛跑似的。 综上所述,面对Vue应用可能出现的反应慢问题,我们需要理解Vue的核心机制,合理利用各种API与功能,适时引入性能优化策略,并借助工具进行问题定位与排查。这样操作,咱们的Vue应用才能既塞满各种实用功能,又能确保用户体验丝滑流畅,一点儿不卡顿。记住,优化是个持续的过程,需要我们在实践中不断探索与改进。
2023-02-07 14:18:17
139
落叶归根
DorisDB
...象一下,我们有个用户信息表叫users,里面有个age栏。咱们经常得根据年龄段来捞人,就是找特定年纪的用户。为了提高查询效率,我们可以创建一个针对age列的索引: sql CREATE INDEX idx_users_age ON users (age); 这样,在执行查询时,DorisDB可以直接通过索引来定位需要的数据,而无需扫描整个表,从而减少了网络传输的数据量。 3.4 使用分区表 分区表可以将大数据集分成多个较小的部分,从而提高查询效率。想象一下,我们有个表格叫sales,里面记录了所有的销售情况,还有一个日期栏叫date。每次我们需要查某个时间段内的销售记录时,就得用上这个表格了。为了提高查询效率,我们可以创建一个基于date列的分区表: sql CREATE TABLE sales ( id INT, date DATE, amount DECIMAL(10, 2) ) PARTITION BY RANGE (date) ( PARTITION p2023 VALUES LESS THAN ('2024-01-01'), PARTITION p2024 VALUES LESS THAN ('2025-01-01') ); 这样,在执行查询时,DorisDB只需要扫描相关的分区,而无需扫描整个表,从而减少了网络传输的数据量。 4. 实践经验分享 在实际工作中,我发现以下几点可以帮助我们更好地优化DorisDB的网络带宽使用: - 监控网络流量:定期检查网络流量情况,找出瓶颈所在。可以使用工具如iftop或nethogs来监控网络流量。 - 分析查询日志:通过分析查询日志,找出频繁执行且消耗资源较多的查询,对其进行优化。 - 合理规划集群:合理规划集群的规模和节点分布,避免因节点过多而导致网络带宽竞争激烈。 - 持续学习和实践:DorisDB的技术不断更新迭代,我们需要持续学习新的技术和最佳实践,不断优化我们的系统。 5. 结语 优化DorisDB的网络带宽使用是一项系统工程,需要我们从多方面入手,综合考虑各种因素。用上面说的那些招儿,咱们能让系统跑得飞快又稳当,让用户用起来更爽!希望这篇文章能对你有所帮助,让我们一起努力,让数据流动得更顺畅!
2025-01-14 16:16:03
87
红尘漫步
Netty
...探讨,并结合实际代码示例以增强理解和实践效果。 1. SO_REUSEADDR的含义与作用 首先,让我们揭开SO_REUSEADDR这个神秘面纱。在咱们的TCP/IP协议这套体系里,有个叫SO_REUSEADDR的小功能,可别小瞧它。简单来说,就是允许咱在同一台电脑的不同程序里头,即使之前某个连接还在“TIME_WAIT”这个等待状态没完全断开,也能重新使用同一个IP地址和端口进行绑定。这就像是同一家咖啡馆,即使前一位客人还没完全离开座位,服务员也能让新客人坐到同一个位置上。这对于服务器程序来说,可是个大大的关键点。想象一下,如果服务器突然罢工或者重启了,如果我们没把这个选项给设置好,新的服务在启动时就可能遇到些小麻烦。具体是什么呢?就是那些旧的、还没彻底断开的TIME_WAIT连接可能会霸占着端口不放,导致新服务无法立马投入使用,这样一来,咱的服务连续性和可用性可就大打折扣啦! 2. Netty中的SO_REUSEADDR配置 在Netty中,我们可以通过ChannelOption.SO_REUSEADDR来启用这个特性。下面是一段典型的Netty ServerBootstrap配置SO_REUSEADDR的代码示例: java EventLoopGroup bossGroup = new NioEventLoopGroup(); EventLoopGroup workerGroup = new NioEventLoopGroup(); try { ServerBootstrap b = new ServerBootstrap(); b.group(bossGroup, workerGroup) .channel(NioServerSocketChannel.class) // 配置SO_REUSEADDR选项 .option(ChannelOption.SO_REUSEADDR, true) .childHandler(new ChannelInitializer() { @Override protected void initChannel(SocketChannel ch) throws Exception { // 初始化通道处理器等操作... } }); ChannelFuture f = b.bind(PORT).sync(); f.channel().closeFuture().sync(); } finally { bossGroup.shutdownGracefully(); workerGroup.shutdownGracefully(); } 在这段代码中,我们在创建ServerBootstrap实例后,通过.option(ChannelOption.SO_REUSEADDR, true)设置了SO_REUSEADDR选项为true,这意味着我们的Netty服务器将能够快速地重新绑定到之前被关闭或异常退出的服务器所占用的端口上,显著提升了服务的重启速度和可用性。 3. 应用场景分析及思考过程 想象这样一个场景:我们的Netty服务因某种原因突然宕机,此时可能存在大量未完全关闭的连接在系统中处于TIME_WAIT状态,如果立即重启服务,未配置SO_REUSEADDR的情况下,服务可能会因为无法绑定端口而无法正常启动。当咱们给服务开启了SO_REUSEADDR这个神奇的设置后,新启动的服务就能对那些处于TIME_WAIT状态的连接“视而不见”,直接霸道地占用端口,然后以迅雷不及掩耳之势恢复对外提供服务。这样一来,系统的稳定性和可用性就蹭蹭地往上飙升了,真是给力得很呐! 然而,这里需要强调的是,虽然SO_REUSEADDR对于提升服务可用性有明显帮助,但并不意味着它可以随意使用。当你在处理多个进程或者多个实例同时共享一个端口的情况时,千万可别大意,得小心翼翼地操作,不然可能会冒出一些你意想不到的“竞争冲突”或是“数据串门”的麻烦事儿。因此,理解并合理运用SO_REUSEADDR是每个Netty开发者必备的技能之一。 总结来说,通过在Netty中配置ChannelOption.SO_REUSEADDR,我们可以优化服务器重启后的可用性,减少由于端口占用导致的延迟,让服务在面对故障时能更快地恢复运行。这不仅体现了Netty在实现高性能、高可靠服务上的灵活性,也展示了其对底层网络通信机制的深度掌握和高效利用。
2023-12-02 10:29:34
441
落叶归根
Hibernate
... 4. 解决方案及示例代码 如何正确地在Hibernate中开启并管理事务? 对于上述问题,我们需要在执行更新/删除操作前显式地开启一个事务,并在操作完成后根据业务需求提交或回滚事务。 下面是一个使用Hibernate Session API手动管理事务的例子: java Session session = sessionFactory.openSession(); Transaction transaction = null; try { // 开启事务 transaction = session.beginTransaction(); // 执行删除操作 session.createQuery("delete from User where id = :id").setParameter("id", userId).executeUpdate(); // 提交事务,确认更改 transaction.commit(); } catch (Exception e) { if (transaction != null && transaction.isActive()) { // 如果有异常发生,回滚事务 transaction.rollback(); } throw e; } finally { // 关闭Session session.close(); } 另外,对于更复杂的场景,我们可以借助Spring框架提供的事务管理功能,让事务管理变得更加简洁高效: java @Transactional public void deleteUser(Long userId) { Session session = sessionFactory.getCurrentSession(); session.createQuery("delete from User where id = :id").setParameter("id", userId).executeUpdate(); } 在此例子中,通过Spring的@Transactional注解,我们可以在方法级别自动管理事务,无需手动控制事务的开启、提交和回滚。 5. 结论 理解并正确处理Hibernate中的TransactionRequiredException异常是每个Hibernate开发者必备技能之一。通过妥善处理各项事务,咱们不仅能有效防止这类异常情况的发生,更能稳稳地保证系统数据的完整无缺和一致性,这样一来,整个应用程序就会健壮得像头牛,坚如磐石。希望本文能帮助你在面对类似问题时,能够迅速定位原因并采取恰当措施解决。记住,无论何时,当你打算修改数据库状态时,请始终不忘那个守护数据安全的“金钟罩”——事务。
2023-05-10 14:05:31
575
星辰大海
Nginx
...的Nginx配置文件示例: nginx http { upstream backend { server 192.168.1.1:8080; server 192.168.1.2:8080; } server { listen 80; location / { proxy_pass http://backend; } } } 在这个配置文件中,我们定义了一个名为backend的上游服务器组,它包含两个后端服务器。然后,在server块中,我们指定了监听80端口,并将所有请求转发到backend组。这样一来,当客户端的请求找到Nginx时,Nginx就会按照负载均衡的规则,把请求派给后端的服务器们去处理。 4. Nginx的高级功能 定制化与扩展性 Nginx不仅仅是一个基本的反向代理服务器,它还提供了许多高级功能,可以满足各种复杂的需求。比如说,你可以用Nginx来搞缓存,这样就能少给后端服务器添麻烦,减轻它的负担啦。以下是一个简单的缓存配置示例: nginx location /images/ { proxy_cache my_cache; proxy_cache_valid 200 1h; proxy_pass http://backend; } 在这个配置中,我们定义了一个名为my_cache的缓存区,并设置了对200状态码的响应缓存时间为1小时。这样一来,对于那些静态资源比如图片,Nginx会先看看缓存里有没有。如果有,就直接把缓存里的东西给用户,根本不需要去后台问东问西的。 5. 总结与展望 Nginx带给我的启示 通过这段时间的学习和实践,我对Nginx有了更深入的理解。这不仅仅是个能扛事儿的Web服务器和反向代理,还是应对高并发访问的超级神器呢!在未来的项目中,我相信Nginx还会继续陪伴着我,帮助我们应对各种挑战。希望这篇分享能对你有所帮助,如果你有任何问题或想法,欢迎随时交流! --- 希望这篇文章能够帮助你更好地理解和使用Nginx。如果你有任何疑问或想要了解更多细节,请随时提问!
2025-01-17 15:34:14
71
风轻云淡
Struts2
...rial》一书,书中详细解读了Servlet规范中的过滤器和监听器机制,结合实例分析有助于读者全面掌握这一核心概念,并能灵活应用于各类Web框架之中。 总之,紧跟技术发展趋势,了解过滤器在不同环境和框架下的应用场景及优化策略,将有助于我们更好地运用Struts2或其他框架的过滤器功能,构建出高效稳定的企业级Web应用。
2023-07-17 17:26:48
60
柳暗花明又一村-t
DorisDB
...时记录当前的数据版本信息,在准备提交事务时检查数据版本是否发生变化,如果期间数据被其他事务修改,则认为存在冲突,事务需要重新执行或回滚。这种方法能够提高系统并发处理能力,尤其是在高并发场景下,但由于可能出现较多冲突重试,故适用于并发争用较小的场景。
2023-12-11 10:35:22
482
夜色朦胧-t
Scala
... 3. 运算符重载示例一 自定义向量类的加法 首先,假设我们创建了一个简单的二维向量类: scala class Vector2D(x: Double, y: Double) { def +(that: Vector2D): Vector2D = new Vector2D(this.x + that.x, this.y + that.y) } 上述代码中,我们为Vector2D类定义了一个+方法,它接受另一个Vector2D对象作为参数,并返回一个新的Vector2D对象,代表两个向量相加的结果。这样一来,当我们写v1 + v2时,实际上是在调用v1.+(v2),实现了对加法运算符的重载。 4. 运算符重载示例二 自定义复杂度比较 接下来,我们看一个更复杂的例子,比如我们想在自定义的“任务”类中,用 < 符号来表示任务的优先级比较: scala class Task(val priority: Int, val description: String) { def <(that: Task): Boolean = this.priority < that.priority } val task1 = new Task(3, "Do laundry") val task2 = new Task(1, "Feed the cat") if (task1 < task2) println(s"${task1.description} has higher priority!") 在这个例子中,我们定义了一个<方法,用于比较两个任务的优先级。所以,在条件判断的时候,task1 < task2已经不是老套的字节码或者整数之间的较量了,而是按照我们自定义的方式来决定谁该排前面,谁该让位。这就像是我们在玩一场游戏,规则由我们自己定,哪个任务优先级更高,不再是由它们本身的数字大小说了算,而是看我们怎么给它们排座次。 5. 小结与思考 通过以上两个实例,我们可以看到Scala的运算符重载是如何让我们能够根据实际需求重新定义运算符的行为。这个特点让代码变得更加简单易懂,就像咱们人类一瞧就明白的那样,而且还给代码表达力来了个大升级,让它更能“说”出程序员的心声。 但值得注意的是,虽然运算符重载能极大提高代码的可读性和编写效率,但也可能导致潜在的混淆。所以,在我们设计和实现的时候,得悠着点儿选择什么时候、怎么去搞运算符重载这事儿。重点是,咱得保证这个重载后的运算符行为跟原本那个运算符的基本含义保持逻辑上的一致性,这样一来,其他开发者瞅见了也能秒懂,方便他们后续的维护工作。 总结一下,Scala中重载运算符的过程其实就是在自定义类中定义相应名称的方法,通过这种方式,我们可以使运算符服务于特定场景,进一步提升代码的灵活性和表现力。希望这篇讲得既透彻又易懂的文章,能实实在在地在你未来的Scala编程冒险中,助你更溜地运用运算符重载这个超级给力的工具,让编程变得更轻松有趣。
2023-04-15 13:42:55
137
繁华落尽
NodeJS
...实现了异步处理。当在错误处理或数据流事件(如 data 和 end )上设置回调函数时,可以确保相关逻辑在合适的时机得到执行,而不会阻塞主线程的其他任务。
2023-03-20 14:09:08
124
雪域高原-t
转载文章
...表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。 {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里技术人对外发布原创技术内容的最大平台;社区覆盖了云计算、大数据、人工智能、IoT、云原生、数据库、微服务、安全、开发与运维9大技术领域。","link1":"https://developer.aliyun.com/group/?spm=a2c6h.12883283.1377930.25.7287201c9RKTCi&groupType=other","link":"https://developer.aliyun.com/","icon":"https://img.alicdn.com/tfs/TB1TlXBEkT2gK0jSZPcXXcKkpXa-200-200.png","btn2":"开发者藏经阁","tip":"打通开发者成长路径,学习中心 。全线阿里云技术大牛公开课,立即查看","btn1":"技术与产品技术圈","link2":"https://developer.aliyun.com/topic/ebook?spm=a2c6h.12883283.1362932.15.7287201c9RKTCi","title":"阿里云开发者社区"}],"search":[{"txt":"学习中心","link":"https://developer.aliyun.com/learning?spm=a2c6h.13788135.1364563.41.299f5f24exe3IS"},{"txt":"技能测试中心 ","link":"https://developer.aliyun.com/exam?spm=a2c6h.13716002.1364563.42.6cac18a3JWCM5U"},{"txt":"开发者云 ","link":"https://developer.aliyun.com/adc/?spm=a2c6h.13716002.1364563.59.6b0818a3DV0vzN"},{"txt":"在线编程 ","link":"https://developer.aliyun.com/coding?spm=5176.13257455.1364563.57.701e7facHvqi5r"},{"txt":"学习中心 ","link":"https://developer.aliyun.com/learning?spm=a2c6h.12883283.1364563.41.5f1f201c5CLDCC"},{"txt":"高校计划 ","link":"https://developer.aliyun.com/adc/college/?spm=a2c6h.13716002.1364563.58.6cac18a3JWCM5U"}],"countinfo":{"search":{"length_pc":0,"length":0},"card":{"length_pc":0,"length":0} }} {"$env":{"JSON":{} },"$page":{"env":"production"},"$context":{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里技术人对外发布原创技术内容的最大平台;社区覆盖了云计算、大数据、人工智能、IoT、云原生、数据库、微服务、安全、开发与运维9大技术领域。","link1":"https://developer.aliyun.com/group/?spm=a2c6h.12883283.1377930.25.7287201c9RKTCi&groupType=other","link":"https://developer.aliyun.com/","icon":"https://img.alicdn.com/tfs/TB1TlXBEkT2gK0jSZPcXXcKkpXa-200-200.png","btn2":"开发者藏经阁","tip":"打通开发者成长路径,学习中心 。全线阿里云技术大牛公开课,立即查看","btn1":"技术与产品技术圈","link2":"https://developer.aliyun.com/topic/ebook?spm=a2c6h.12883283.1362932.15.7287201c9RKTCi","title":"阿里云开发者社区"}],"search":[{"txt":"学习中心","link":"https://developer.aliyun.com/learning?spm=a2c6h.13788135.1364563.41.299f5f24exe3IS"},{"txt":"技能测试中心 ","link":"https://developer.aliyun.com/exam?spm=a2c6h.13716002.1364563.42.6cac18a3JWCM5U"},{"txt":"开发者云 ","link":"https://developer.aliyun.com/adc/?spm=a2c6h.13716002.1364563.59.6b0818a3DV0vzN"},{"txt":"在线编程 ","link":"https://developer.aliyun.com/coding?spm=5176.13257455.1364563.57.701e7facHvqi5r"},{"txt":"学习中心 ","link":"https://developer.aliyun.com/learning?spm=a2c6h.12883283.1364563.41.5f1f201c5CLDCC"},{"txt":"高校计划 ","link":"https://developer.aliyun.com/adc/college/?spm=a2c6h.13716002.1364563.58.6cac18a3JWCM5U"}],"countinfo":{"search":{"length_pc":0,"length":0},"card":{"length_pc":0,"length":0} }} } 本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_39884323/article/details/110752404。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-01-31 19:12:04
257
转载
MyBatis
...案。近期,随着《个人信息保护法》的实施,企业对敏感信息加密处理的要求愈发严格。例如,阿里云推出了全面的数据加密服务,不仅支持数据库字段级别的透明加密,还实现了密钥管理和生命周期自动化,有效防止数据泄露风险。 同时,区块链技术在数据加密领域的应用也在逐步深化,其分布式账本和加密算法结合,确保了数据的安全存储与传输。IBM、微软等科技巨头正积极研发基于区块链的数据加密方案,为复杂的企业级数据安全防护提供了新的思路和技术手段。 此外,针对数据库加密算法的选择与优化也是值得探讨的话题。除了文中提到的AES加密算法,还有如RSA、SM2等公钥加密体系在特定场景下的应用研究。不断跟进并采用更为安全高效的加密算法,是保障数据安全的重要一环。 综上所述,在实际操作中运用Mybatis-plus进行多字段加密只是数据安全领域的一小部分实践,而紧跟行业发展趋势,了解并掌握最新的数据加密技术和法规要求,才能更好地为企业和个人数据安全保驾护航。
2023-07-21 08:07:55
149
飞鸟与鱼_t
Go Gin
...的坏家伙,避免我们的信息被偷窥或者泄露出去的风险。当有用户不走“安全通道”,试图通过HTTP来访问我们家的网站时,咱们得像个贴心的小助手那样,帮他们自动拐个弯儿,转跳到更安全的HTTPS地址上去。 二、Go Gin框架中的中间件设计(3) Go Gin的设计理念之一就是“中间件”,这是一种可以插入请求处理流程中执行额外操作的组件。想要实现HTTPS强制跳转这个需求,咱们完全可以动手写一个定制版的中间件来轻松搞定这件事儿。 go package main import ( "github.com/gin-gonic/gin" ) func ForceHTTPSMiddleware() gin.HandlerFunc { return func(c gin.Context) { if c.Request.TLS == nil { // 检查当前请求是否为HTTPS url := "https://" + c.Request.Host + c.Request.URL.String() c.Redirect(301, url) // 若不是HTTPS,则重定向至HTTPS版本 c.Abort() // 中止后续的处理流程 } else { c.Next() // 如果已经是HTTPS请求,继续执行下一个中间件或路由处理函数 } } } 上述代码创建了一个名为ForceHTTPSMiddleware的中间件,该中间件会在每次请求到达时检查其是否为HTTPS请求。如果不是,它将生成对应的HTTPS URL并以301状态码(永久重定向)引导客户端跳转。 三、中间件的使用与部署(4) 接下来,我们要将这个中间件添加到Go Gin引擎中,确保所有HTTP请求都会先经过这个中间件: go func main() { r := gin.Default() // 使用自定义的HTTPS强制跳转中间件 r.Use(ForceHTTPSMiddleware()) // 添加其他路由规则... r.GET("/", func(c gin.Context) { c.JSON(200, gin.H{"message": "Welcome to the secure zone!"}) }) // 启动HTTPS服务器 err := r.RunTLS(":443", "path/to/cert.pem", "path/to/key.pem") if err != nil { panic(err) } } 注意,在运行HTTPS服务器时,你需要提供相应的证书文件路径(如cert.pem和key.pem)。这样,你的Go Gin应用就成功实现了HTTPS强制跳转。 结语(5) 在解决Go Gin框架下的HTTPS强制跳转问题时,我们不仅了解了如何根据实际需求编写自定义中间件,还加深了对HTTPS工作原理的认识。这种带着情感化和技术思考的过程,正是编程的魅力所在。面对每一个技术挑战,只要我们保持探索精神,总能找到合适的解决方案。而Go Gin这个框架,它的灵活性和强大的功能简直就像个超级英雄,在我们实现各种需求的时候,总能给力地助我们一臂之力。
2023-01-14 15:57:07
518
秋水共长天一色
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
ln -s target link
- 创建符号链接。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"