前端技术
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
[Mark Russinovich开发的系...]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
Gradle
...L语法的开源构建自动化工具。在Java开发领域中,它被广泛用于项目构建、依赖管理和自动化任务执行。通过灵活且强大的构建脚本,Gradle支持多项目构建、增量构建以及自定义构建生命周期,使得开发者能够高效地组织、配置和优化其项目的构建过程。 传递依赖(Transitive Dependency) , 在软件开发中,特别是在使用构建工具如Gradle管理项目依赖时,传递依赖是指当你直接依赖某个库时,该库会自动将其自身的所有依赖项引入到你的项目中。例如,在Gradle中声明对A库的依赖时,如果A库又依赖了B和C库,那么B和C就构成了传递依赖。虽然传递依赖简化了依赖管理,但也可能导致版本冲突等问题,因此需要进行合理的管理和控制。 Maven Central , Maven Central是Java开发中最主要的开源组件仓库之一,由Sonatype公司维护。它是Maven默认的中央仓库,包含了大量经过验证的开源Java组件及其元数据信息。开发者在使用Gradle等构建工具时,可以方便地从Maven Central下载所需的第三方库,确保项目的构建和运行具有充足的依赖支持。当在Gradle配置文件中声明远程仓库时不特别指定其他地址时,默认会去Maven Central查找依赖。
2023-12-14 21:36:07
336
柳暗花明又一村_
Go Iris
...bernetes生态系统中的Istio服务网格就支持gRPC作为其主要通信方式之一,进一步提升了分布式系统间的通信效率和可管理性。 此外,Google于今年初发布了gRPC 1.40版本,该版本引入了对HTTP/3协议的支持,这意味着gRPC将在未来拥有更低延迟和更强的网络容错能力。同时,为了更好地服务于异构系统间的互操作,gRPC还加强了与其他API规范(如GraphQL)的集成与转换工具支持。 对于希望深化gRPC技术应用的开发者而言,不仅可以通过查阅官方文档获取最新特性及最佳实践,还可以关注各大技术社区的相关讨论与案例分享,比如InfoQ、CNCF博客等平台都提供了许多关于gRPC实战与优化的深度解读文章。通过持续跟进gRPC的发展动态和技术趋势,开发者能够不断提升自身构建高性能、高可用分布式服务的能力。
2023-04-20 14:32:44
451
幽谷听泉-t
Superset
...后,您可能对数据分析工具的自动化报告和通知功能有了更全面的认识。实际上,这一功能在现代企业中具有极高的实用价值,特别是在实时业务监控、异常检测以及关键数据洞察分享等方面。 近日,Apache Superset社区发布了新版本更新,其中强化了与多种电子邮件服务提供商的集成能力,包括但不限于Office 365、Gmail和企业内部部署的SMTP服务器,使得用户能够更加灵活、安全地进行邮件通知设置。此外,新版本还优化了邮件模板定制功能,支持图表内嵌、自定义样式和动态内容,让数据分析师能够创建更具专业性和交互性的邮件报告。 对于进一步提升工作效率,建议探索更多与Superset配合使用的自动化工作流工具,例如Airflow和Zapier等,它们可以将Superset的数据分析结果无缝集成到企业的自动化流程中,实现从数据分析到决策执行的快速流转。同时,随着DevOps和DataOps理念的普及,掌握如何在持续集成/持续交付(CI/CD)环境中配置和管理Superset的邮件通知系统,也成为现代数据工程师必备技能之一。 总之,借助强大的数据分析工具如Superset,并结合高效的邮件通知机制,企业和团队能更好地利用数据驱动决策,及时响应市场变化,从而在瞬息万变的商业环境中保持竞争力。
2023-10-01 21:22:27
61
蝶舞花间-t
Superset
...的支持,并针对其服务优化了数据库连接性能。例如,AWS发布了针对Redshift数据仓库的SQLAlchemy适配器更新,显著提升了Superset在处理大规模数据查询时的速度和稳定性。 同时,在数据安全方面,随着全球对企业数据保护法规(如GDPR、CCPA)的严格实施,用户在使用Superset构建数据源连接时,不仅需要关注URI设置,更应关注如何通过配置加密连接、权限管理和审计日志等功能来满足合规要求。为此,SQLAlchemy官方文档及时更新了一系列关于如何在连接字符串中启用SSL/TLS加密以及整合企业级身份认证系统的指南。 此外,对于那些寻求深度定制和扩展Superset功能的企业,可参考业界专家对开源生态中Superset插件开发、集成第三方BI工具以及利用容器化技术部署Superset生产环境等方面的深入解读。这些内容不仅能够帮助您提升Superset在实际项目中的效能,还能助您紧跟大数据时代下快速发展的技术和行业趋势,充分挖掘和发挥数据资产的价值。
2024-03-19 10:43:57
53
红尘漫步
Redis
...在部署过程中采用自动化工具进行版本管理和配置验证,确保环境一致性;同时,通过日志审计和监控告警系统实时跟踪Sentinel的状态,以便快速定位并解决潜在问题。 此外,值得注意的是,随着Kubernetes等容器编排技术的广泛应用,许多企业开始探索在K8s平台上部署和管理Redis Sentinel的新模式,这要求开发者不仅要深入理解Redis本身的特性,还需熟悉容器化环境下的服务治理逻辑,以确保在复杂分布式环境下实现Redis高可用性的最大化。 总之,持续关注Redis官方更新动态,结合实际应用场景进行深度实践与优化,是有效避免Redis Sentinel配置错误及无法启动等问题的关键所在,从而助力企业在瞬息万变的技术浪潮中始终保持业务系统的高性能与高稳定性。
2023-03-26 15:30:30
457
秋水共长天一色-t
Oracle
...没有它们,就像我们在优化数据库性能、提升查询速度、管理存储空间这些重要环节时缺了个趁手的好工具,那可真是干瞪眼没办法了。这篇东西,咱们会手把手、深度探索,并配上满满干货的实例代码,一起把Oracle数据统计信息这块儿神秘面纱给揭个底朝天,让大家明明白白瞧个清楚。 2. 数据统计信息的重要性 在我们日常的数据库运维过程中,Oracle会自动收集并维护各类数据统计信息,包括表、索引、分区等对象的行数、分布情况、空值数量等。这些信息对SQL优化器来说,就好比是制定高效执行计划的“导航图”,要是没了这些准确的数据统计信息,那就相当于飞行员在伸手不见五指的夜里,没有雷达的帮助独自驾驶飞机,这样一来,SQL执行起来可能就会慢得像蜗牛,还可能导致资源白白浪费掉。 例如,当Oracle发现某字段存在大量重复值时,可能选择全表扫描而非索引扫描,这就是基于统计信息做出的智能决策。 3. 数据统计信息的收集与维护 (1)自动收集 Oracle默认开启了自动统计信息收集任务,如DBMS_STATS.AUTO_STATS_JOB_ENABLED参数设定为TRUE,系统会在适当的时间自动收集统计信息。 sql -- 检查自动统计信息收集是否开启 SELECT name, value FROM v$parameter WHERE name = 'dbms_stats.auto_stats_job_enabled'; (2)手动收集 当然,你也可以根据业务需求手动收集特定表或索引的统计信息: sql -- 手动收集表EMP的统计信息 EXEC DBMS_STATS.GATHER_TABLE_STATS('SCOTT', 'EMP'); -- 收集所有用户的所有对象的统计信息 BEGIN DBMS_STATS.GATHER_DATABASE_STATS; END; / 4. 数据统计信息的解读与应用 (1)查看统计信息 获取表的统计信息,我们可以使用DBA_TAB_STATISTICS视图: sql -- 查看表EMP的统计信息 SELECT FROM dba_tab_statistics WHERE table_name = 'EMP'; (2)基于统计信息的优化 假设我们发现某个索引的基数(distinct_keys)远小于实际行数,这可能意味着该索引的选择性较差,可以考虑优化索引或者调整SQL语句以提高查询效率。 5. 进阶探讨 统计信息的影响与策略 - 影响:统计信息的准确性和及时性直接影响到SQL优化器生成执行计划的质量。过时的统计信息可能导致最优路径未被选中,进而引发性能问题。 - 策略:在高并发、大数据量环境下,我们需要合理设置统计信息的收集频率和时机,避免在业务高峰期执行统计信息收集操作,同时,对关键业务表和索引应定期或按需更新统计信息。 6. 结语 总的来说,Oracle中的数据统计信息像是数据库运行的晴雨表,它默默记录着数据的变化,引导着SQL优化器找到最高效的执行路径。对于我们这些Oracle数据库管理员和技术开发者来说,摸透并熟练运用这些统计信息进行高效管理和巧妙利用,绝对是咱们不可或缺的一项重要技能。想要让咱的数据库系统始终保持巅峰状态,灵活应对各种复杂的业务场景,就得在实际操作中不断瞅瞅、琢磨和调整。就像是照顾一颗生机勃勃的树,只有持续观察它的生长情况,思考如何修剪施肥,适时做出调整,才能让它枝繁叶茂,结出累累硕果,高效地服务于咱们的各项业务需求。
2023-04-01 10:26:02
134
寂静森林
Flink
...在实际运维大数据处理系统时,类似的故障排查与优化工作是常态。近期,Apache Flink社区发布了一个重要的更新——Flink 1.14版本,它对ResourceManager的稳定性与资源管理效率进行了显著提升。 在新版本中,ResourceManager引入了更精细化的资源调度策略,允许用户根据作业需求动态调整TaskManager的资源配置,有效避免资源浪费和集群瓶颈问题。此外,Flink 1.14还改进了日志输出和错误提示信息,使得在面对诸如ResourceManager未启动这类问题时,开发人员能够更快定位到故障源头,从而极大地提高了问题解决效率。 同时,为了更好地服务大规模生产环境,社区强化了Flink与其他云原生生态工具的集成,如Kubernetes、YARN等,通过标准化接口和容器化部署,降低了ResourceManager在复杂环境中的部署难度和运维成本。 因此,对于正在使用或计划采用Apache Flink进行大数据处理的技术团队来说,持续关注Flink社区的最新动态和技术演进,结合本文介绍的基础知识,将有助于在日常运维中更高效地应对各类问题,确保系统的稳定性和资源利用率。同时,深入研究和应用Flink 1.14版本的新特性,将有力推动企业级大数据平台的性能优化与架构升级。
2023-12-23 22:17:56
759
百转千回
转载文章
...gh的范围还可以通过系统参数java.lang.Integer.IntegerCache.high设置),并在valueOf调用时判断是否落在这个范围,如果范围合适,返回现成的对象。由于Integer是不变对象,所以它的复用是没有任何隐患的。 public static Integer valueOf(int i) { if(i >= -128 && i <= IntegerCache.high) return IntegerCache.cache[i + 128]; else return new Integer(i); } 话虽如此,但这只是一个优化手段,平时是不应该使用==来进行判断对象是否相等的。 Integer和字符串的相互转换 整型和字符串的相互转换也是常用的功能。看一下Integer转换成字符串的源码。 public static String toString(int i, int radix) { if (radix < Character.MIN_RADIX || radix > Character.MAX_RADIX) radix = 10; / Use the faster version / if (radix == 10) { return toString(i); } char buf[] = new char[33]; boolean negative = (i < 0); int charPos = 32; if (!negative) { i = -i; } while (i <= -radix) { buf[charPos--] = digits[-(i % radix)]; i = i / radix; } buf[charPos] = digits[-i]; if (negative) { buf[--charPos] = '-'; } return new String(buf, charPos, (33 - charPos)); } 算法还是比较简单的,就是根据基数radix不断对这个整数取余数,根据余数找到从digits数组中找到对应字符。这里需要注意的是, 为什么正数要取反使用负数而不是反过来呢,用正数不是更好处理么?其实,这涉及到是否溢出的问题,对于最小的整数integer,取反就会出现移除,还是一个负数,这样就有问题了。 还有一个功能是把整数换成16进制(toHexString)、8进制(toOctalString)或2进制的字符串(toBinaryString),它最终是调用toUnsignedString实现的。 / Convert the integer to an unsigned number. / private static String toUnsignedString(int i, int shift) { char[] buf = new char[32]; int charPos = 32; int radix = 1 << shift; int mask = radix - 1; do { buf[--charPos] = digits[i & mask]; i >>>= shift; } while (i != 0); return new String(buf, charPos, (32 - charPos)); } 以16进制为例子,shift就是4,得到的mark就是1111,i和mask做与运算后就可以得到在16进制中字符数组的位置,从而得到这4位对应的16进制字符,最后通过右移就抹掉这低4位。 Integer类中有许多方法是和位操作相关的。待后续详解。 本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_33130645/article/details/114425171。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-09-20 21:27:37
103
转载
HessianRPC
...无缝对接? 在分布式系统开发中,HessianRPC作为一种轻量级、高效的远程调用协议,广泛应用于跨语言的服务通信。在实际做项目,特别是迭代的时候,服务端接口更新优化什么的,简直就是家常便饭。这样一来,就牵扯出一个大问题:当咱们把Hessian服务端改头换面升级之后,怎么才能确保客户端能跟这个新版本的服务端无缝衔接、配合得溜溜的呢?这篇文咱就打算把这个事儿掰开了揉碎了讲讲,并且还会附上一些实实在在的实例代码,让大家一看就懂,一用就会。 1. 版本控制策略 首先,为了保证服务端更新时对客户端的影响降到最低,我们需要建立一套严格的版本控制策略。在设计Hessian服务接口的时候,我们可以像给小宝贝添加成长标签一样,为每个接口或者整个服务设置一个版本号。这样,当服务端内部有了什么新变化、更新迭代时,就像孩子长大了一岁,我们就通过升级这个版本号来区分新旧接口。而客户端呢,就像个聪明的玩家,会根据自己手里的“说明书”(支持的版本)去选择调用哪个合适的接口。 java // 定义带有版本号的Hessian服务接口 public interface MyService { // v1版本的接口 String oldMethod(int arg) throws RemoteException; // v2版本的接口,增加了新的参数 String newMethod(int arg, String newParam) throws RemoteException; } 2. 向后兼容性设计 当服务端新增接口或修改已有接口时,应尽可能保持向后兼容性,避免破坏现有客户端调用。比如,当你添加新的参数时,可以给它预先设定一个默认值。而如果你想删掉或者修改某个参数,只要不影响业务正常运作的那个“筋骨”,就可以保留原来的接口,让老版本的客户端继续舒舒服服地用着,不用着急升级换代。 java // 新版本接口考虑向后兼容 public String newMethod(int arg, String newParam = "default_value") { //... } 3. 双重部署和灰度发布 在实际更新过程中,我们可以通过双重部署及灰度发布的方式来平滑过渡。先部署新版本服务,并让部分用户或流量切换至新版本进行验证测试,确认无误后再逐步扩大范围直至全量替换。 4. 客户端适配升级 对于客户端来说,应对服务端接口变化的主要方式是对自身进行相应的更新和适配: - 动态加载服务接口:客户端可以通过动态加载机制,根据服务端返回的版本信息加载对应的接口实现类,从而实现自动适配新版本服务。 java // 动态加载示例(伪代码) String serviceUrl = "http://server:port/myService"; HessianProxyFactory factory = new HessianProxyFactory(); MyService myService; try { // 获取服务端版本信息 VersionInfo versionInfo = getVersionFromServer(serviceUrl); // 根据版本创建代理对象 if (versionInfo.isV1()) { myService = (MyService) factory.create(MyService.class, serviceUrl + "?version=v1"); } else if (versionInfo.isV2()) { myService = (MyService) factory.create(MyService.class, serviceUrl + "?version=v2"); } } catch (Exception e) { // 错误处理 } // 调用对应版本的方法 String result = myService.newMethod(1, "newParam"); - 客户端版本迭代:对于无法通过兼容性设计解决的重大变更,客户端也需要同步更新以适应新接口。这时候,咱们得好好策划一个详尽的升级计划和方案出来,并且要赶紧给所有客户端开发的大哥们发个消息,让他们麻溜地进行更新工作。 总结起来,要保证Hessian服务端更新后与客户端的无缝对接,关键在于合理的设计和服务管理策略,包括但不限于版本控制、接口向后兼容性设计、双重部署及灰度发布以及客户端的灵活适配升级。在整个过程中,不断沟通、思考和实践,才能确保每一次迭代都平稳顺利地完成。
2023-10-30 17:17:18
496
翡翠梦境
Tesseract
...eract OCR因系统库依赖缺失引发初始化失败的问题后,我们认识到正确安装和管理软件依赖关系对于任何项目开发都至关重要。近期,开源社区对此类问题的关注度持续提升,特别是在容器化与持续集成/持续部署(CI/CD)等现代软件工程实践中。 例如,在Docker等容器技术中,开发者能够通过创建包含所有必要依赖环境的镜像来确保应用的一致性和可移植性,从而有效避免了类似Tesseract初始化失败的情况。一篇发表于InfoQ的《使用Docker构建可靠且可重复的OCR服务》文章深入探讨了如何借助Docker解决OCR工具在不同环境下的依赖难题。 此外,随着DevOps理念的普及,自动化工具如pipenv、npm、conda等包管理器在处理复杂依赖关系时展现出了强大的能力。TechCrunch最近的一篇报道《自动化包管理:提升软件开发效率的新利器》就分析了这些工具如何帮助企业更好地管理和更新项目依赖,减少由依赖缺失引发的问题,进一步保障了像Tesseract OCR这类关键组件的稳定运行。 因此,无论是关注具体场景下如Tesseract OCR的依赖配置问题,还是从宏观层面探讨现代软件工程中依赖管理的发展趋势,都有助于我们深化理解并优化日常开发工作中的依赖管理实践。
2023-02-15 18:35:20
155
秋水共长天一色
Shell
...解更多关于Linux系统管理和自动化运维的最新动态与实践案例。近期,业界推出了一些颇具时效性和实用性的资源值得进一步探索。 首先,《Linux Journal》杂志近期发布了一篇深度解析文章,详尽探讨了如何利用Shell脚本优化Linux服务器性能监控和故障排查流程,文中列举了多个实战场景及对应的Shell脚本解决方案,为读者提供了宝贵的经验借鉴。 其次,开源社区GitHub上有一款名为"awesome-bash"的项目备受关注,该项目汇集了众多精良的Bash脚本实例、开发工具以及最佳实践指南,实时更新且内容丰富,无论是新手还是老手都能从中受益匪浅。 再者,红帽公司(Red Hat)在其官网上定期分享了一系列基于Shell的高级自动化运维教程,其中包含了对Ansible、Puppet等自动化运维工具与Shell结合使用的深度解读,对于提升大规模集群环境下的运维效率极具指导意义。 最后,全球最大的开发者问答平台Stack Overflow上每日都有大量与Shell相关的讨论和问题解答,涉及从基础语法到复杂脚本编写等多个层面,紧跟技术潮流,及时解决实际问题,是持续深化Shell技能的绝佳互动场所。 总之,理论结合实践,不断跟进最新的技术动态,积极参与社区交流,才能使你在Shell编程的世界中不断提升,并将其运用到更广阔的信息技术领域中去。
2023-09-20 15:01:23
54
笑傲江湖_
ElasticSearch
...时数据分析、智能推荐系统等场景的新特性。例如,最新版本中优化的近义词自动扩展功能,能更精准地捕捉用户意图,极大提升用户体验,尤其适用于电商、新闻资讯等行业的大规模内容检索。 同时,随着物联网、日志分析等领域的快速发展,Elasticsearch的应用边界也在不断拓宽。不少企业利用其地理空间搜索功能进行车辆定位追踪、物流路径优化等业务实践,实现数据驱动决策。此外,Elasticsearch结合Kibana可视化工具,可将复杂的数据以直观易懂的图表形式展现,为数据分析人员提供高效的数据洞察手段。 对于希望深入研究Elasticsearch技术原理与实战应用的读者,可以参考《Elasticsearch权威指南》一书,或关注Elastic Stack官方博客及社区论坛,获取最新的技术动态和最佳实践案例。通过持续学习和实践,您将能够更好地驾驭这一强大的搜索引擎,为企业数字化转型赋能。
2023-02-26 23:53:35
528
岁月如歌-t
Shell
...evOps是一种强调开发与运维紧密协作的文化、理念和实践,旨在通过自动化工具链、持续集成/持续部署(CI/CD)、敏捷开发方法论等手段,实现快速交付高质量软件产品并优化流程效率。在文中语境下,DevOps文化推动了Shell脚本在自动化运维场景中的广泛应用。 CI/CD(Continuous Integration/Continuous Deployment) , CI/CD是现代软件工程中的一种自动化流程,其中CI(持续集成)是指开发人员频繁地将代码变更合并到主分支,并通过自动构建和测试确保新代码的质量和兼容性;CD(持续部署或持续发布)则进一步自动化了软件包从构建环境到生产环境的部署过程。文中提及将Shell脚本融入CI/CD流程,意味着开发者可以利用Shell编写自动化脚本来简化和加速软件的构建、测试及发布过程。 容器编排 , 容器编排是一种管理和自动化容器化应用部署、扩展和维护的过程,它涉及资源调度、服务发现、负载均衡、健康检查等多个环节。在文中语境下,Shell脚本在DevOps实践中可以参与到容器编排中,例如使用Shell编写脚本来启动、停止、迁移容器,或者根据需求动态调整容器集群规模,从而提高系统资源利用率和服务可靠性。Docker和Kubernetes等主流容器技术平台都支持通过脚本进行一定程度的自定义编排。
2023-09-05 16:22:17
101
山涧溪流_
Etcd
...,作为分布式键值存储系统,在Kubernetes集群中扮演着至关重要的角色。它维护了集群状态的一致性,确保服务发现、配置共享等任务的稳定执行。而摸清和玩转Etcd的日志级别调整及输出方式,可是运维人员在解决故障、优化性能时不可或缺的独门秘籍!嘿,朋友们,这篇东西会手把手地带你们揭开Etcd日志设置背后的那些小秘密,就像侦探破案一样层层递进。我将通过实实在在的例子,教大家在日常操作中如何把Etcd日志设置玩得溜起来,让你们见识一下它的灵活性和实用性! 1. Etcd日志级别简介 Etcd使用了Go语言的标准日志库logrus,提供了多个级别的日志输出,包括Debug、Info、Warning、Error以及Fatal五个等级。不同的日志级别对应不同的信息详细程度: - Debug:记录详细的调试信息,用于开发阶段的问题排查。 - Info:提供运行时的基本信息,如节点启动、客户端连接等。 - Warning:记录潜在错误或非预期行为,但不影响程序正常运行。 - Error:记录已发生错误,可能影响部分功能。 - Fatal:记录严重错误,导致进程终止。 2. 设置Etcd日志级别 Etcd的日志级别可以通过启动参数--log-level来设定。下面是一段启动Etcd并将其日志级别设置为info的示例代码: bash ./etcd --name my-etcd-node \ --data-dir /var/lib/etcd \ --listen-peer-urls http://localhost:2380 \ --listen-client-urls http://localhost:2379 \ --initial-cluster-token etcd-cluster-1 \ --initial-cluster=my-etcd-node=http://localhost:2380 \ --advertise-client-urls http://localhost:2379 \ --log-level=info 上述命令行中--log-level=info表示我们只关心Info及以上级别的日志信息。 3. 输出方式与格式化 Etcd默认将日志输出到标准错误(stderr),你也可以通过--log-output参数指定输出文件,例如: bash ./etcd --log-output=/var/log/etcd.log ... 此外,Etcd还支持JSON格式的日志输出,只需添加启动参数--log-format=json即可: bash ./etcd --log-format=json ... 4. 实践应用与思考 在日常运维过程中,我们可能会遇到各种场景需要调整Etcd的日志级别。比如,当我们的集群闹脾气、出现状况时,我们可以临时把日志的“放大镜”调到Debug级别,这样就能捞到更多更细枝末节的内部运行情况,像侦探一样迅速找到问题的幕后黑手。而在平时一切正常运转的日子里,为了让日志系统保持高效、易读,我们一般会把它调到Info或者Warning这个档位,就像给系统的日常表现打个合适的标签。 同时,合理地选择日志输出方式也很重要。直接输出至终端有利于实时监控,但不利于长期保存和分析。所以,在实际的生产环境里,我们通常会选择把日志稳稳地存到磁盘上,这样一来,以后想回过头来找找线索、分析问题什么的,就方便多了。 总的来说,熟练掌握Etcd日志级别的调整和输出方式,不仅能让我们更好地理解Etcd的工作状态,更能提升我们对分布式系统管理和运维的实战能力。这就像一位超级厉害的侦探大哥,他像拿着放大镜一样细致地研究Etcd日志,像读解神秘密码那样解读其中的含义。通过这种抽丝剥茧的方式,他成功揭开了集群背后那些不为人知的小秘密,确保我们的系统能够稳稳当当地运行起来。
2023-01-29 13:46:01
832
人生如戏
Maven
...目模板? 在Java开发领域,Apache Maven作为一款强大的构建工具,以其标准化的构建流程和依赖管理能力深受开发者喜爱。在众多给力的功能里头,Maven archetype插件可真是个神器,它能帮我们嗖嗖地生成项目模板,工作效率那可是蹭蹭地往上涨啊!嘿,伙计们,这篇内容将手把手地带你们畅游在Maven archetype的神奇天地中,用超级详细的步骤和鲜活的实例代码,教大家如何巧妙地运用这个工具去搭建一个崭新的项目模板,让你彻底玩转这个领域! 1. 理解Maven Archetype 首先,让我们对Maven archetype有个基本的认识。Maven archetype可以理解为一种项目模板,它预先定义了一组特定项目的目录结构和基本文件配置。当我们要捣鼓新项目的时候,完全可以省去从零开始的繁琐步骤,直接拿这些现成的模板来用就OK啦!这样一来,不仅能够告别枯燥无味的手动创建过程,还能让咱们的项目启动变得超级轻松快捷,效率嗖嗖地往上涨! 2. 安装与配置Maven环境 在开始使用archetype插件前,请确保你的系统已安装并配置好Maven环境。这里假设你已经完成了这一基础工作,接下来就可以直接进入实战环节了。 3. 使用archetype:generate命令创建项目模板 3.1 初始化一个新的Maven项目模板 打开命令行界面,输入以下命令: shell mvn archetype:generate \ -DarchetypeGroupId=org.apache.maven.archetypes \ -DarchetypeArtifactId=maven-archetype-quickstart \ -DarchetypeVersion=1.4 \ -DgroupId=com.example \ -DartifactId=my-new-project \ -Dversion=1.0-SNAPSHOT 上述命令的作用是使用Maven内置的maven-archetype-quickstart模板创建一个新项目。其中: - -DarchetypeGroupId,-DarchetypeArtifactId和-DarchetypeVersion分别指定了要使用的模板的Group ID,Artifact ID和版本。 - -DgroupId,-DartifactId和-Dversion则是用于定义新项目的基本信息。 执行完该命令后,Maven会提示你确认一些参数,并在指定目录下生成新的项目结构。 3.2 创建自定义的archetype项目模板 当然,你也可以创建自己的项目模板,供后续多次复用。首先,咱先来新建一个普普通通的Maven项目,接着就可以按照你的小心思,尽情地设计和调整目录结构,别忘了把初始文件内容也填充得妥妥当当的哈。接着,在pom.xml中添加archetype相关的配置: xml 4.0.0 com.example my-custom-archetype 1.0-SNAPSHOT maven-archetype org.apache.maven.archetype archetype-packaging 3.2.0 org.apache.maven.plugins maven-archetype-plugin 3.2.0 generate-resources generate-resources 最后,通过mvn clean install命令打包并发布到本地仓库,这样就创建了一个自定义的archetype模板。 3.3 使用自定义的archetype创建新项目 有了自定义的archetype模板后,创建新项目的方式同上,只需替换相关参数即可: shell mvn archetype:generate \ -DarchetypeGroupId=com.example \ -DarchetypeArtifactId=my-custom-archetype \ -DarchetypeVersion=1.0-SNAPSHOT \ -DgroupId=com.new.example \ -DartifactId=my-new-project-from-custom-template \ -Dversion=1.0-SNAPSHOT 在这个过程中,我深感Maven archetype的强大之处,它就像一位贴心助手,帮我们在繁杂的项目初始化工作中解脱出来,专注于更重要的业务逻辑开发。而且,我们能够通过定制自己的archetype,把团队里那些最牛掰的工作模式给固定下来,这样一来,不仅能让整个团队的开发速度嗖嗖提升,还能让大伙儿干活儿时更有默契,一致性蹭蹭上涨,就像乐队排练久了,配合起来那叫一个天衣无缝! 总结一下,Maven archetype插件为我们提供了一种快速创建项目模板的机制,无论是内置的模板还是自定义模板,都能极大地简化项目创建流程。只要我们把这个工具玩得溜溜的,再灵活巧妙地运用起来,就能在Java开发这条路上走得更顺溜,轻松应对各种挑战,简直如有神助。所以,不妨现在就动手试试吧,感受一下Maven archetype带来的便利与高效!
2024-03-20 10:55:20
109
断桥残雪
Tomcat
...儿,特别是对于那些在开发网站过程中遇到网站响应时间过长问题的朋友。最近我在弄一个项目,结果发现网站打开慢得要命,简直想砸电脑。然后我就一头栽进研究Tomcat性能优化的世界里了,希望能把这事儿搞定。嘿,大家好!今天想跟你们聊聊我最近的一次探索之旅,还有我是怎么捣鼓Tomcat的设置,让网站加载快得像闪电一样! 1. 初识Tomcat 为何它会影响网站响应时间? 首先,让我们简单回顾一下Tomcat是个啥。Tomcat可是个大名鼎鼎的开源Web服务器,它是Apache旗下的产物。简单来说,Tomcat就像个超级能干的小助手,专门负责解读和运行Java Servlet和JSP(就是那种用来编写动态网页的Java代码)。这样一来,它就能帮我们生成各种炫酷的动态网页啦!不过,你可能会想,这跟网站打开慢有啥关系呢?其实很多时候,网站加载慢并不是因为服务器不够强,而是因为Tomcat没配好,或者是应用本身有点问题。 思考时刻:你有没有想过,为什么同样的代码在不同的服务器上表现差异巨大?这就是我们需要深入研究Tomcat配置的原因之一。 2. 性能瓶颈分析 找出问题所在 在解决任何问题之前,我们首先需要知道问题出在哪里。这里有几个常见的影响因素: - 内存不足:如果Tomcat服务器分配给Java堆的内存不够,应用程序运行时可能会频繁触发垃圾回收,导致响应时间变长。 - 线程池配置不合理:线程池大小设置不当会导致请求处理效率低下,特别是在高并发场景下。 - 数据库连接池配置:数据库连接池配置不当也会严重影响性能,比如连接池大小设置太小,导致数据库连接成为瓶颈。 代码示例: 假设我们想要增加Tomcat中Java堆的内存,可以在catalina.sh文件中添加如下参数: bash JAVA_OPTS="-Xms512m -Xmx1024m" 这里,-Xms表示初始堆大小,-Xmx表示最大堆大小。根据实际情况调整这两个值可以有效缓解内存不足的问题。 3. 调优技巧 如何让Tomcat飞起来? 找到问题之后,接下来就是对症下药了。下面是一些实用的调优建议: - 调整JVM参数:除了前面提到的内存设置外,还可以考虑启用压缩引用(-XX:+UseCompressedOops)等JVM参数来提高性能。 - 优化线程池配置:合理设置线程池大小可以显著提高并发处理能力。例如,在server.xml文件中的元素下设置maxThreads="200"。 - 使用连接池:确保数据库连接池配置正确,比如使用HikariCP这样的高性能连接池。 代码示例: 在server.xml中配置线程池: xml connectionTimeout="20000" redirectPort="8443" maxThreads="200"/> 4. 实践案例分享 从慢到快的转变 在我自己的项目中,我发现网站响应时间过长的主要原因是数据库查询效率低。加了缓存之后,再加上SQL查询也优化了一下,网站的反应速度快了不少,用起来顺手多了!另外,我调了一下JVM参数和线程池配置,这样系统在高峰期就能扛得住更大的流量啦。 思考时刻:优化工作往往不是一蹴而就的,需要不断测试、调整、再测试。在这个过程中,耐心和细心是非常重要的品质。 结语 好了,今天的分享就到这里。希望这篇文章能给你点灵感,让你知道怎么通过调整Tomcat的设置来让网站跑得更快些。记住,技术永远是在不断进步的,保持好奇心和学习的态度是成长的关键。如果你有任何问题或见解,欢迎随时留言交流! 最后,祝大家都能拥有一个响应迅速、用户体验优秀的网站! --- 希望这篇技术文章能够帮助到你,如果有任何具体问题或者需要进一步的信息,请随时告诉我!
2024-10-20 16:27:48
111
雪域高原
转载文章
...的功能集和丰富的插件系统,在实际项目中得到了广泛应用。 2023年年初,dva.js发布了其最新版本,进一步优化了数据流管理逻辑,并对内置fetch进行了性能提升,以适应现代Web应用更为复杂的数据交互需求。与此同时,团队加强了与TypeScript的集成支持,使得开发者能够更加方便地利用静态类型检查来提高代码质量。 而在umijs方面,社区围绕其展开了一系列深度定制和扩展工作。近期,umijs携手Ant Design Pro推出了全新的企业级模板,整合了包括dva.js在内的诸多最佳实践,旨在提供一站式的企业级中后台项目搭建方案。此外,umijs通过引入更多高性能插件,如按需加载模块优化工具以及更完善的PWA支持,不断提升用户在移动端和桌面端的使用体验。 值得关注的是,随着前端技术的发展趋势向Serverless方向倾斜,umijs也在积极布局云原生应用开发领域,结合阿里云等服务商提供的服务,让开发者能够轻松构建并部署基于云函数的全栈应用,进一步降低开发门槛,提升迭代效率。 总之,无论是从易用性、功能性还是前瞻性的角度来看,dva.js与umijs都展现出了极高的价值和发展潜力。作为前端开发者,密切关注这些框架的最新动态和技术演进,将有助于我们在实际工作中更好地把握技术脉搏,打造出更高效、稳定且符合时代潮流的高质量应用程序。
2023-11-06 14:19:32
317
转载
SpringBoot
...轻松升级,这样一来,系统的维护和扩容就变得超级灵活便捷,就像搭积木一样简单易行。为了确保各个服务间能顺畅地“交流”和协同工作,我们一般会借助一个叫做消息中间件的工具来帮忙传递信息和数据。这就像是在各个服务之间搭建起一座无形的桥梁,让数据能够高效、准确地从一个地方跑到另一个地方。本文我们将通过Spring Boot集成RocketMQ来实现实现异步任务的消息推送。 二、Spring Boot简介 Spring Boot是Spring框架的一个子项目,旨在简化Spring应用的构建和配置过程。它提供了一个开箱即用的开发环境,能够快速地搭建出基于Spring的应用程序。另外,Spring Boot还自带了一大堆好用的内置组件和自动化工具,这些家伙能帮我们更轻松地搞定应用程序的管理问题。 三、RocketMQ简介 RocketMQ是一款开源的分布式消息中间件,由阿里巴巴公司推出。这个家伙,可厉害了!它能够飞快地传输大量数据,速度嗖嗖的,延迟低得几乎可以忽略不计。而且,它的稳定性和容错能力也是一级棒,就像个永不停歇、从不出错的小超人一样,随时待命,让人安心又放心。RocketMQ支持多种协议,包括Java API、Stomp、RESTful API等,可以方便地与其他系统进行集成。 四、Spring Boot集成RocketMQ 要实现Spring Boot与RocketMQ的集成,我们需要引入相关的依赖。首先,在pom.xml文件中添加如下依赖: xml org.springframework.boot spring-boot-starter-rocketmq 然后,我们需要在配置文件application.properties中添加如下配置: properties spring.rocketmq.namesrv-address=127.0.0.1:9876 这里的namesrv-address属性表示RocketMQ的命名服务器地址,我们可以通过这个地址获取到Broker节点列表。 接下来,我们就可以开始编写生产者的代码了。下面是一个简单的生产者示例: java import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer; import org.apache.rocketmq.common.message.MessageQueue; import java.util.ArrayList; import java.util.List; public class Producer { public static void main(String[] args) { // 创建一个消息消费者,并设置一个消息消费者组 DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("testGroup"); // 指定NameServer地址 consumer.setNamesrvAddr("localhost:9876"); // 初始化消费者,整个应用生命周期内只需要初始化一次 consumer.start(); // 关闭消费者 consumer.shutdown(); } } 在这个示例中,我们创建了一个名为testGroup的消息消费者组,并指定了NameServer地址为localhost:9876。然后,我们就像启动一辆跑车那样,先给消费者来个“start”热身,让它开始运转起来;最后嘛,就像关上家门一样,我们顺手给它来了个“shutdown”,让这个消费者妥妥地休息了。 五、总结 本文介绍了如何通过Spring Boot集成RocketMQ实现异步任务的消息推送。用这种方式,我们就能轻轻松松地管理好消息队列,让系统的稳定性和扩展性噌噌噌地往上涨。同时,Spring Boot和RocketMQ的结合也使得我们的应用程序更加易于开发和维护。以后啊,我们还可以捣鼓捣鼓其他的通讯工具,比如Kafka、RabbitMQ这些家伙,让咱们的系统的运行速度和稳定性更上一层楼。
2023-12-08 13:35:20
83
寂静森林_t
Saiku
...u这一功能强大的报表工具之后,我们发现数据可视化与分析领域正在不断取得新的突破。近日,Apache Superset——另一个开源的数据可视化平台,也因其灵活、可扩展的特性及丰富的图表类型获得了业界的关注。Superset支持实时数据分析和多维数据集探索,且同样具备友好的用户界面,让用户无需编码即可创建美观且信息量大的仪表板。 同时,随着大数据时代的到来,企业对于数据分析的需求日益增强,全球众多公司正致力于研发更为高效便捷的报表工具。例如,Tableau和Power BI等商业解决方案也在持续更新迭代,提供AI驱动的智能洞察,以及无缝集成各种云服务的能力,以帮助企业更好地利用数据进行决策。 此外,针对Saiku使用者可能关心的开源社区动态,近期Saiku开发者团队宣布了新版本的重大更新,其中包括对更多数据源的支持、性能优化以及用户体验的进一步提升。这些进展不仅印证了Saiku坚持创新的决心,也为广大用户带来了更加强大、易用的报表构建体验。 总的来说,在当前的大数据环境下,无论是开源工具如Saiku和Apache Superset,还是商业产品如Tableau和Power BI,都在不断推动报表和数据分析技术的发展,为企业数字化转型提供了有力支撑。而掌握并有效运用这些工具,无疑将助力企业和个人在信息时代中占据竞争优势。
2023-02-10 13:43:51
120
幽谷听泉-t
转载文章
...数据可视化展示(可视化工具 pyecharts,seaborn,matplotlib) 代码结构 ├── data│ ├── garbage-classify-for-pytorch│ │ ├── train│ │ ├── train.txt│ │ ├── val│ │ └── val.txt│ └── garbage_label.txt├── analyzer│ ├── 01 垃圾分类_一级分类 数据分布.ipynb│ ├── 02 垃圾分类_二级分类 数据分析.ipynb│ ├── 03 数据加载以及可视化.ipynb│ ├── 03 数据预处理-缩放&裁剪&标准化.ipynb│ ├── garbage_label_40 标签生成.ipynb├── models│ ├── alexnet.py│ ├── densenet.py│ ├── inception.py│ ├── resnet.py│ ├── squeezenet.py│ └── vgg.py├── facebook│ ├── app_resnext101_WSL.py│ ├── facebookresearch_WSL-Images_resnext.ipynb│ ├── ResNeXt101_pre_trained_model.ipynb├── checkpoint│ ├── checkpoint.pth.tar│ ├── garbage_resnext101_model_9_9547_9588.pth├── utils│ ├── eval.py│ ├── json_utils.py│ ├── logger.py│ ├── misc.py│ └── utils.py├── args.py├── model.py├── transform.py├── garbage-classification-using-pytorch.py├── app_garbage.py data: 训练数据和验证数据、标签数据 checkpoint: 日志数据、模型文件、训练过程checkpoint中间数据 app_garbage.py:在线预测服务 garbage-classification-using-pytorch.py:训练模型 models:提供各种pre_trained_model ,例如:alexlet、densenet、resnet,resnext等 utils:提供各种工具类,例如;重新flask json 格式,日志工具类、效果评估 facebook: 提供facebook 分类器神奇的分类预测和数据预处理 analyzer: 数据分析和数据预处理模块 transform.py:通过pytorch 进行数据预处理 model.py: resnext101 模型集成以及调整、模型训练和验证函数封装 resnext101网络架构 pre_trained_model resnext101 网络架构原理 基于pytorch 数据处理、resnext101 模型分类预测 在线服务API 接口 垃圾分类-训练 python garbage-classification-using-pytorch.py \--model_name resnext101_32x16d \--lr 0.001 \--optimizer adam \--start_epoch 1 \--epochs 10 \--num_classes 40 model_name 模型名称 lr 学习率 optimizer 优化器 start_epoch 训练过程断点重新训练 num_classes 分类个数 垃圾分类-评估 python garbage-classification-using-pytorch.py \--model_name resnext101_32x16d \--evaluate \--resume checkpoint/checkpoint.pth.tar \--num_classes 40 model_name 模型名称 evaluate 模型评估 resume 指定checkpoint 文件路径,保存模型以及训练过程参数 垃圾分类-在线预测 python app_garbage.py \--model_name resnext101_32x16d \--resume checkpoint/garbage_resnext101_model_2_1111_4211.pth model_name 模型名称 resume 训练模型文件路径 模型预测 命令行验证和postman 方式验证 举例说明:命令行模式下预测 curl -X POST -F file=@cat.jpg http://ip:port/predict 最后,我们从0到1教大家掌握如何进行垃圾分类。通过本学习,让你彻底掌握AI图像分类技术在我们实际工作中的应用。 1. 你是什么垃圾? 2. 告诉你,你是什么垃圾 3. 使用它告诉你,你是啥垃圾 本篇文章为转载内容。原文链接:https://blog.csdn.net/shenfuli/article/details/103008003。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-02-10 23:48:11
518
转载
Kubernetes
...何通过可视化手段提升系统的可管理性与洞察力。 二、Kubernetes基础概览 Kubernetes(简称K8s)是一个开源的容器编排系统,它允许开发者和系统管理员自动部署、扩展和管理应用程序容器。Kubernetes的核心组件包括: - Pod:一组运行相同或不同应用容器的集合。 - Namespace:用于隔离资源并提供命名空间内的逻辑分组。 - Service:为Pod提供网络访问服务。 - Deployment:用于创建和更新Pod的副本集。 - StatefulSet:用于创建具有唯一身份标识的Pod集合。 - Ingress:提供外部对应用的访问入口。 三、Kiali的引入 Kiali是Kubernetes可视化监控和管理的一个重要工具,它通过图形界面提供了丰富的功能,包括服务发现、流量管理、健康检查、故障恢复策略等。哎呀,Kiali这个家伙可真能帮大忙了!它就像个超级厉害的侦探,能一眼看出你应用和服务到底是活蹦乱跳还是生病了。而且,它还有一套神奇的魔法,能把那些复杂的运维工作变得简单又快捷,就像是给你的工作流程装上了加速器,让你的效率噌噌噌往上涨。简直不能更贴心了! 四、Kubernetes与Kiali的集成 要将Kubernetes与Kiali整合,首先需要确保你的环境中已经部署了Kubernetes集群,并且安装了Kiali。接下来,通过以下步骤实现集成: 1. 配置Kiali bash kubectl apply -f https://kiali.io/install/kiali-operator.yaml 2. 验证Kiali安装 bash kubectl get pods -n kiali-system 应该能看到Kiali相关的Pod正在运行。 3. 访问Kiali UI bash kubectl port-forward svc/kiali 8080:8080 & 然后在浏览器中访问http://localhost:8080,即可进入Kiali控制台。 五、利用Kiali进行可视化监控 在Kiali中,你可以轻松地完成以下操作: - 服务发现:通过服务名或标签快速定位服务实例。 - 流量分析:查看服务之间的调用关系和流量流向。 - 健康检查:监控服务的健康状态,包括响应时间、错误率等指标。 - 故障恢复:配置故障转移策略,确保服务的高可用性。 六、案例分析 构建一个简单的微服务应用 假设我们有一个简单的微服务应用,包含一个后端服务和一个前端服务。我们将使用Kubernetes和Kiali来部署和监控这个应用。 yaml apiVersion: apps/v1 kind: Deployment metadata: name: backend-service spec: replicas: 3 selector: matchLabels: app: backend template: metadata: labels: app: backend spec: containers: - name: backend-container image: myregistry/mybackend:v1 ports: - containerPort: 8080 --- apiVersion: v1 kind: Service metadata: name: backend-service spec: selector: app: backend ports: - protocol: TCP port: 80 targetPort: 8080 在Kiali中,我们可以直观地看到这些服务是如何相互依赖的,以及它们的健康状况如何。 七、结论 Kubernetes与Kiali的结合,不仅极大地简化了Kubernetes集群的管理,还提供了丰富的可视化工具,使运维人员能够更加直观、高效地监控和操作集群。通过本文的介绍,我们了解到如何通过Kubernetes的基础配置、Kiali的安装与集成,以及实际应用的案例,实现对复杂微服务环境的有效管理和监控。随着云原生技术的不断发展,Kubernetes与Kiali的组合将继续发挥其在现代应用开发和运维中的核心作用,助力企业构建更可靠、更高效的云原生应用。
2024-09-05 16:21:55
61
昨夜星辰昨夜风
转载文章
...业界对在线协作和可视化工具的最新趋势和发展动态。随着远程办公和数字化转型的加速推进,在线制图平台的需求日益增长。例如,近日有报道指出,全球多家知名科技公司正在加大对云端绘图与协作工具的研发投入,旨在提升用户体验,实现跨地域、多用户的实时协作设计。 同时,数据可视化及建模技术也在不断革新。专家们强调了UML、ER模型等标准化建模语言在软件工程和系统架构设计中持续发挥的关键作用,并预测未来将结合AI和机器学习技术,使这些工具能够更加智能地辅助用户进行复杂系统的分析与优化。 此外,对于企业级服务而言,云架构部署与流程优化成为了行业热点。阿里云、AWS等国际主流云服务商近期陆续发布了新的架构设计与管理工具,助力企业更高效地构建、管理和展示其云上系统的整体架构,这也从侧面印证了像Freedgo Design这类提供云架构绘制功能的在线制图网站在未来市场中的重要地位。 综上所述,无论是从在线协作绘图工具的技术演进,还是从数据建模和云架构设计的专业需求出发,Freedgo Design所代表的一类在线制图服务不仅顺应了当下工作方式的变化潮流,而且在不断提升自身的功能性和智能化水平,以满足各行业对图形化表达和系统设计日趋精细化的要求。
2023-04-03 21:03:06
106
转载
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
Ctrl+R
- 启动反向搜索历史命令功能。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
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
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"