nginxinc/ingress-demo该镜像是 nginxdemos/hello 的改进版本,专为 Kubernetes Ingress Controller 演示设计的 Web 服务器。主要用于展示和测试 Kubernetes 环境中的 Ingress 规则配置、流量路由及相关功能验证。
提供两个版本以适配不同安全环境:
| 标签 | UID | GID | 暴露端口 |
|---|---|---|---|
| latest | root | root | 80(HTTP)、443(HTTPS) |
| latest-unprivileged | nginx | nginx | 8080(HTTP)、8443(HTTPS) |
服务器通过 /health URI 端点响应健康检查请求,便于监控和自动恢复机制集成。
访问日志仅记录 4xx(客户端错误)和 5xx(服务器错误)响应,减少冗余日志输出。
内置自签名 SAN 证书(适用于 *.nginx.net 域名),默认启用 TLSv1.2 及以上版本加密。支持自定义证书替换,满足生产环境安全需求。
根据目标环境选择对应标签,通过 docker run 命令启动容器:
bashdocker run -d -p 80:80 -p 443:443 --name ingress-demo nginxdemos/ingress-demo:latest
bashdocker run -d -p 8080:8080 -p 8443:8443 --name ingress-demo-unprivileged nginxdemos/ingress-demo:latest-unprivileged
默认使用自签名证书,如需替换为自定义证书,通过挂载卷方式指定证书路径:
证书路径:
/etc/nginx/certs/nginx.pem/etc/nginx/certs/nginx-key.pem部署示例(以 latest 标签为例):
bashdocker run -d \ -p 80:80 -p 443:443 \ -v /path/to/custom-cert.pem:/etc/nginx/certs/nginx.pem \ -v /path/to/custom-key.pem:/etc/nginx/certs/nginx-key.pem \ --name ingress-demo-custom-tls nginxdemos/ingress-demo:latest
以下为多环境部署示例,包含特权和非特权版本:
yamlversion: '3' services: ingress-demo-privileged: image: nginxdemos/ingress-demo:latest ports: - "80:80" - "443:443" restart: always ingress-demo-unprivileged: image: nginxdemos/ingress-demo:latest-unprivileged ports: - "8080:8080" - "8443:8443" restart: always user: nginx # 非特权用户运行(可选,镜像默认已配置)
容器启动后,可通过以下命令验证健康检查端点:
bashcurl http://<容器IP>:<HTTP端口>/health
成功响应表示服务正常运行。
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务