manureyesi/batch-opos-galicia-nginxNginx(发音为"engine-x")是一款由Igor Sysoev开发的开源HTTP和反向代理服务器,同时支持IMAP/POP3/SMTP代理功能。作为Docker镜像,Nginx提供了便捷的部署方式,无需复杂环境配置即可快速启动高性能服务器实例。其主要用途包括:
通过以下命令快速启动Nginx容器:
bashdocker run --name my-nginx -p 80:80 -d nginx
--name my-nginx:指定容器名称为my-nginx-p 80:80:将容器的80端口映射到主机的80端口-d:后台运行容器nginx:使用最新版Nginx镜像(默认标签为latest)启动后,访问http://localhost即可看到Nginx默认欢迎页面。
4.2.1 挂载自定义配置文件
将本地配置文件挂载到容器中替换默认配置:
bashdocker run --name my-nginx -p 80:80 -v /path/to/nginx.conf:/etc/nginx/nginx.conf:ro -d nginx
/path/to/nginx.conf:本地Nginx配置文件路径/etc/nginx/nginx.conf:容器内Nginx主配置文件路径:ro:以只读模式挂载,防止容器内修改配置文件4.2.2 挂载网站根目录
将本地静态文件目录挂载到容器的默认网站根目录:
bashdocker run --name my-nginx -p 80:80 -v /path/to/website:/usr/share/nginx/html:ro -d nginx
/path/to/website:本地静态文件目录(包含index.html等)/usr/share/nginx/html:容器内Nginx默认网站根目录创建docker-compose.yml文件实现更复杂部署:
yamlversion: '3' services: nginx: image: nginx:alpine # 使用轻量级Alpine版本 container_name: my-nginx ports: - "80:80" - "443:443" # 映射HTTPS端口 volumes: - ./nginx.conf:/etc/nginx/nginx.conf:ro - ./conf.d:/etc/nginx/conf.d:ro # 挂载虚拟主机配置 - ./html:/usr/share/nginx/html:ro # 静态文件目录 - ./ssl:/etc/nginx/ssl:ro # SSL证书目录 restart: unless-stopped # 容器退出时自动重启(除非手动停止) networks: - nginx-network networks: nginx-network: driver: bridge
启动服务:
bashdocker-compose up -d
Nginx官方镜像本身不提供环境变量注入配置的功能,所有配置需通过挂载配置文件实现。常用配置路径:
/etc/nginx/nginx.conf/etc/nginx/conf.d/(默认包含default.conf)/usr/share/nginx/html/var/log/nginx(包含access.log和error.log)典型虚拟主机配置示例(conf.d/my-site.conf):
nginxserver { listen 80; server_name example.com [***] root /usr/share/nginx/html; index index.html index.htm; location / { try_files $uri $uri/ =404; } # 启用gzip压缩 gzip on; gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; }
创建负载均衡配置(conf.d/load-***.conf):
nginx# 定义后端服务器组 upstream backend_servers { server backend1:8080 weight=5; # 权重5 server backend2:8080; # 默认权重1 server backend3:8080 backup; # 备份服务器 } server { listen 80; server_name api.example.com; location / { proxy_pass [***] proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } }
配合docker-compose使用时,需确保Nginx容器与后端服务在同一网络中。
-v)挂载,避免容器删除导致数据丢失docker exec -it my-nginx nginx -t验证配置语法正确性nginx:1.25-alpine)而非latest,确保环境一致性--memory和--cpus参数限制容器资源使用,避免影响主机系统探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像服务
在 Docker Desktop 配置镜像
Docker Compose 项目配置
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
MacOS OrbStack 容器配置
在宝塔面板一键配置镜像
Synology 群晖 NAS 配置
飞牛 fnOS 系统配置镜像
极空间 NAS 系统配置服务
爱快 iKuai 路由系统配置
绿联 NAS 系统配置镜像
QNAP 威联通 NAS 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
来自真实用户的反馈,见证轩辕镜像的优质服务