专属
文档
插件
助手
邀请
顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像
专业版
轩辕镜像 官方专业版
轩辕镜像
专业版
首页个人中心搜索镜像

交易
充值流量我的订单

文档

工具

功能
提交工单页面收录

帮助
轩辕镜像免费版

其他
关于我们网站地图
热门搜索:
single-page-application-server

codecentric/single-page-application-server

codecentric

单页应用(SPA)基础镜像,使用Nginx作为Web服务器,支持SPA路由处理、动态配置、环境特定设置、资源缓存及安全强化,适用于Angular、React等SPA部署。

3 次收藏下载次数: 0状态:社区镜像维护者:codecentric仓库类型:镜像最近更新:29 天前
让 AI 帮你使用轩辕镜像? · 展开查看说明

如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。

只需在 AI 对话中先发送下面这句话即可:

请先完整阅读并严格遵守以下文档中的全部规则与要求:

https://xuanyuan.cloud/agents.md

在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。

查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。

轩辕镜像,让镜像更快,让人生更轻。点击查看
中文简介
标签列表
镜像标签列表与下载命令
轩辕镜像,让镜像更快,让人生更轻。点击查看

单页应用服务器

!https://github.com/codecentric/single-page-application-server/workflows/Update%20Docker%20Images/badge.svg

该容器镜像提供了使用Nginx作为Web服务器来部署单页应用(SPA)的基础。

使用此镜像部署应用时,对应的Helm chart也可在https://hub.docker.com/r/codecentric/single-page-application-server-chart%E8%8E%B7%E5%8F%96%E3%80%82

标签

以下标签每周自动更新,包含最新的Nginx基础镜像:

  • latest(别名:1-nginx-stable-alpine)
  • 1(别名:1-nginx-stable-alpine)
  • latest-nginx-stable-alpine(别名:1-nginx-stable-alpine)
  • 1-nginx-stable-alpine
  • latest-nginx-mainline-alpine(别名:1-nginx-mainline-alpine)
  • 1-nginx-mainline-alpine

同时提供特定Nginx版本的额外标签。

示例

Angular和React的使用示例位于examples目录中。

通用特性

  • SPA路由处理:不匹配静态文件的路由将返回index.html,但.js、.css等资源除外。
  • 动态配置:容器启动时配置SPA,配置可通过window.spaConfig访问。
  • 环境特定配置:基于端口和域名自定义设置。
  • 资源缓存:带哈希的资源(哈希至少8个字符)将被永久缓存。
  • HTTP/2:默认对HTTPS连接启用。
  • Helm Chart:提供通用https://github.com/codecentric/single-page-application-server/blob/master/chart/README.md%E7%94%A8%E4%BA%8E%E4%BD%BF%E7%94%A8%E6%AD%A4%E9%95%9C%E5%83%8F%E7%9A%84%E5%BA%94%E7%94%A8%E3%80%82

安全特性

  • 内容安全策略(CSP):默认严格,自动白名单服务器API端点。
  • 引用策略:默认禁用以防止信息泄露。
  • 内容类型嗅探:默认禁用。
  • HTTPS:启用HSTS时强制使用;采用https://github.com/OWASP/CheatSheetSeries/blob/1e07c6c894f98af58d8a417eb8df1b20e1b3337e/cheatsheets/TLS_Cipher_String_Cheat_Sheet.md%E3%80%82
  • 非root用户:容器以非root用户运行,但可绑定80和443端口。
  • 源代码映射:默认禁用。
  • 只读根文件系统:容器运行时支持
  • 供应链验证:所有镜像使用cosign签名,详见供应链验证。

配置

应用目录

将SPA资源放置在/app/目录下,该目录中的所有文件将由Nginx提供服务。

YAML配置

通过容器启动时的YAML文件配置应用:

  1. 默认配置:添加默认配置文件至/config/default.yaml,通常在docker build时添加。
  2. 运行时配置:将运行时配置文件挂载至/config/config.yaml,此文件将覆盖默认设置。

示例配置

yaml
default:
  spa_config:
    appTitle: "我的应用"
    endpoints:
      api: "https://api.example.com"

也可定义特定主机的配置:

yaml
default:
  spa_config:
    appTitle: "默认标题"
    endpoints:
      api: "https://api.example.com"
special_host:
  server_names:
    - "special.example.com"
  spa_config:
    appTitle: "特定域名标题"

配置参考

以下配置展示了基础镜像所有可用设置的默认值:

