Maven下载安装

Maven安装与配置指南


1.下载安装

进入官网:https://maven.apache.org/
点击 Download ,往下拖选择这个 bin.zip 结尾的:
在这里插入图片描述
下载好之后解压到任意路径即可,尽量别放系统盘
可以放在这种位置:D:\Program Files\maven
在这里插入图片描述


2.配置环境变量

和配置JDK差不多,只是JAVA_HOME变成了MAVEN_HOME
添加一个MAVEN_HOME变量,值为你的maven安装路径
在这里插入图片描述
在path变量中添加一个值%MAVEN_HOME%\bin
在这里插入图片描述


3.测试安装结果

cmd命令行中输入mvn --version
弹出版本号说明安装成功,系统变量也配置正确
在这里插入图片描述


4.配置本地仓库

本地仓库默认为${user.home}/.m2/repository,也就是用户目录下,在系统盘,这样不好,需要修改一下

编辑conf下的settings.xml
在这里插入图片描述
我改到了这里:D:\maven\repository
settings下加上这么一段:

<localRepository>D:\maven\repository</localRepository>

在这里插入图片描述


5.配置中央仓库

中央仓库在国外,卡的要死,需要配置成国内的镜像仓库
把mirrors下面的mirror删了加上这段:
(这是阿里云的镜像,需要其他镜像可以去百度)

<mirror>
	<id>nexus-aliyun</id>
	<mirrorOf>central</mirrorOf>
	<name>Nexus aliyun</name>
	<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
</mirror>

在这里插入图片描述


6.测试仓库配置是否正确

创建一个Maven的java工程

模板,括号中内容自定义

mvn archetype:generate 
-DgroupId={project-packaging} 
-DartifactId={project-name} 
-DarchetypeArtifactId=maven-archetype-quickstart 
-DinteractiveMode=false

这里给一个例子

mvn archetype:generate -DgroupId=com.cxstar -DartifactId=my-test-project -DarchetypeArtifactId=maven-archetype-quickstart -Dversion=0.0.1-snapshot -DinteractiveMode=false

命令行执行后结果如下,如果下载速度很快,说明中央仓库配置成功
在这里插入图片描述
接下来可以试试maven的命令:

注意:如果执行以下命令时报了类似这种错
“[ERROR] 不再支持目标选项 1.5。请使用 1.6 或更高版本。”
那说明jdk和maven版本不匹配,在项目的pom.xml文件中的project标签下加入这段代码

<!-- 我是最新的jdk所以写的是11 根据你自己的jdk版本写 -->
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>11</maven.compiler.source>
    <maven.compiler.target>11</maven.compiler.target>
</properties>

1.mvn compile
在这里插入图片描述
2.mvn clean
在这里插入图片描述
3.mvn package
在这里插入图片描述
4.mvn install
在这里插入图片描述
随便执行一条命令,然后去刚才配置的本地仓库下看看
在这里插入图片描述
此时仓库有内容,说明本地仓库配置成功

RocketMQ 中,**分片(Sharding)** 是实现高并发、高可用和可展性的重要机制之一。其核心作用是将消息的存储和消费进行分布式管理,以支持大规模消息处理场景。 ### 分片的作用 1. **提升系统吞吐量** 通过将一个 Topic 的消息分布到多个 Broker 上,每个 Broker 负责一部分消息的存储和转发,从而实现横向展,提高整体系统的吞吐能力。 2. **支持负载均衡** 在消息生产与消费过程中,分片机制使得消息可以均匀分布在多个 Broker 上,生产者和消费者可以并行地处理多个分片,实现负载均衡[^5]。 3. **增强系统可用性与容错性** 每个分片可以配置主从结构(Master-Slave),实现数据复制与故障切换,确保在某个 Broker 故障时仍能保证消息的高可用[^4]。 ### 分片的工作机制 1. **Topic 与 Message Queue 的关系** 在 RocketMQ 中,每个 Topic 会被划分为多个 **Message Queue**(也称为队列或分片),这些队列分布在不同的 Broker 上。例如,一个 Topic 可能有 4 个队列,分别分布在两个 Broker 上,每个 Broker 管理两个队列。 2. **生产者的分片选择** 当生产者发送消息时,会根据一定的策略(如轮询、哈希等)选择一个合适的 Message Queue 进行投递。这一过程称为**生产者负载均衡**。生产者会定期从 NameServer 获取 Topic 的队列分布信息,以保证选择的准确性[^5]。 3. **消费者的分片分配** 消费者组(ConsumerGroup)中的每个消费者实例会负责一部分 Message Queue 的消费任务。这一过程称为**消费者负载均衡**,由 Broker 协调完成,确保每个队列只被一个消费者实例消费,从而避免重复消费和竞争问题。 4. **消息的物理存储** RocketMQ 将所有消息写入统一的 **CommitLog** 文件中,然后通过 **ConsumeQueue** 文件记录每个 Topic 的分片索引信息,实现逻辑分片与物理存储的分离。这种机制保证了写入的高效性和读取的灵活性[^4]。 ### 分片配置与管理 - **创建 Topic 时指定分片数量** 在创建 Topic 时,可以通过命令行或配置文件指定其分片数量(即 Message Queue 数量)。 - **动态容** 可以在不中断服务的情况下,向集群中新增 Broker,并为已有 Topic 增加分片,以应对不断增长的消息量。 ### 示例代码:查看 Topic 分片信息 ```bash # 查看 Topic 的队列分布信息 mqadmin topicRoute -n localhost:9876 -t MyTopic ``` 该命令将输出 Topic `MyTopic` 的路由信息,包括各个 Message Queue 所在的 Broker 地址。 ---
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

什么都干的派森

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值