FreeBSD 14
Sponsored Link

Redis 7 : SSL/TLS の設定2024/08/23

 

Redis で SSL/TLS による暗号化通信の設定を有効にします。

[1] 自己署名の証明書を作成します。Let's Encrypt 等の正規の証明書を使用する場合は当作業は不要です。
root@dlp:~ #
cd /usr/local/etc

root@dlp:/usr/local/etc #
openssl req -x509 -nodes -newkey rsa:2048 -keyout redis.pem -out redis.pem -days 3650

Generating a RSA private key
.................+++++
........+++++
writing new private key to 'vsftpd.pem'
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:JP                            # 国コード
State or Province Name (full name) [Some-State]:Hiroshima       # 地域(県)
Locality Name (eg, city) []:Hiroshima                           # 都市
Organization Name (eg, company) [Internet Widgits Pty Ltd]:GTS  # 組織名
Organizational Unit Name (eg, section) []:Server World          # 組織の部門名
Common Name (e.g. server FQDN or YOUR name) []:dlp.srv.world    # サーバーの FQDN
Email Address []:root@srv.world                                 # 管理者アドレス

root@dlp:/usr/local/etc #
chmod 600 redis.pem

root@dlp:/usr/local/etc #
chown redis:redis redis.pem

[2] Redis の SSL/TLS の設定です。
root@dlp:~ #
vi /usr/local/etc/redis.conf
# 138行目 : 変更 : [0] 指定でリスン無効化

port
0
# 195行目 : コメント解除

tls-port 6379
# 201,202行目 : コメント解除して証明書を指定

tls-cert-file
/usr/local/etc/redis.pem

tls-key-file
/usr/local/etc/redis.pem
# 246行目 : コメント解除

tls-auth-clients no
root@dlp:~ #
service redis restart

[3] クライアントからの接続です。他ホストから接続する場合は、事前に証明書をクライアントへ転送しておく必要があります。
root@node01:~ #
ll /usr/local/etc/redis.pem

-rw-------  1 root wheel uarch 3164 Aug 23 14:51 /usr/local/etc/redis.pem

# [tls] オプションと証明書を指定して接続する
root@node01:~ # redis-cli -h dlp.srv.world --tls \
--cert /usr/local/etc/redis.pem \
--key /usr/local/etc/redis.pem \
--cacert /usr/local/etc/redis.pem

dlp.srv.world:6379> auth password 
OK
dlp.srv.world:6379> info
# Server
redis_version:7.0.15
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:acbb172d25191eda
redis_mode:standalone
os:FreeBSD 14.1-RELEASE amd64
arch_bits:64
monotonic_clock:POSIX clock_gettime
multiplexing_api:kqueue
atomicvar_api:c11-builtin
gcc_version:4.2.1
process_id:994
process_supervised:no
run_id:7b3e1b07f0db8a38f417e7537f328f6322710c8d
tcp_port:6379
server_time_usec:1724392480769227
uptime_in_seconds:49
uptime_in_days:0
hz:10
configured_hz:10
lru_clock:13116448
executable:/usr/local/bin/redis-server
config_file:/usr/local/etc/redis.conf
io_threads_active:0
.....
.....
関連コンテンツ