yaml
default:
  # 指定此配置适用的主机名
  server_names:
    # "_"匹配任何主机名
    - "_"
  # index.html中base元素的href属性
  base_href: "/"
  # 此映射中的所有选项将通过`window.spaConfig`在SPA中可用
  # 要启用此功能,还需在index.html中包含spa_config.js
  # 现有spa_config.js将在容器启动时被覆盖
  spa_config:
    # SPA通信的端点映射
    # 若启用.hardening.whitelist_connect_sources,这些端点将自动添加到CSP的connect-src白名单
    endpoints: {}
  access_log:
    # 启用访问日志
    enabled: false
  source_maps:
    # 启用源代码映射
    enabled: false
    # 用于识别源代码映射资源的正则表达式
    regex: "\\.(js|css)\\.map$"
  http:
    enabled: true
    port: 80
    # 若启用HTTPS,是否重定向至HTTPS
    https_redirect: true
    # 应用位于NAT后时,使用不同的HTTPS重定向端口
    # 0 = 使用https.port
    https_redirect_port: 0
    # 纯文本连接默认禁用HTTP/2,因为Nginx仅通过预先了解支持纯文本HTTP/2
    # https://trac.nginx.org/nginx/ticket/816
    http2_enabled: false
  https:
    enabled: false
    port: 443
    # 永久强制使用HTTPS
    hsts_enabled: true
    ssl_certificate: /etc/ssl/default.crt
    ssl_certificate_key: /etc/ssl/default.key
    # 使用推荐值配置支持的TLS协议和密码套件
    # https://github.com/OWASP/CheatSheetSeries/blob/1e07c6c894f98af58d8a417eb8df1b20e1b3337e/cheatsheets/TLS_Cipher_String_Cheat_Sheet.md
    owasp_cipher_string: A
    http2_enabled: true
  keepalive:
    server:
      # 服务器端保持活动客户端连接的超时时间(秒)
      timeout_seconds: 75
  hardening:
    # 禁用引用以防止信息泄露
    referrer_policy: "no-referrer"
    # 防止浏览器猜测内容类型
    x_content_type_options: "nosniff"
    # 启用时,自动将.spa_config.endpoints中的端点添加到CSP的connect-src白名单
    whitelist_spa_config_endpoints_as_connect_sources: true
    # CSP指令映射,将添加到所有HTML和JavaScript文档的HTTP响应中
    content_security_policy:
      base-uri: "'self'"
      block-all-mixed-content: true
      default-src: "'self'"
      form-action: "'self'"
      frame-ancestors: "'self'"
      frame-src: "'self'"
      object-src: "'none'"
      script-src: "'self'"
      style-src: "'self'"

只读根文件系统支持

为增强安全性,可使用只读根文件系统。确保以下目录可写:

  • /config/.out:用于文件生成。
  • /tmp:Nginx用于缓存文件和nginx.pid。

在Kubernetes中,建议将这些目录挂载为emptyDir类型的可写卷。

供应链验证

当Dockerfile使用codecentric/single-page-application-server作为基础镜像时,使用cosign验证基础镜像:

bash
cosign dockerfile verify Dockerfile \
  --certificate-oidc-issuer https://token.actions.githubusercontent.com \
  --certificate-identity-regexp '^https\:\/\/github\.com\/codecentric\/single\-page\-application\-server' \
  --base-image-only

可通过克隆此仓库并在examples/angular目录中执行该命令进行测试。

开发

  • 配置生成:使用gomplate模板。
  • 镜像测试:使用Java和Testcontainers编写。
  • Helm Chart测试:使用https://github.com/helm-unittest/helm-unittest Helm插件。

许可证

MIT

镜像拉取方式

您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

轩辕镜像加速拉取命令点我查看更多 single-page-application-server 镜像标签

docker pull docker.xuanyuan.run/codecentric/single-page-application-server:<标签>

使用方法:

  • 登录认证方式
  • 免认证方式

DockerHub 原生拉取命令

docker pull codecentric/single-page-application-server:<标签>

更多 single-page-application-server 镜像推荐

linuxserver/code-server logo

linuxserver/code-server

LinuxServer.io 社区镜像
linuxserver/code-server是VS Code服务器版Docker镜像,可在浏览器中运行完整VS Code开发环境,无需本地安装即可跨设备访问。支持全部VS Code扩展、代码同步与终端功能,适配远程开发、团队协作或低配置设备场景。镜像经linuxserver优化,兼容ARM/AMD架构,内置持久化存储与安全配置,开箱即用,轻松打造云端IDE,提升开发灵活性与效率。
736 次收藏5000万+ 次下载
27 天前更新
linuxserver/openssh-server logo

linuxserver/openssh-server

LinuxServer.io 社区镜像
提供OpenSSH服务器服务,支持远程登录与服务器管理,具备易于部署、配置灵活的特点,适用于各类需要安全远程访问的场景。
146 次收藏1000万+ 次下载
30 天前更新
mailserver/docker-mailserver logo

mailserver/docker-mailserver

