当我通过 puppet 更改 redis 配置时,除了重新启动 redis 服务之外,有没有更好的方法来加载配置?
答案1
是的,您可以这样做,但这需要在 Puppet 中编写自己的客户提供商。这并非易事,但如果您愿意减少您关心的设置,它会更简单。
一个简单的例子可能是只动态设置主服务器或从服务器。我们会将这些参数添加到您的 Redis 类中。我们当然会模板化 redis.conf,并将这些设置放入其中,就像您现在可能做的那样。然后您需要某种语法,例如下面的语法,因为语义可能更具表现力。
redisconf { 'master': enable => 'true', }
redisconf 将是您的自定义提供程序,用 Ruby 编写。它需要连接到 Redis 服务器的端口(这是您需要设置的另一个输入和默认值)。连接后,您需要发出信息并获取结果输出作为哈希值。
第一步是确定你使用的 Redis 版本。如果是 2.4/2.6,你可以使用配置集和配置获取,否则您将使用我们已经拥有的哈希并手动运行命令。在我们的示例中,您将检查角色的值。如果它是主服务器,则不执行任何操作。如果它是从服务器,则执行“slaveof no one”并生成 Puppet 事件。假设存在差异,redisconf Puppet 提供程序将需要进行更改并理想情况下进行验证或抛出错误。将整个内容包装在 Puppet-isms 中,您就可以开始了。
如果您决定接受的话,这将是一个不错的小项目。
答案2
只要您通过保存指令设置了持久性,重新启动(大多数)都是非破坏性的。
如果redis进程没有持久化,可以用CONFIG SET开启
telnet 127.0.0.1 1234
CONFIG SET SAVE "900 1 300 10 60 10000"
通过转到 dir 配置值指定的目录并查找等于 dbfilename 配置值的文件来检查数据备份是否已创建。创建后,您可以编辑配置并重新启动 redis,您将在日志中看到类似以下内容:
[17296] 18 Nov 00:38:32.253 * DB loaded from disk: 0.158 seconds
Viola,您已重新启动 redis 并保留了大部分数据,我排除了备份文件创建和重新启动之间发生的事情。
答案3
不,目前无法重新加载配置。
如果您操纵可通过以下方式调整的设置配置集您可以在正在运行的实例中设置它们,然后跳过重新启动。
不过,我不建议在正常情况下这样做,因为您可能会破坏配置文件,并且只有在下次重新启动该实例时才会注意到它。