cka-2026-ConfigMap

您必须连接到正确的主机。不这样做可能导致零分。

[ student@k8s-master1 ] $ ssh cka0000 00

Task

名为 nginx-stati c 的 NGINX Deployment 正在 nginx-static namespace 中运行。它通过名为 nginx-configConfigMap 进行配置。

更新 nginx-config ConfigMap 以仅允许TLSv1.2 TLSv1.3 连接。注意:您可以根据需要重新创建、重新启动或扩展资源。

您可以使用以下命令测试更改:

student @cka000048$ curl -k --tls-max 1.2 https://web.k8snginx.local

最后请将nginx-config ConfigMap 设置为不可变

题解:

步骤1、导nginx-config ConfigMap

由于 ConfigMap 的 immutable 属性设置为 true,不能直接更新现有的 ConfigMap。

需要先导出现有的 ConfigMap,然后删除现有的 ConfigMap ,并重新创建一个新的 ConfigMap

kubectl -n nginx-static get configmaps nginx-config

kubectl -n nginx-static get configmap nginx-config -o yaml > nginx-config.yaml

< 3 > 修改 nginx-config ConfigMap

vim nginx-config.yaml

在 data 部分中,修改 ssl_protocols 配置,将其值设置为 TLSv1.2 TLSv1.3;

bash 复制代码
apiVersion: v1
data:
  default.conf: |
    # 定义 Nginx 服务器块
    server {
        # 监听 443 端口,启用 SSL 加密
        listen 443 ssl;
        
        # 定义该服务器块的域名
        server_name web.k8snginx.local;

        # 指定 SSL 证书文件的路径(公钥)
        ssl_certificate /etc/nginx/ssl/tls.crt;

        # 指定 SSL 证书的私钥文件路径
        ssl_certificate_key /etc/nginx/ssl/tls.key;

        # 定义启用的 SSL 协议
        # 这里只启用了 TLSv1.3 以提高安全性
        ssl_protocols TLSv1.3;

        # 其他 SSL 设置,例如密码套件、HTTP/2 支持等,可以在此配置
        # ssl_ciphers 'HIGH:!aNULL:!MD5'; # 定义强加密密码套件的示例
        # ssl_prefer_server_ciphers on; # 可选,指定服务器优先使用的密码套件
        
        # 可选:启用 HTTP/2 支持以提高性能
        # listen 443 ssl http2;

        # 可选:配置额外的设置,比如重定向、错误页面等
        # 例如,强制 HTTP 请求重定向到 HTTPS:
        # server {
        #   listen 80;
        #   server_name web.k8snginx.local;
        #   return 301 https://$host$request_uri;
        # }
    }
bash 复制代码
apiVersion: v1
data:
default.conf: |
server {
listen 443 ssl;
server_name web.k8snginx.local;
ssl_certificate /etc/nginx/ssl/tls.crt;
ssl_certificate_key /etc/nginx/ssl/tls.key;
#ssl_protocols TLSv1.2 TLSv1.3;
ssl_protocols TLSv1.3;
...

添加不可变配置:

immutable: true #背掉这个单词

< 4 > 先删除,再重新创建 nginx-config ConfigMap

kubectl -n nginx-static delete configmaps nginx-config

kubectl apply -f nginx-config.yaml

< 5 > 需要重建 nginx-static Deployment。

kubectl rollout restart deployment nginx-static -n nginx-static

< 6 > 检查

确保新的 pod 是 running 的

kubectl -n nginx-static get pod

相关推荐
FQNmxDG4S5 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
青梅橘子皮5 小时前
Linux---基本指令
linux·运维·服务器
REDcker5 小时前
Linux信号机制详解 POSIX语义与内核要点 sigaction与备用栈实践
linux·运维·php
虹科网络安全5 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje6 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv76 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫6 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287926 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本6 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
cui_ruicheng6 小时前
Linux进程间通信(三):System V IPC与共享内存
linux·运维·服务器