В соответствии с http://redis.io/topics/security, Я могу установить requirepass
значение, например, requirepass foobared
в файлах конфигурации Redis.
Однако я не хочу этого в моих файлах конфигурации.
В принципе, я хочу, чтобы этот пароль не попадал в .conf
файлы и установите его, используя redis-cli
.
################################## SECURITY ###################################
# Require clients to issue AUTH <PASSWORD> before processing any other
# commands. This might be useful in environments in which you do not trust
# others with access to the host running redis-server.
#
# This should stay commented out for backward compatibility and because most
# people do not need auth (e.g. they run their own servers).
#
# Warning: since Redis is pretty fast an outside user can try up to
# 150k passwords per second against a good box. This means that you should
# use a very strong password otherwise it will be very easy to break.
#
# 2015.12.14 nbasanes: Although I prefer enabling this, I'm not
# sure it buys us much, since a clear password in a config
# file is bad for security:
# requirepass foobared
# 2015.12.14 nbasanes: This could be interesting, although
# I don't put much weight in security-by-obscurity:
# Command renaming.
#
# It is possible to change the name of dangerous commands in a shared
# environment. For instance the CONFIG command may be renamed into something
# hard to guess so that it will still be available for internal-use tools
# but not available for general clients.
#
# Example:
#
# rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52
#
# It is also possible to completely kill a command by renaming it into
# an empty string:
#
# rename-command CONFIG ""
#
# Please note that changing the name of commands that are logged into the
# AOF file or transmitted to slaves may cause problems.
Да, вы действительно можете установить requirepass
значение в активном экземпляре Redis.
В этом примере показано, как я устанавливаю его на подчиненное устройство Redis:
[nbasanes@SLAVEONE ~]$ redis-cli -h $(facter ipaddress)
101.222.222.222:6379> CONFIG SET REQUIREPASS FOOBARED
OK
101.222.222.222:6379> CONFIG SET REQUIREPA FOOBARED
(error) NOAUTH Authentication required.
101.222.222.222:6379> AUTH FOOBARED
OK
101.222.222.222:6379> CONFIG SET REQUIREPA FOOBARED
(error) ERR Unsupported CONFIG parameter: REQUIREPA
10.252.226.179:6379> ROLE
1) "slave"
2) "101.102.94.22"
3) (integer) 6379
4) "connected"
5) (integer) 702567
101.222.222.222:6379>
Да, можно изменить авторизацию во время выполнения. (См. Ответ Натана Басанеса).
Кроме того, не забудьте запустить команду config rewrite, чтобы аутентификация продолжалась. В противном случае он может быть потерян, если экземпляр Redis перезапустится.
CONFIG REWRITE
Вы можете получить список всех параметров, которые можно изменить во время выполнения, запустив CONFIG GET * для вашего экземпляра Redis.
127.0.0.1:6379> CONFIG GET *
1) "dbfilename"
2) "dump.rdb"
3) "requirepass"
4) ""
5) "masterauth"
6) ""
7) "unixsocket"
8) ""