服务器端知识库nginx搭建文件服务器

简介: 作为一名前端开发者,使用nginx配置静态web服务器是我们经常使用的功能之一。此外对于nginx的其他功能,比如说负载均衡,反向代理之类的我们接触的比较少。但是我认为要想掌握nginx这一大利器,我们就需要去多多了解他所具备的功能,以及nginx的设计架构和原理,而如果想要快速的掌握这块,我觉得动手去使用nginx是最快的途径之一。本章记录下搭建nginx的过程。

前言


作为一名前端开发者,使用nginx配置静态web服务器是我们经常使用的功能之一。此外对于nginx的其他功能,比如说负载均衡,反向代理之类的我们接触的比较少。但是我认为要想掌握nginx这一大利器,我们就需要去多多了解他所具备的功能,以及nginx的设计架构和原理,而如果想要快速的掌握这块,我觉得动手去使用nginx是最快的途径之一。本章记录下搭建nginx的过程。

基本实现


基本功能

  • 文件目录查看
  • 点击文件目录展示下一级
  • 文件目录下文件数量显示(待定)
  • 点击文件下载功能
  • 文件信息展示(更新时间 文件类型 文件大小)
  • 文件上传功能(待定)
  • 文件目录搜索功能(待定)
  • 文件目录自定义样式(待定 fancyindex)

相关api

在开始搭建文件服务器之前我们先要了解下实现这块的相关api,在nginx模块中有如下 ngx_http_autoindex_module,模块处理以斜杠('/')结尾的请求,并生成目录列表。

  • autoindex :启用或禁用目录列表输出。
  • autoindex_exact_size:默认为on,显示出文件的确切大小,单位是bytes。改为off后,显示出文件的大概大小,单位是kB或者MB或者GB
  • autoindex_format:html | xml | json | jsonp;
  • autoindex_localtime:默认为off,显示的文件时间为GMT时间。 改为on后,显示的文件时间为文件的服务器时间

实现步骤

  • 服务器(百度云ubuntu)
  • 安装nginx
apt install nginx
  • 配置nginx
http{
    server{
        location /test{
            alias /var/www; //目录路径
            autoindex on;
        }
    }
}
  • 测试/启用nginx
nginx -t //返回ok则说名语法没问题
nginx -s start
  • 打开浏览器页面

网络异常,图片无法展示
|
这个是nginx自带的文件处理,样式不够美观,在真实项目中我们常常使用Nginx-Fancyindex-Theme来美化目录样式。

facyindex的配置使用

当我们不满足于nginx自带的文件服务器样式时候,我们可以使用facyindex来重新格式化其目录样式,具体操作如下

环境安装(必须在linux机器上,window没试过)

  • 下载nginx和fancyindex源代码(centos)
yum install https://extras.getpagespeed.com/redhat/7/x86_64/RPMS/nginx-module-fancyindex-1.12.0.0.4.1-1.el7.gps.x86_64.rpm
  • 安装fancyindex
yum install nginx-module-fancyindex
  • 加载fancyindex
load_module "modules/ngx_http_fancyindex_module.so";

//如果系统是ubuntu那比较简单

  • 安装fancyindex
sudo apt-get install nginx-extras

配置fancyindex

  • 基础配置
location /teset {
  alias /var/www; //目录路径
  fancyindex on;              # Enable fancy indexes.
  fancyindex_exact_size off;  # Output human-readable file sizes.
}
  • 其他fancyindex配置
//允许在生成的清单中插入指向CSS样式表的链接。该链接将插入到内置CSS规则之后,因此您可以覆盖默认样式。
fancyindex_css_href
//指定应该将哪个文件插入到目录清单的底部。如果设置为空字符串,则发送模块提供的默认页脚。
fancyindex_footer
//指定应该将哪个文件插入到目录清单头部。如果设置为空字符串,则发送模块提供的默认页眉。
fancyindex_header
//指定将不会在生成的清单中显示的文件名列表
fancyindex_ignore
//Enables showing file times as local time. Default is “off” (GMT time).
fancyindex_localtime

启动nginx

nginx -t
nginx -s reload

至此我们可以实现一个比默认格式更美观的文件服务器,如下图:

网络异常,图片无法展示
|
这样肯定还不够的,为此我们可以引入个开源插件fancyindex-theme,这个提供了两种主题light和dark我选择了light主题进行搭建

引入fancyindex-theme

注:fancyindex-theme是基于fancyindex的插件,提供了更加优美的文件展示页面。以及一些检索操作。

  • 准备好前两步的环境
  • clone fancyindex-theme仓库
git clone https://github.com/Naereen/Nginx-Fancyindex-Theme
  • 将light主题文件放到对应的文件夹下(及在配置文件中alias定义的路径)
cp Nginx-Fancyindex-Theme-light /var/www/Nginx-Fancyindex-Theme-light
  • 修改nginx配置文件
{
       fancyindex_localtime on;
        fancyindex_header "/Nginx-Fancyindex-Theme-light/header.html";
        fancyindex_footer "/Nginx-Fancyindex-Theme-light/footer.html";
}

注:如果我们在nginx中的配置location 为/test,那我们在引入fancyindex_header和fancyindex_footer是就要如下写

