前端技术
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
[分析器配置 ]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
转载文章
...在实际软件开发和数据分析领域也扮演着重要角色。Facebook的研究团队近期就利用动态规划优化了其内部大规模数据处理流程,通过最小化不必要的计算步骤显著提升了效率。同时,模拟法在复杂系统建模、游戏开发等领域也有广泛的应用价值,如自动驾驶仿真测试中,就需要用到精确的模拟技术来预测不同情况下的车辆行为。 此外,深入探究数学理论,我们会发现这类问题与数论中的同余类、中国剩余定理等高级概念存在着内在联系。在更广泛的计算机科学视角下,对于字符串操作和数字属性转换的研究,可以启发我们开发出更加高效的数据压缩算法或密码学安全方案。 因此,读者在理解并掌握本文介绍的基础算法后,可进一步关注最新的算法竞赛题目及行业动态,研读相关领域的经典论文和教材,如《算法导论》中的动态规划章节,以及《数论概要》中关于同余类的论述,从而深化对这两种解题方法的理解,并能将其应用于更广泛的现实场景中。
2023-04-14 11:43:53
385
转载
Gradle
...entation是配置名称,它们分别表示主源码编译依赖与测试源码编译依赖。后面的字符串则是依赖的具体描述,遵循“groupId:artifactId:version”的格式。 2. 依赖传递性理解与控制 Gradle支持依赖的传递性,这意味着如果你直接依赖的库又依赖了其他库,那么那些间接依赖也会自动被包含进来。不过,在某些情况下,你可能需要控制或排除某些传递性依赖,可以使用exclude关键字实现: groovy dependencies { implementation('org.springframework.boot:spring-boot-starter-data-jpa') { exclude group: 'org.hibernate', module: 'hibernate-entitymanager' } } 上述代码表示我们在引入Spring Boot Data JPA starter时,明确排除了Hibernate Entity Manager。 3. 打包时确保依赖包含无遗漏 当执行Gradle的jar任务(或Android的assemble任务)打包项目时,Gradle会自动处理所有已声明的依赖关系。一般来说,如果没啥特殊设定,那些直接用到的依赖关系会自动被塞进类路径里。而那些间接、传递过来的依赖关系,是否会被纳入其中,就得看具体的配置策略怎么安排了。 但是请注意,Gradle并不会将依赖库的.jar文件物理地打包进你的主.jar文件中,而是会在生成的.jar文件的META-INF/MANIFEST.MF文件中记录依赖信息,以供运行时解析。如果你想创建一个包含所有依赖的“fat jar”(或称为"uber jar"),可以使用如shadow插件或原生的bootJar任务(针对Spring Boot项目): groovy plugins { id 'com.github.johnrengelman.shadow' version '6.1.0' } jar { manifest { attributes 'Main-Class': 'com.example.Main' } } task shadowJar(type: ShadowJar) { archiveBaseName = 'my-app' archiveClassifier = 'all' mergeServiceFiles() } 以上代码片段展示了如何应用Shadow插件并创建一个包含所有依赖的自包含.jar文件。 总结起来,要确保Gradle打包时正确包含依赖包,关键在于合理地在build.gradle中声明和管理依赖,并根据实际需求选择合适的打包策略。Gradle这个家伙的设计理念啊,就是让构建项目这件事儿变得瞅一眼就明白,摸一下就能灵活运用,甭管多复杂的依赖关系网,都能轻松玩转。这样一来,咱们就能麻溜地把项目打包工作给搞定了,高效又省心!在你亲自上手捣鼓和尝试Gradle的过程中,你会发现这玩意儿的强大程度绝对超乎你的想象,它会像个给力的小助手一样,陪你一起砍断开发道路上的各种难题荆棘,勇往直前地一路狂奔。
2023-10-25 18:00:26
454
月影清风_
Apache Atlas
...加接地气、细致入微的分析探索。 二、大规模图表数据性能问题 在处理大规模图表数据时,我们经常会遇到一些性能问题,如查询速度慢、存储空间不足等。这些问题不仅拖慢了我们有效利用数据的节奏,甚至可能变成一道坎儿,拦住我们深入挖掘、获得更多有价值的数据洞见。 三、Apache Atlas解决问题的方法 那么,Apache Atlas是如何帮助我们解决这些问题的呢?主要有以下几点: 1. 使用高效的图数据库 Apache Atlas使用了TinkerPop作为其底层的图数据库,这是一个高性能、可扩展的图数据库框架。用上TinkerPop这个神器,Apache Atlas就像装上了涡轮增压器,嗖嗖地在大规模数据查询中飞驰,让咱们的数据访问性能瞬间飙升,变得超级给力! 2. 提供灵活的数据模型 Apache Atlas提供了一个灵活的数据模型,允许我们根据需要自定义图谱中的节点和边的属性。这样一来,我们就能在不扩容存储空间的前提下,灵活应对各种场景下的数据需求啦。 3. 支持多种数据源 Apache Atlas支持多种数据源,包括Hadoop、Hive、Spark等,这使得我们可以从多个角度理解和管理我们的数据。 四、Apache Atlas的实践应用 接下来,我们将通过一个实际的例子来展示Apache Atlas的应用。 假设我们需要对一组用户的行为数据进行分析。这些数据分布在多个不同的系统中,包括Hadoop HDFS、Hive和Spark SQL。我们想要构建一个图谱,表示用户和他们的行为之间的关系。 首先,我们需要创建一个图模型,定义用户和行为两个节点类型以及它们之间的关系。然后,我们使用Apache Atlas提供的API,将这些数据导入到图数据库中。最后,我们就可以通过查询图谱,得到我们想要的结果了。 这就是Apache Atlas的一个简单应用。用Apache Atlas,我们就能轻轻松松地管理并解析那些海量的图表数据,这样一来,工作效率嗖嗖地提升,简直不要太方便! 五、总结 总的来说,Apache Atlas是一个强大的工具,可以帮助我们有效地解决大规模图表数据性能问题。无论你是大数据的初学者,还是经验丰富的专业人士,都可以从中受益。嘿,真心希望这篇文章能帮到你!如果你有任何疑问、想法或者建议,千万别客气,随时欢迎来找我聊聊哈!
2023-06-03 23:27:41
473
彩虹之上-t
PHP
...况下,我们需要进一步分析服务器返回的内容,找出问题所在。 四、解决HTTP响应状态码错误或不匹配的方法 1. 异常处理 在PHP中,我们可以使用try-catch语句来捕获并处理可能出现的异常。例如: php try { $response = file_get_contents('http://example.com'); } catch (Exception $e) { echo "An error occurred while making the request: " . $e->getMessage(); } ?> 2. 日志记录 对于一些复杂的错误情况,单纯的打印异常信息可能无法完全解决问题。这时,我们可以选择将日志记录下来,以便于后续分析。PHP提供了丰富的日志记录功能,如error_log()函数。 3. 使用第三方库 对于一些常见的问题,可以考虑使用第三方库来解决。比如,在发送HTTP请求的时候,咱们可以选择一些像cURL这样的第三方工具库,这些小帮手往往会对收到的HTTP响应进行超级严格的检查和精心处理。 五、结论 总的来说,HTTP响应状态码是服务器与客户端之间通信的重要组成部分。明白HTTP响应状态码的含义,就如同拥有了一个超级实用的小工具,它能帮我们在调试和优化应用程序时,更加得心应手,让程序运行更加顺畅。无论是碰到HTTP响应状态码出错,还是发现情况对不上号,我们都有好几种实打实的解决办法可以灵活应对,任君挑选。希望通过这篇接地气的文章,你能像剥洋葱一样一层层深入理解这个问题,然后在实际开发的战场上,无论遇到啥挑战都能挥洒自如,灵活应对。
2023-01-24 18:55:06
76
岁月静好-t
Spark
...性和数据特性进行深度分析,设计出针对性的分区方案,显著提升了关联查询等复杂计算任务的执行效率。 综上所述,随着大数据技术的不断发展和完善,Spark Partitioner的优化与定制已经成为提升整个数据处理流水线性能的关键一环。持续关注相关领域的最新研究成果和技术实践,对于更好地运用Spark解决实际生产问题、挖掘其在大数据处理领域的潜力具有重要意义。
2024-02-26 11:01:20
71
春暖花开-t
Tomcat
...时候,我们可能需要对配置进行调整后重启服务,这可以通过先停止再启动的方式来实现,但更便捷的方式是直接使用restart.sh(Linux或Mac)或restart.bat(Windows): bash ./restart.sh 此命令会自动完成服务的优雅停机和重新启动过程。 4. 更深层次的管理操作 除了基本的启动、停止和重启外,我们还可以通过命令行对Tomcat进行更细致的管理,例如修改JVM参数、调整日志级别等。 4.1 调整JVM参数 在catalina.sh或catalina.bat脚本中,你可以设置Java虚拟机的参数,比如调整内存大小: bash export JAVA_OPTS="-Xms512m -Xmx1024m" ./startup.sh 这段代码将JVM初始堆内存设置为512MB,最大堆内存设置为1024MB。 4.2 调整日志级别 在运行时,我们可以通过发送HUP信号给Tomcat来动态更改日志级别,无需重启服务。假设我们要将org.apache.catalina.core包的日志级别调整为DEBUG: bash kill -1 pgrep java 然后编辑${CATALINA_BASE}/conf/logging.properties文件,调整日志级别,改动立即生效。 注意: 这里的pgrep java用于获取Java进程ID,实际情况请根据你的环境做出相应调整。 总的来说,掌握Tomcat命令行管理技巧能够让我们在部署、调试和运维过程中更加得心应手。希望通过这篇文章的详细介绍,你能更好地驾驭这只"猫",让它在你的开发之旅中发挥出最大的效能。在实际操作的过程中,千万记得要多动手尝试、多动脑思考!毕竟,只有把理论知识和实践经验紧密结合,咱们的技术之路才能越走越宽广,越走越长远。
2023-02-24 10:38:51
317
月下独酌
ClickHouse
...何高效地存储、处理和分析海量数据成为了每一个企业和组织面临的重要挑战。话说在这个大环境下,ClickHouse闪亮登场啦!它可是一款超级厉害的数据库系统,采用了列式存储的方式,嗖嗖地提升查询速度,延迟低到让你惊讶。这一特性瞬间就吸引了无数开发者和企业的眼球,大家都对它青睐有加呢! 二、ClickHouse的特性 ClickHouse的特点主要体现在以下几个方面: 1. 高性能 ClickHouse通过独特的列式存储方式和计算引擎,实现了极致的查询性能,对于实时查询和复杂分析场景有着显著的优势。 2. 稳定性 ClickHouse具有良好的稳定性,能够支持大规模的数据处理和分析,并且能够在分布式环境下提供高可用的服务。 3. 易用性 ClickHouse提供了直观易用的SQL接口,使得数据分析变得更加简单和便捷。 三、使用ClickHouse实现高可用性架构 1. 什么是高可用性架构? 所谓高可用性架构,就是指一个系统能够在出现故障的情况下,仍能继续提供服务,保证业务的连续性和稳定性。在实际应用中,我们通常会采用冗余、负载均衡等手段来构建高可用性架构。 2. 如何使用ClickHouse实现高可用性架构? (1) 冗余部署 我们可以将多个ClickHouse服务器进行冗余部署,当某个服务器出现故障时,其他服务器可以接管其工作,保证服务的持续性。比如说,我们可以动手搭建一个ClickHouse集群,这个集群里头有三个节点。具体咋安排呢?两个节点咱们让它担任主力,也就是主节点的角色;剩下一个节点呢,就作为备胎,也就是备用节点,随时待命准备接替工作。 (2) 负载均衡 通过负载均衡器,我们可以将用户的请求均匀地分发到各个ClickHouse服务器上,避免某一台服务器因为承受过大的压力而出现性能下降或者故障的情况。比如,我们可以让Nginx大显身手,充当一个超级智能的负载均衡器。想象一下,当请求像潮水般涌来时,Nginx这家伙能够灵活运用各种策略,比如轮询啊、最少连接数这类玩法,把请求均匀地分配到各个服务器上,保证每个服务器都能忙而不乱地处理任务。 (3) 数据备份和恢复 为了防止因数据丢失而导致的问题,我们需要定期对ClickHouse的数据进行备份,并在需要时进行恢复。例如,我们可以使用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
ActiveMQ
...造成的: - 未正确配置持久化机制:ActiveMQ默认是非持久化的,这意味着如果消息队列崩溃,存储在内存中的消息将会丢失。 - 消息确认机制配置错误:如果消息确认机制配置不当,可能会导致消息重复消费或丢失。 java // 创建一个持久化的队列 Destination destination = session.createQueue("PERSISTENT.TEST.QUEUE"); // 创建一个生产者并设置持久化选项 MessageProducer producer = session.createProducer(destination); producer.setDeliveryMode(DeliveryMode.PERSISTENT); 5.2 预防措施 为了防止数据丢失,我们可以采取以下措施: - 启用持久化机制:确保消息在发送之前被持久化到磁盘。 - 正确配置消息确认机制:确保消息在成功处理后才被确认。 java // 使用事务来确保消息的可靠发送 Session session = connection.createSession(true, Session.SESSION_TRANSACTED); // 发送消息 producer.send(message); // 提交事务 session.commit(); 6. 数据不一致的原因及预防措施 6.1 数据不一致的原因 除了数据丢失,数据不一致也是一个严重的问题。这可能是因为: - 消息重复消费:如果消息队列没有正确地处理重复消息,可能会导致数据不一致。 - 消息顺序混乱:消息在传输过程中可能会被打乱,导致处理顺序错误。 java // 使用唯一标识符来避免重复消费 TextMessage message = session.createTextMessage("Hello, World!"); message.setJMSMessageID(UUID.randomUUID().toString()); producer.send(message); 6.2 预防措施 为了避免数据不一致,我们可以: - 使用唯一标识符:为每条消息添加一个唯一的标识符,以便识别重复消息。 - 保证消息顺序:确保消息按照正确的顺序被处理。 java // 使用事务来保证消息顺序 Session session = connection.createSession(true, Session.SESSION_TRANSACTED); // 发送多条消息 for (int i = 0; i < 10; i++) { TextMessage message = session.createTextMessage("Message " + i); producer.send(message); } // 提交事务 session.commit(); 7. 结论 总之,ActiveMQ是一个功能强大的消息队列工具,但在使用过程中需要特别注意故障恢复策略。通过巧妙设置持久化方式和消息确认系统,我们能大幅减少数据丢失的几率。另外,用唯一标识符和事务来确保消息顺序,这样就能很好地避免数据打架的问题了。希望这篇文章能够帮助大家更好地理解和应对ActiveMQ中的这些问题。如果你有任何疑问或建议,欢迎在评论区留言交流! --- 这篇文章力求通过具体的代码示例和实际操作,帮助读者更好地理解和解决ActiveMQ中的故障恢复问题。希望它能对你有所帮助!
2025-02-06 16:32:52
23
青春印记
PostgreSQL
...工具通常可以帮助我们分析SQL语句的执行计划、索引使用情况以及潜在的资源消耗等,以便于我们对SQL进行优化改进。在实际操作中,如果咱们对这些工具的认识和运用不够熟练精通的话,那可能会出现“优化”不成,反而帮了倒忙的情况,让SQL的执行效率不升反降。 例如,假设我们在一个包含数百万条记录的orders表中查找特定用户的订单: sql -- 不恰当的SQL示例 SELECT FROM orders WHERE user_id = 'some_user'; 虽然可能有针对user_id的索引,但如果直接运行此查询并依赖优化工具盲目添加或调整索引,而不考虑查询的具体内容(如全表扫描),可能会导致SQL执行效率下降。 2. 理解PostgreSQL的查询规划器与执行计划 在PostgreSQL中,查询规划器负责生成最优的执行计划。要是我们没找准时机,灵活运用那些SQL优化神器,那么这个规划器小家伙,可能就会“迷路”,选了一条并非最优的执行路线。比如,对于上述例子,更好的方式是只选择需要的列而非全部: sql -- 更优的SQL示例 SELECT order_id, order_date FROM orders WHERE user_id = 'some_user'; 同时,结合EXPLAIN命令查看执行计划: sql EXPLAIN SELECT order_id, order_date FROM orders WHERE user_id = 'some_user'; 这样,我们可以清晰地了解查询是如何执行的,包括是否有效利用了索引。 3. 错误使用索引优化工具的案例分析 有时候,我们可能过于依赖SQL优化工具推荐的索引创建策略。例如,工具可能会建议为每个经常出现在WHERE子句中的字段创建索引。但这样做并不总是有益的,尤其是当涉及多列查询或者数据分布不均匀时。 sql -- 错误的索引创建示例 CREATE INDEX idx_orders_user ON orders (user_id); 如果user_id字段值分布非常均匀,新创建的索引可能不会带来显著性能提升。相反,综合考虑查询模式创建复合索引可能会更有效: sql -- 更合适的复合索引创建示例 CREATE INDEX idx_orders_user_order_date ON orders (user_id, order_date); 4. 结论与反思 面对SQL执行效率低下,我们需要深度理解SQL优化工具背后的原理,并结合具体业务场景进行细致分析。只有这样,才能避免因为工具使用不当而带来的负面影响。所以呢,与其稀里糊涂地全靠自动化工具,咱们还不如踏踏实实地去深入了解数据库内部是怎么运转的,既要明白表面现象,更要摸透背后的原理。这样一来,咱就能更接地气、更靠谱地制定出高效的SQL优化方案了。 总之,在PostgreSQL的世界里,SQL优化并非一蹴而就的事情,它要求我们具备严谨的逻辑思维、深入的技术洞察以及灵活应变的能力。让我们在实践中不断学习、思考和探索,共同提升PostgreSQL的SQL执行效率吧! 注:全表扫描在数据量巨大时往往意味着较低的查询效率,尤其当仅需少量数据时。
2023-09-28 21:06:07
264
冬日暖阳
Netty
...中的核心启动类,用于配置和初始化一个新的客户端或服务器端Channel。通过设置线程模型、选择传输层协议、配置网络选项及处理器链等步骤,Bootstrap帮助开发者方便快捷地构建高性能的网络应用程序,并支持批量创建和管理连接,从而实现在Netty中建立客户端连接池的功能。 ChannelFutureGroup , ChannelFutureGroup是Netty提供的一个接口,主要用于管理和跟踪一组ChannelFuture对象的状态。ChannelFuture代表了一个异步I/O操作的结果,而ChannelFutureGroup则可以用来批量处理多个ChannelFuture的完成状态,比如在批量创建连接时,等待所有连接成功建立。
2023-12-01 10:11:20
85
岁月如歌-t
转载文章
...、图数据查询、图数据分析和图数据可视化。 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
转载
DorisDB
...主研发的高性能、实时分析型MPP数据库,可厉害了!它有着超强的并行处理肌肉,对海量数据管理那叫一个游刃有余。特别是在数据导入导出这块儿,表现得尤为出色,让人忍不住要拍手称赞!本文打算手把手地带大家,通过实实在在的操作演示和接地气的代码实例,深度探索DorisDB这个神器是如何玩转高效的数据导入导出,让数据流转变得轻松又快捷。 2. DorisDB数据导入机制 - Broker Load (1)Broker Load 简介 Broker Load是DorisDB提供的一种高效批量导入方式,它充分利用分布式架构,通过Broker节点进行数据分发,实现多线程并行加载数据,显著提高数据导入速度。 sql -- 创建一个Broker Load任务 LOAD DATA INPATH '/path/to/your/data' INTO TABLE your_table; 上述命令会从指定路径读取数据文件,并将其高效地导入到名为your_table的表中。Broker Load这个功能可厉害了,甭管是您电脑上的本地文件系统,还是像HDFS这种大型的数据仓库,它都能无缝对接,灵活适应各种不同的数据迁移需求场景,真可谓是个全能型的搬家小能手! (2)理解 Broker Load 的内部运作过程 当我们执行Broker Load命令时,DorisDB首先会与Broker节点建立连接,然后 Broker 节点根据集群拓扑结构将数据均匀分发到各Backend节点上,每个Backend节点再独立完成数据的解析和导入工作。这种分布式的并行处理方式大大提高了数据导入效率。 3. DorisDB数据导出机制 - EXPORT (1)EXPORT功能介绍 DorisDB同样提供了高效的数据导出功能——EXPORT命令,可以将数据以CSV格式导出至指定目录。 sql -- 执行数据导出 EXPORT TABLE your_table TO '/path/to/export' WITH broker='broker_name'; 此命令将会把your_table中的所有数据以CSV格式导出到指定的路径下。这里使用的也是Broker服务,因此同样能实现高效的并行导出。 (2)EXPORT背后的思考 EXPORT的设计充分考虑了数据安全性与一致性,导出过程中会对表进行轻量级锁定,确保数据的一致性。同时,利用Broker节点的并行能力,有效减少了大规模数据导出所需的时间。 4. 高效实战案例 假设我们有一个电商用户行为日志表user_behavior需要导入到DorisDB中,且后续还需要定期将处理后的数据导出进行进一步分析。 sql -- 使用Broker Load导入数据 LOAD DATA INPATH 'hdfs://path_to_raw_data/user_behavior.log' INTO TABLE user_behavior; -- 对数据进行清洗和分析后,使用EXPORT导出结果 EXPORT TABLE processed_user_behavior TO 'hdfs://path_to_export/processed_data' WITH broker='default_broker'; 在这个过程中,我们可以明显感受到DorisDB在数据导入导出方面的高效性,以及对复杂业务场景的良好适应性。 5. 结语 总的来说,DorisDB凭借其独特的Broker Load和EXPORT机制,在保证数据一致性和完整性的同时,实现了数据的高效导入与导出。对企业来讲,这就意味着能够迅速对业务需求做出响应,像变魔术一样灵活地进行数据分析,从而为企业决策提供无比强大的支撑力量。就像是给企业装上了一双洞察商机、灵活分析的智慧眼睛,让企业在关键时刻总能快人一步,做出明智决策。探索DorisDB的技术魅力,就像解开一把开启大数据宝藏的钥匙,让我们在实践中不断挖掘它的潜能,享受这一高效便捷的数据处理之旅。
2023-01-08 22:25:12
456
幽谷听泉
Gradle
...来。理解这一点是正确配置和打包依赖的关键。 1.1 在build.gradle文件中声明依赖 每个Gradle项目都有一个或多个build.gradle文件,这是配置项目构建过程的地方。在这里,我们可以用groovy或者kotlin DSL来声明依赖。例如: groovy dependencies { // 声明一个Java项目的编译期依赖 implementation 'com.google.guava:guava:30.1-jre' // 声明测试相关的依赖 testImplementation 'junit:junit:4.13.2' // 声明运行时需要但编译时不需要的依赖 runtimeOnly 'mysql:mysql-connector-java:8.0.26' } 上述代码中,我们在dependencies块内通过implementation、testImplementation和runtimeOnly等方式分别指定了不同类型的依赖。 2. 控制依赖范围与传递性 2.1 依赖范围 Gradle为依赖提供了多种范围,如implementation、api、compileOnly等,用于控制依赖在编译、测试及运行阶段的作用域。比方说,implementation这个家伙的作用,就好比你有一个小秘密,只告诉自己模块内部的成员,不会跑去跟依赖它的其他模块小伙伴瞎嚷嚷。但是,当你用上api的时候,那就相当于你不仅告诉了自家模块的成员,还大方地把这个接口分享给了所有下游模块的朋友。 2.2 依赖传递性 默认情况下,Gradle具有依赖传递性,即如果A模块依赖B模块,而B模块又依赖C模块,那么A模块间接依赖了C模块。有时我们需要控制这种传递性,可以通过transitive属性进行设置: groovy dependencies { implementation('org.hibernate:hibernate-core:5.6.9.Final') { transitive = false // 禁止传递依赖 } } 3. 使用定制化仓库 除了标准的Maven中央仓库,我们还可以添加自定义的仓库地址来下载依赖包: groovy repositories { mavenCentral() // 默认的Maven中央仓库 maven { url 'https://maven.example.com/repo' } // 自定义仓库 } 4. 打包时包含依赖 当执行gradle build命令时,Gradle会自动处理并包含所有已声明的依赖。对于Java应用,使用jar任务打包时,默认并不会将依赖打进生成的jar文件中。若需将依赖包含进去,可采用如下方式: groovy task fatJar(type: Jar) { archiveBaseName = 'my-fat-app' from { configurations.runtimeClasspath.collect { it.isDirectory() ? it : zipTree(it) } } with jar } 这段代码创建了一个名为fatJar的任务,它将运行时依赖一并打包进同一个jar文件中,便于部署和运行。 总结来说,掌握Gradle依赖管理的核心在于理解其声明式依赖配置以及对依赖范围、传递性的掌控。同时,咱们在打包的时候,得瞅准实际情况,灵活选择最合适的策略把依赖项一并打包进去,这样才能保证咱们的项目构建既一步到位,又快马加鞭,准确高效没商量。在整个开发过程中,Gradle就像个超级灵活、无比顺手的工具箱,让开发者能够轻轻松松解决各种乱七八糟、错综复杂的依赖关系难题,真可谓是个得力小助手。
2023-06-09 14:26:29
408
凌波微步_
Linux
如何配置Linux系统的定时任务(Cron)的优先级:深入探索与实践 在Linux世界中,cron作为系统级别的定时任务调度器,负责按照预设的时间表执行各类脚本或命令。不过有时候,我们巴不得在电脑资源紧张的时候,让那些至关重要的任务优先跑起来,就像插队买票一样,先干重要的活儿。嘿,朋友,这篇文会带你畅游Linux定时任务的神奇天地,咱一块琢磨下如何机智地把Systemd Timer这位新秀和老牌悍将crontab联手起来,实现对定时任务优先级随心所欲的个性化设置,让你的Linux小宇宙更加井然有序、充满活力! 1. Cron基础认知 首先,让我们回顾一下cron的基础知识。每个Linux用户都有自己的crontab文件,用于存储定时任务列表。我们可以使用crontab -e命令编辑个人的定时任务配置: bash $ crontab -e 然后,在打开的编辑器中添加一行典型的定时任务配置,比如每天凌晨2点执行某个脚本important_script.sh: bash 0 2 /path/to/important_script.sh 然而,cron本身并不直接提供任务间的优先级设置功能,所有任务基本遵循先到先执行的原则。为了解决这个问题,我们将引入Systemd Timer机制来实现更高级别的控制。 2. Systemd Timer简介 Systemd Timer是Systemd的一部分,它可以与Service配合,以时间间隔或者特定时间点触发服务运行,并且提供了丰富的配置选项,包括任务执行的优先级设定。 创建一个Systemd Timer文件,例如important_task.timer: ini /etc/systemd/system/important_task.timer [Unit] Description=High Priority Timer for Important Task [Timer] OnCalendar=daily 每天触发一次 Persistent=true 如果错过触发时间,则尽快执行一次 [Install] WantedBy=timers.target 接着,创建对应的Service文件important_task.service,指定要执行的任务: ini /etc/systemd/system/important_task.service [Unit] Description=Execute Important Script [Service] ExecStart=/path/to/important_script.sh Nice=15 可以调整任务的优先级,数值越小,优先级越高 3. 设置任务优先级 注意到在important_task.service文件中的Nice字段,这是用来设置进程优先级的。在Linux系统里,nice这个小东西就像个调度员手中的优先权令牌,它决定了各个进程抢夺CPU资源时的相对先后顺序。这个优先级数值呢,通常会从-20开始耍,代表着“最高大上”的优先级;然后一路悠哉悠哉地滑到19,这表示的是“最低调”级别的优先级啦。默认情况下,每个进程都是以0这个中间值起步的,不偏不倚,童叟无欺。在这儿,我们把那些至关重要的任务,比如像“Nice=-5”这样的,优先级调得贼高,这样一来,它们就能分到更多的系统资源,妥妥地保障完成。 此外,还可以通过LimitCPU、LimitFSIZE等配置项进一步限制其他非关键任务占用资源,间接提高重要任务的执行效率。 4. 启动并管理定时任务 启用新创建的Systemd Timer和服务,并查看状态: bash sudo systemctl enable important_task.timer sudo systemctl start important_task.timer sudo systemctl status important_task.timer 这样,我们就成功地用Systemd Timer为“重要任务”设置了优先级,即使在系统繁忙时段也能保证其顺利执行。 结语 在面对复杂的Linux系统管理问题时,灵活运用各种工具与技术手段显得尤为重要。经过对cron和Systemd Timer的深入理解,再灵活搭配使用,咱们就能在Linux系统里把定时任务管理得明明白白,还能随心所欲地调整它们执行的优先级,就像给每个任务安排专属的时间表和VIP通道一样。这种策略不仅让系统的稳定性噌噌往上涨,还为自动化运维开辟了更多新玩法和可能性,让运维工作变得更高效、更便捷。而每一次这样的实战经历,就像是我们在Linux天地间的一场头脑风暴和经验值的大丰收,真心值得我们撸起袖子深入钻研,不断去打磨提升。
2023-05-19 23:21:54
57
红尘漫步
SpringCloud
...过程中,我们经常需要配置一些Bean来实现特定的功能。而这些Bean通常是通过@Configuration注解来定义的。然而,在真实世界的应用场景里,我们往往会发现一个秘密:@Configuration类竟然会被偷偷地做代理处理。你可能会问,哎,这是为啥呢?这就得揭开@Configuration类被代理背后的神秘面纱啦! 二、@Configuration类被代理的原理 在了解@Configuration类被代理的原理之前,我们需要了解一下什么是代理。代理是一种设计模式,它可以作为其他对象的一个替身或者行为的包装器。当你想要给某个东西加点料,改改它的表现方式时,咱们可以脑洞大开,造个替身出来,让它代替原本的那个家伙去干活儿,这样一来,就轻而易举地实现了我们的小目标。 那么@Configuration类是如何被代理的呢?让我们一起来看看Spring的源码吧! 三、源码解析 在Spring的源码中,当我们使用@Configuration注解的时候,实际上Spring会对这个类进行一些特殊的处理。首先,Spring会创建一个代理对象来替代@Configuration类本身。然后,你瞧这啊,当程序去呼唤@Configuration这个类里面的方法时,实际上它玩的是代理对象的小把戏,就是在调用代理对象的方法呢。 在这个过程中,Spring做了两件事情: 1. 保存原始类的引用 在创建代理对象的时候,Spring会保存原始类的引用,以便在需要的时候能够恢复到原始类。这是因为代理对象就像是原始类的一个分身小弟,它代替原始类执行任务。但如果我们让它完全取代了原始类这位“大哥”,那我们可就摸不着头脑了,没法再去调用原始类那些特有的方法和属性了。 2. 添加拦截器 在创建代理对象的时候,Spring还会添加一些拦截器。这些拦截器会在代理对象执行方法之前和之后做一些额外的操作。比如说,我们可以插一个拦截器,就像一个小秘书那样,专门记录下每次方法被调用的具体时间。这样一来,我们就能像看手表一样,实时掌握系统的运行效率和性能状况了。 这就是@Configuration类被代理的基本原理。下面我们来看一个具体的例子。 四、实战演示 假设我们有一个@Service类,它里面有一些业务逻辑。现在呢,我们想要实时地盯着这些业务逻辑的运行状况,就像有个小雷达一样随时监测。所以,咱们琢磨了一下,决定动手用Spring的那个强大的AOP功能,来帮我们达成这个小心愿。不过,在配置的过程中,我们碰到了个不大不小的难题,那就是咱们还没搞清楚到底该在哪些环节巧妙地插入AOP的切面。这时,我们就需要用到@Configuration类了。 在@Configuration类中,我们可以添加一个@Bean注解来声明一个Bean。而在@Bean注解后面,我们可以添加一个方法来返回这个Bean。那么,如果我们想要给这个Bean添加一个切面,我们应该怎么做呢? 这时,我们就需要用到Spring的AOP功能了。我们可以用@Aspect这个小家伙来标记一个切面,接着再通过@Pointcut这个小帮手来确定我们要切入的具体位置。就像是在编程的世界里画了个“切割符号”,先声明“我要处理哪一类事情”(切面),再具体指定“在哪儿动手做”(切点)。最后,我来给你说个有趣的事情,我们可以用一个叫@Around的神奇小标签,给它定义一个“通知员”的角色。每当找到符合条件的方法要开始执行或者已经执行完毕时,这位“通知员”就会自动出场,前后忙活起来。 然后,我们将这个切面注入到Spring的ApplicationContext中,这样就可以在运行的时候使用这个切面了。 五、总结 @Configuration类被代理是Spring的一种重要特性,它为我们提供了一种方便的方式来管理和配置Bean。了解了@Configuration类被代理的原理后,咱们就能更深入地掌握Spring的AOP功能,而且能够随心所欲地运用@Configuration类来满足咱们的各种需求,让编程变得更加游刃有余。
2023-10-23 20:18:43
129
海阔天空_t
c#
...将对这个问题进行深入分析,并提供一些实用的解决方案。 二、问题概述 在封装SqlHelper类时,我们往往会定义一系列方法来操作数据库,如增删改查等。其中,插入数据的方法是最基础也是最常见的操作之一。不过呢,当我们想要把数据塞进去的时候,可能会冒出各种幺蛾子,比如参数没对准、SQL语句写得语法不对劲儿,甚至有时候直接插不进去,这些情况都可能发生。 三、原因分析 为什么会出现这些问题呢?其实,主要原因有两个: 1. 参数传递不正确 在调用insert方法时,我们需要传入要插入的数据。如果这些数据的类型、格式或数量不符合预期,就可能导致插入失败。 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
410
素颜如水_t
ActiveMQ
...段Camel DSL配置表示的是,根据color头部属性值的不同,消息会被路由至不同的目标队列。 (2)复合路由器(Composite Destinations) 另外,ActiveMQ还可以利用复合目的地(Composite Destinations)实现消息的多路广播。一条消息可以同时发送到多个目的地: java Destination[] destinations = {destination1, destination2}; MessageProducer producer = session.createProducer(null); producer.send(message, DeliveryMode.PERSISTENT, priority, timeToLive, destinations); 在这个例子中,一条消息会同时被发送到destination1和destination2两个队列。 3. 思考与探讨 理解并掌握ActiveMQ的消息过滤与路由规则,对于优化系统架构、提升系统性能具有重要意义。这就像是在那个熙熙攘攘的物流中心,我们不能一股脑儿把包裹都堆成山,而是得像玩拼图那样,瞅准每个包裹上的标签信息,然后像给宝贝找家一样,精准地把这些包裹送达到各自对应的地区仓库里头去。同样的,在消息队列中,精准高效的消息路由能力能够帮助我们构建更加健壮、灵活的分布式系统。 总的来说,ActiveMQ通过丰富的API和强大的路由策略,让我们在面对复杂业务逻辑时,能更自如地定制消息过滤与路由规则,使我们的系统设计更加贴近实际业务需求,让消息传递变得更为智能和精准。不过,实际上啊,咱们在真正用起来的时候,千万不能忽视系统的性能和扩展性这些重要因素。得把这些特性灵活巧妙地运用起来,才能让它们发挥出应有的作用,就像是做菜时合理搭配各种调料一样,缺一不可!
2023-12-25 10:35:49
422
笑傲江湖
JSON
...模JSON数据的实时分析与检索场景,NoSQL数据库如MongoDB充分利用JSON文档型数据模型的优势,支持索引、聚合等多种高级查询功能,使得查询第二条或任何特定条件的记录变得轻松且高效。 综上所述,无论是在编程语言层面,还是在数据库系统及API设计领域,围绕JSON数据查询的技术手段正不断演进与丰富,以适应日益复杂的应用需求与挑战。开发者应紧跟技术潮流,灵活运用这些工具与策略,提升自身处理JSON数据的能力与实战经验。
2023-04-13 20:41:35
460
烟雨江南
Linux
... 第四章:安装与配置 4.1 安装SQL Server - 使用yum安装SQL Server,记得替换版本号和实例名称。 bash sudo yum install mssql-server-2016 -y sudo systemctl start msopengauss - 如果是社区版,可能会看到类似mssql-server的包名。 4.2 配置和初始化 - 使用mssql-conf工具进行基本配置,如设置监听端口和密码。 bash sudo opt/mssql/bin/mssql-conf setup - 选择“Custom Configuration”,根据需要自定义安装。 4.3 数据库实例管理 - 创建数据库实例,例如: bash sudo opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P 'your_password' -Q "CREATE DATABASE YourDatabaseName" - 更改默认的sa用户密码: bash sudo opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P 'old_password' -Q "ALTER LOGIN sa WITH PASSWORD = 'new_password'" 第五章:连接与验证 5.1 命令行工具 - 使用sqlcmd工具连接到新安装的数据库。 bash sqlcmd -S localhost -U sa -P 'your_password' - 验证连接成功后,可以执行查询操作。 5.2图形化工具 - 可以选择安装SQL Server Management Studio(SSMS)的Linux版本,或者使用第三方工具如ssms-linux,来进行更直观的管理。 结论 6.1 总结与展望 - CentOS 7确实可以安装SQL Server 2016,尽管它已经不再是最新版本,但对于那些还在使用或需要兼容旧版本的用户来说,这是一个可行的选择。 - 未来,随着技术的迭代,SQL Server on Linux的体验会越来越完善,跨平台的数据库管理将更加无缝。 在这个快速发展的技术时代,适应变化并充分利用新的工具是关键。真心希望这篇指南能像老朋友一样,手把手教你轻松搞定在Linux大本营里安装和打理SQL Server 2016的那些事儿,让你畅游在数据库的海洋里无阻无碍。嘿,想找最潮的解决招数对吧?记得翻翻官方手册,那里有新鲜出炉的支援和超实用的建议!
2024-04-11 11:07:55
96
醉卧沙场_
Mahout
...大规模数据集的处理与分析,如协同过滤、聚类、分类等任务。在本文语境中,Mahout是帮助用户有效管理和优化内存使用以及磁盘I/O的关键工具,尤其适合用于大数据环境下的机器学习实践。 流式处理 , 流式处理是一种数据处理范式,允许系统连续地接收、处理并生成数据流的结果,而无需等待所有输入数据全部到达或一次性加载到内存中。在文章中,流式处理被比喻为“吃饭时分批品尝菜肴”,对应于数据处理场景,则表示将大型数据集分批读取和逐步处理,以减轻对内存资源的压力,例如通过Mahout中的StreamingVectorSpaceModel实现。 数据缓存 , 数据缓存是一种提高数据访问速度的技术,它将常用或最近使用的数据存储在快速存取的存储器(如RAM)中,以便在后续请求时直接从内存读取,从而减少对较慢存储设备(如硬盘)的频繁访问。在本文中,为了优化磁盘I/O,推荐使用MapReduce框架中的CacheManager来设置数据缓存,预先将常用数据加载至内存,避免大量磁盘读写操作造成的性能瓶颈。
2023-04-03 17:43:18
87
雪域高原-t
Kibana
...代,有一个强大的数据分析和可视化工具叫做Kibana,它能够帮助我们更好地理解和分析数据。那么,你是否想过,Kibana在数据挖掘中有哪些具体的应用呢? 二、什么是Kibana? Kibana是一款开源的数据分析和可视化工具,它的主要功能是对存储在Elasticsearch中的数据进行搜索、查看和分析,并通过可视化的方式展示出来,便于我们更好地理解和掌握数据。 三、Kibana在数据挖掘中的应用 1. 数据分析和可视化 Kibana最强大的功能就是数据分析和可视化。用Kibana这个工具,咱们就能随心所欲地绘制各种图表,比如柱状图、折线图、饼图等等,这样一来,那些复杂到让人头大的数据就能瞬间变得一目了然,像看图画书一样简单明了。这样一来,咱们就能更直观、更接地气地摸清数据的走势和内在规律,进而更高效、更精准地挖出数据中的宝藏。 举例来说,假设我们想要对一个网站的日访问量数据进行分析。我们可以在Kibana中创建一个柱状图,然后将每日的访问量数据输入进去。这样,我们就能实实在在地瞅见每天访问量的起伏变化,一眼洞察到哪些天人气最旺、访问量蹭蹭往上涨,又有哪些天稍微冷清些、访问量有所下滑,还能摸清楚访问量整体走势的那些小秘密~ 2. 自定义查询和过滤器 Kibana还支持自定义查询和过滤器,让我们可以根据自己的需求对数据进行深入挖掘和分析。比如,如果我们好奇哪个城市在某个时间段里最受用户欢迎,访问量最大,我们只需要在Kibana这个工具里轻松设置个过滤器,就能立马得到想要的答案啦! 举例来说,假设我们有一份包含用户地理位置和访问时间的数据。在Kibana这个工具里头,我们可以捣鼓一下,先搞个过滤器,让它只显示某个时间段内的数据内容。接着再接再厉,设置第二个过滤器,这次是专门用来筛选出某个特定城市的详细信息。这样一来,数据就像被我们精准地“框选”出来了,既实用又直观。这样,我们就能掌握这个城市在那个时间段里被访问的情况,进而对这些数据进行更深层次的挖掘和分析。 3. 实时监控 Kibana还提供了一些其他的功能,例如实时监控、警报、报告等。这些功能可以帮助我们及时发现问题,提高工作效率。 举例来说,如果我们有一个在线商城,我们需要时刻关注商品销售情况。嘿,你知道吗?咱们可以在Kibana这个工具里整一个超酷的实时监控功能。这样一来,只要商品销售数量有丁点儿风吹草动,立马就能触发警报提醒我们,就像有个小雷达时刻帮咱盯着呢!这样,我们就可以及时调整销售策略,提高销售额。 四、结论 总的来说,Kibana是一款非常强大且实用的数据分析和可视化工具,它可以帮助我们在数据挖掘中节省大量时间和精力,提高工作效率。如果你还没有尝试过使用Kibana进行数据挖掘,我强烈建议你试一试。相信你一定会被它的强大功能所吸引!
2023-06-10 18:59:47
306
心灵驿站-t
MemCache
...ed支持多服务器集群配置,通过在多台服务器上分散存储缓存数据,即使某一台服务器崩溃,其他服务器仍然能够提供部分缓存服务,降低整体数据丢失的影响。 03.4 数据持久化探索 虽然Memcached本身不支持数据持久化,但社区有一些变通的解决方案,如memcachedb、twemproxy等中间件,它们在一定程度上实现了缓存数据的持久化,不过这会牺牲一部分性能且增加系统复杂性,因此在选择时需权衡利弊。 0 4. 结论与思考 尽管Memcached服务崩溃会导致所有缓存数据丢失,但这并不妨碍它在提升系统性能方面发挥关键作用。作为开发者,咱们得充分意识到这个问题的重要性,并且动手去解决它。咱可以想想怎么设计出更合理的架构,重建一下数据策略,再比如利用集群技术和持久化方案这些手段,就能妥妥地应对这个问题了。每一个技术工具都有它自己的“用武之地”和“短板”,关键在于我们如何去洞察并巧妙运用,让它们在实际场景中最大程度地发光发热,发挥出最大的价值。就像一把锤子,不是所有问题都是钉子,但只要找准地方,就能敲出实实在在的效果。每一次遇到挑战,都是一次深度理解技术和优化系统的契机,让我们共同在实践中成长。
2023-09-25 18:48:16
61
青山绿水
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
screen 或 tmux
- 创建持久化会话,可以在断开SSH连接后恢复工作。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
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
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"