mailserver
一个全栈且简单易用的邮件服务器,支持SMTP、IMAP协议,集成LDAP、反垃圾邮件及反病毒等功能。
262 次收藏1000万+ 次下载
26 天前更新
linuxserver/unifi-network-application logo

linuxserver/unifi-network-application

LinuxServer.io 社区镜像
LinuxServer.io 提供的 Unifi Network Application Docker 镜像,是一款功能强大的企业级无线软件引擎,适用于需要低延迟和高 uptime 性能的高密度客户端部署场景。
133 次收藏100万+ 次下载
28 天前更新
linuxserver/sonarr logo

linuxserver/sonarr

LinuxServer.io 社区镜像
由LinuxServer.io提供的Sonarr容器,是一款专为电视节目集管理设计的自动化工具,能够监控指定剧集的更新信息、自动从索引器获取下载链接并通过下载客户端(如Deluge、qBittorrent等)完成资源下载,同时支持按自定义规则整理文件结构、重命名剧集文件以保持媒体库整洁有序;LinuxServer.io作为专注于提供高质量容器化应用的团队,其构建的Sonarr容器基于轻量级Linux系统,优化了资源占用与运行稳定性,适合家庭媒体服务器或个人影视库的自动化管理场景使用。
2.1千 次收藏10亿+ 次下载
1 个月前更新
linuxserver/jackett logo

linuxserver/jackett

LinuxServer.io 社区镜像
这是由LinuxServer.io提供的Jackett容器,其中Jackett是一款实用的种子索引聚合工具,能够整合多个torrent追踪器的搜索结果,为qBittorrent、Deluge等各类P2P下载客户端提供统一的搜索接口,帮助用户更便捷地查找和获取所需资源;而LinuxServer.io团队凭借专业的容器化技术,确保该Jackett容器具备稳定的运行环境、简便的部署流程以及持续的更新支持,可满足用户在不同系统环境下高效使用Jackett的需求。
1.2千 次收藏10亿+ 次下载
26 天前更新

查看更多 single-page-application-server 相关镜像

轩辕镜像配置手册

按平台快速找到配置文档

Docker

登录仓库拉取

登录认证 · 私有仓库

专属域名拉取

免登录 · 高速拉取

Linux

Docker 镜像配置

Windows / Mac

Docker Desktop 配置

MacOS OrbStack

OrbStack 容器

Docker Compose

Compose 项目配置

NAS

群晖

Synology 配置

飞牛

fnOS 镜像配置

绿联

绿联 NAS

威联通

QNAP 配置

极空间

极空间 NAS

企业仓库

其他仓库

ghcr · Quay · nvcr

Harbor 镜像源

Proxy Repository 对接

Portainer 镜像源

Registries 配置

Nexus 镜像源

Docker Proxy 缓存

开发工具

Dev Containers

VS Code 开发容器

Podman

Podman 配置指南

Singularity / Apptainer

HPC 科学计算容器

Kubernetes

K8s Containerd

Kubernetes · Containerd

K3s

轻量级集群

面板 / 网络

爱快路由

iKuai 镜像加速

宝塔面板

一键配置镜像源

AI

用 AI 使用轩辕镜像

agents.md · AI 对话 · 提示词

一键安装

一键安装 Docker

Linux Docker 一键安装

需要其他帮助?请查看我们的 常见问题 Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

功能

免费版与专业版区别

功能对比 · 版本选择

支持的镜像仓库

Docker Hub · GCR · GHCR

新手拉取配置

登录 · 专属域名 · 配置

docker search 限制

专属域名 · Hub 搜索

不支持 push

仅支持 pull · 不支持

拉取速度原因

带宽 · 缓存 · 冷热镜像

错误码

402 与流量用尽

402 · 流量包 · 充值

401 认证失败

401 · docker login

manifest unknown

标签错误 · 镜像不存在

410 Gone 排查

410 · Docker 升级

429 限流

免费版 · 请求频率

其他报错

DNS 超时

DNS 解析 · 网络超时

TLS 证书失败

no matching manifest(架构)

账号

失败是否计费

manifest · blob · 计费

申请开发票(企业 / 个人)

企业 · 个人 · 工单

修改登录密码

网站 · 仓库 · 重置

注销账户

工单 · 数据 · 注销

原理

mirrors 不生效

daemon.json · 重启

去掉域名前缀

docker tag · 重命名

指定架构拉取

ARM64 · AMD64 · 多架构

latest 与「最新」

digest · 版本号 · 标签

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
codecentric/single-page-application-server
教程轩辕镜像功能与使用教程
价格查看流量套餐与价格
热门查看热门 Docker 镜像推荐
博客Docker 镜像公告与技术博客
官方公众号:源码跳动|官方技术交流群:831623681
官方公众号:源码跳动|官方技术交流群:|问题咨询请:提交工单
商务合作:点击复制邮箱
©2024-2026 源码跳动
商务合作:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.