{
     fancyindex_header "/test/Nginx-Fancyindex-Theme-light/header.html";
        fancyindex_footer "/test/Nginx-Fancyindex-Theme-light/footer.html";
}

另外在/Nginx-Fancyindex-Theme-light/footer.html和fancyindex_header "/Nginx-Fancyindex-Theme-light/header.html"文件中需要在引入外部文件的地方都加上前缀test

<link rel="stylesheet" href="/test/Nginx-Fancyindex-Theme/styles.css">
<script type="text/javascript" src="/test/Nginx-Fancyindex-Theme/jquery.min.js"></script>

这个是因为nginx路由匹配规则导致。

  • 重新启动后刷新页面如下图:
    网络异常,图片无法展示
    |

总结


本节主要是了解下nginx在搭建静态文件服务器中的使用,虽然默认的nginx文件模块已经能满足我们功能需求,但作为一名前端工程是追求友好交互是必不可少的品质之一。另外,在这个大前端时代,对于前端开发来说掌握nginx那我们就相当于在前端领域多了另一种可能。

命令总结:

  • 1.autoindex打开文件服务器功能
  • 2.alias设置文件服务器的路径
  • 3.fancyindex文件展示样式优化


相关文章
|
2月前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
178 61
|
1月前
|
弹性计算 负载均衡 网络协议
ECS中实现nginx4层7层负载均衡和ALB/NLB原SLB负载均衡
通过本文的介绍,希望您能深入理解并掌握如何在ECS中实现Nginx四层和七层负载均衡,以及如何使用ALB和NLB进行高效的负载均衡配置,以提高系统的性能和可靠性。
141 9
|
1月前
|
存储 编解码 应用服务中间件
使用Nginx搭建流媒体服务器
本文介绍了流媒体服务器的特性及各种流媒体传输协议的适用场景,并详细阐述了使用 nginx-http-flv-module 扩展Nginx作为流媒体服务器的详细步骤,并提供了在VLC,flv.js,hls.js下的流媒体拉流播放示例。
191 1
|
5月前
|
Ubuntu 应用服务中间件 Linux
在Linux中,如何配置Web服务器(如Apache或Nginx)?
在Linux中,如何配置Web服务器(如Apache或Nginx)?
|
5月前
|
应用服务中间件 Linux 网络安全
在Linux中,如何配置Apache或Nginx Web服务器?
在Linux中,如何配置Apache或Nginx Web服务器?
|
11天前
|
弹性计算 数据挖掘 应用服务中间件
阿里云轻量应用服务器68元与云服务器99元和199元区别及选择参考
目前阿里云有三款特惠云服务器,第一款轻量云服务器2核2G68元一年,第二款经济型云服务器2核2G3M带宽99元1年,第三款通用算力型2核4G5M带宽199元一年。有的新手用户并不是很清楚他们之间的区别,因此不知道如何选择。本文来介绍一下它们之间的区别以及选择参考。
241 87
|
4天前
|
存储 弹性计算 应用服务中间件
阿里云轻量应用服务器出新品通用型实例了,全球26个地域可选
近日,阿里云再度发力,推出了首款全新升级的轻量应用服务器——通用型实例。这款服务器实例不仅标配了200Mbps峰值公网带宽,更在计算、存储、网络等基础资源上进行了全面优化,旨在为中小企业和开发者提供更加轻量、易用、普惠的云计算服务,满足其对于通用计算小算力的迫切需求。目前,这款新品已在全球26个地域正式上线,为全球用户提供了更加便捷、高效的上云选择。
|
21天前
|
机器学习/深度学习 人工智能 PyTorch
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
阿里云GPU云服务器怎么样?阿里云GPU结合了GPU计算力与CPU计算力,主要应用于于深度学习、科学计算、图形可视化、视频处理多种应用场景,本文为您详细介绍阿里云GPU云服务器产品优势、应用场景以及最新活动价格。
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
|
20天前
|
存储 运维 安全
阿里云弹性裸金属服务器是什么?产品规格及适用场景介绍
阿里云服务器ECS包括众多产品,其中弹性裸金属服务器(ECS Bare Metal Server)是一种可弹性伸缩的高性能计算服务,计算性能与传统物理机无差别,具有安全物理隔离的特点。分钟级的交付周期将提供给您实时的业务响应能力,助力您的核心业务飞速成长。本文为大家详细介绍弹性裸金属服务器的特点、优势以及与云服务器的对比等内容。
|
12天前
|
存储 人工智能 网络协议
浅聊阿里云倚天云服务器:c8y、g8y、r8y实例性能详解与活动价格参考
选择一款高性能、高性价比的云服务器对于企业而言至关重要,阿里云推出的倚天云服务器——c8y、g8y、r8y三款实例,它们基于ARM架构,采用阿里自研的倚天710处理器,并基于新一代CIPU架构,通过芯片快速路径加速手段,实现了计算、存储、网络性能的大幅提升。2025年,计算型c8y云服务器活动价格860.65元一年起,通用型g8y云服务器活动价格1187.40元一年起,内存型r8y云服务器活动价格1454.32元一年起。本文将为大家详细解析这三款实例的性能特点、应用场景以及最新的活动价格情况,帮助大家更好地了解阿里云倚天云服务器。