一、基本概念
不加配置文件启动
直接执行启动命令,使用软件自带的默认参数。
方便、快速,适合测试环境。
缺点:灵活性差、配置不可控、不安全。
bashredis-server zookeeper-server-start.sh kafka-server-start.sh
指定配置文件启动
启动时加载外部配置文件,覆盖默认参数。
灵活可控,适合生产环境。
bashredis-server /etc/redis/redis.conf zookeeper-server-start.sh /usr/local/zookeeper/conf/zoo.cfg kafka-server-start.sh /usr/local/kafka/config/server.properties
二、Redis 示例
不加配置文件
端口:6379
无密码(安全性差)
数据目录:当前目录
日志输出:终端
指定配置文件(redis.conf)
bash例如下面的是在redis.conf的配置 port 6380 requirepass mypassword dir /var/lib/redis logfile /var/log/redis.log
端口改为 6380
启用密码
mypassword
数据文件存储在
/var/lib/redis
日志写入
/var/log/redis.log
三、ZooKeeper 示例
不加配置文件
默认数据目录
/tmp/zookeeper
客户端端口:2181
重启可能丢数据(因为 /tmp 会清理)
指定配置文件(zoo.cfg)
bash例如这个是在zoo.cfg下写的配置 dataDir=/usr/local/zookeeper/data clientPort=2181 tickTime=2000 initLimit=5 syncLimit=2
数据保存在固定目录
/usr/local/zookeeper/data
端口仍是 2181(可修改)
tickTime、initLimit、syncLimit 用于集群稳定性配置
四、Kafka 示例
不加配置文件
很少直接这样做,因为 Kafka 必须依赖配置文件才能运行(尤其是要指定 ZooKeeper 或 KRaft 模式)。
默认配置在
config/server.properties
指定配置文件(server.properties)
bash例如这是在server.properties下写的配置 broker.id=0 listeners=PLAINTEXT://:9092 log.dirs=/usr/local/kafka/logs zookeeper.connect=localhost:2181
指定 broker 编号
服务监听端口 9092
日志保存路径
/usr/local/kafka/logs
关联 ZooKeeper 地址
五、总结对比
软件 不加配置文件(默认模式) 指定配置文件(推荐方式) Redis 6379 端口、无密码、数据在当前目录、日志输出到终端 自定义端口/密码/数据目录/日志路径,适合生产 ZooKeeper 数据在 /tmp/zookeeper
、端口 2181、可能丢数据自定义数据目录、端口、集群参数,适合持久运行 Kafka 基本不可用(需要配置) 必须配置 broker.id、监听地址、日志目录、ZooKeeper/KRaft 模式
✅ 一句话总结
不加配置文件:走默认参数,适合测试。
加配置文件:走自定义规则,适合生产,几乎所有生产环境都必须这样做。
软件启动时加配置文件 vs 不加配置文件
你我约定有三2025-09-06 12:50
相关推荐
华仔啊5 分钟前
Spring 配置混乱?搞懂这两个核心组件,问题真能少一半喂完待续17 分钟前
【序列晋升】45 Spring Data Elasticsearch 实战:3 个核心方案破解索引管理与复杂查询痛点,告别低效开发郑重其事,鹏程万里20 分钟前
commons-exec龙茶清欢21 分钟前
具有实际开发参考意义的 MyBatis-Plus BaseEntity 基类示例神龙斗士24024 分钟前
Java 数组的定义与使用计算机学姐25 分钟前
基于微信小程序的扶贫助农系统【2026最新】白露与泡影25 分钟前
2025互联网大厂高频Java面试真题解析forever銳26 分钟前
java中如何保证接口幂等性柯南二号28 分钟前
【Java后端】MyBatis 和 MyBatis-Plus (MP) 的区别斯普信专业组31 分钟前
fluent-bit使用kafka作为数据源采集问题