【承受Ubuntu22】Ambari3.0.0+Bigtop3.2.0——Step5—Nginx安装

注意事项
本文基于 Ubuntu 22.04 LTS 适配,部分包名和配置与 RedHat/Rocky/CentOS 有差异,请勿直接复用其它系统命令。如遇疑难欢迎在
VX 或 QQ 群与作者交流。

附录:完整内容和源代码下载请参照

https://doc.janettr.com/

在这里插入图片描述

在大数据或私有云环境下,经常需要自建本地仓库,用于托管 DEB 包、离线二进制、补丁文件、容器镜像等。
Nginx 以高性能、低资源占用和目录索引能力,成为 Ubuntu 下构建本地仓库的首选。

1. 为什么选 Nginx 做静态仓库?

  • 更轻量,性能高:优于 Apache httpd,系统资源占用小
  • 默认支持目录索引:无需额外插件,直接浏览/下载所有静态文件
  • 部署简单,易于维护:一条命令即可安装,配置简洁明了
  • 灵活适配:可支持 DEB、RPM、二进制、容器镜像、ISO、Python 包等多种仓库场景

2. Nginx 安装(Ubuntu 22.04 专用)

2.1 安装命令

sudo apt update
sudo apt install -y nginx

与 RedHat/CentOS 完全不同!Ubuntu 下必须用 apt 安装 Nginx,不要用 yumdnfepel-release

2.2 检查版本

nginx -v

看到 nginx version: nginx/1.x.x 即为成功。

3. 仓库目录与权限配置

3.1 创建静态仓库根目录

sudo mkdir -p /data/modules

3.2 授权目录访问

sudo chmod -R 755 /data/modules
sudo chown -R www-data:www-data /data/modules

Ubuntu 默认 Nginx 运行用户为 www-data,不是 nginx!目录属主必须为 www-data,或至少有全员读/执行权限,否则 Nginx 会报
403 Forbidden。

4. Nginx 静态仓库配置

4.1 新建仓库专用配置文件

sudo vim /etc/nginx/conf.d/local_repo.conf

内容示例:

image-20250718165132972

server {
listen 80 default_server;
server_name _;
location / {
root /data/modules;
autoindex on;
autoindex_exact_size off;
autoindex_localtime on;
}
error_page 404 /404.html;
}

  • 可根据需求添加 HTTPS、账号认证等安全措施。

4.2 移除默认站点配置

sudo mv /etc/nginx/sites-enabled/default /etc/nginx/sites-enabled/default.bak

Ubuntu Nginx 默认站点配置在 /etc/nginx/sites-enabled/default,不是 /etc/nginx/conf.d/default.conf(RedHat/CentOS
路径),如不禁用会显示欢迎页或冲突!

5. 启动并验证 Nginx 服务

5.1 启动和自启动设置

sudo nginx -t
sudo systemctl restart nginx
sudo systemctl enable nginx

nginx -t 检查配置语法是否正确,务必执行,避免配置出错导致服务无法重启。

5.2 检查运行状态

sudo systemctl status nginx

状态为 active (running) 即正常。

5.3 访问测试

  • 浏览器访问 http://your-server-ip/,可看到 /data/modules 下的全部内容和包文件。

  • 或命令行验证:

    curl -I http://localhost/

    返回 HTTP/1.1 200 OK 表示服务正常。

image-20250718165520616

6. 运维与常见问题

6.1 403 Forbidden/无法访问目录

最常见原因为目录权限或属主不对,务必确保 /data/moduleswww-data 或其它有读权限,检查命令:

ls -ld /data/modules

6.2 文件或目录不可见

  • 检查 Nginx 是否有权限递归访问所有父级目录
  • 确保 autoindex on; 配置无误
  • 没有 SELinux,无需 chconrestorecon 操作

Ubuntu 22.04 默认没有 SELinux,无需做任何 SELinux 权限设置(不要用 chconrestorecon),这与 RedHat/CentOS 完全不同。

6.3 端口防火墙设置

  • 如启用 UFW:

    sudo ufw allow 80/tcp
  • 公网环境请按实际安全策略放行端口

posted @ 2025-08-02 14:02  yjbjingcha  阅读(17)  评论(0)    收藏  举报