Nginx快速搭建通用图片服务

Nginx快速搭建图片服务

一、Nginx系列之配置root目录、虚拟目录alias

Nginx是通过 alias 设置虚拟目录,在Nginx的配置中,alias目录和root目录是有区别的。

  1. alias指定的目录是准确的,即location匹配访问的path目录下的文件直接是在alias目录下查找的;
  2. root指定的目录是location匹配访问的path目录的上一级目录,这个path目录一定要是真实存在root指定目录下的;
  3. 使用alias标签的目录块中不能使用rewrite的break;另外,alias指定的目录后面必须要加上/符号;
  4. alias虚拟目录配置中,location匹配的path目录如果后面不带/,那么访问的url地址中这个path目录后面加不加/不影响访问,访问时它会自动加上/;但是如果location匹配的path目录后面加上/,那么访问的url地址中这个path目录必须要加上/,访问时它不会自动加上/。如果不加上/,访问就会失败!
  5. root目录配置中,location匹配的path目录后面带不带/,都不会影响访问。

实例

比如Nginx配置的域名是www.kinloly.top

示例一
  1. alias 虚拟目录配置,alias虚拟目录配置下,访问http://www.kinloly.top/storage/a.html实际指定的是/home/www/storage/a.html;
    location /storage/ {
    alias /home/www/storage/;
    }
    注意:alias指定的目录后面必须要加上"/",即/home/www/storage/不能改成/home/www/storage;
  2. root目录配置,如下:这样nginx就会去/home/www/storage下寻找http://www.kinloly.top/storage的访问资源,两者配置后的访问效果是一样的;
    location /storage/ {
    root /home/www/;
    }
示例二

上面的例子中alias设置的目录名和location匹配访问的path目录名一致,这样可以直接改成root目录配置;那要是不一致呢?
alias 虚拟目录配置:
location /web/ {
alias /home/www/html/;
}
访问http://www.kinloly.top/web的时候就会去/home/www/html/下寻找访问资源;这样的话,还不能直接改成root目录配置。
root目录配置
如果非要改成root目录配置,就只能在/home/www下将html->web(做软连接,即快捷方式),如下:
location /web/ {
root /home/www/;
}
ln -s /home/www/web /home/www/html //即保持/home/www/web和/home/www/html内容一直

  • 所以,一般情况下,在nginx配置中的良好习惯是:
    • 在location /中配置root目录;
    • 在location /path中配置alias虚拟目录。
例 1:

server {
listen 80;
server_name www.kinloly.top;
index index.html index.php index.htm;
access_log /usr/local/nginx/logs/image.log;
location / {
root /var/www/html;
}
location /haha {
// 匹配的path目录haha不需要真实存在alias指定的目录中
alias /var/www/html/ops/;
// 后面的"/"符号一定要带上
}
location /wang {
// 匹配的path目录wang一定要真实存在root指定的目录中(即/var/www/html下一定要有wang目录存在)
root /var/www/html;
}
}

例 2:

[root@web01 vhosts]# cat nginx.conf
server {
listen 80;
server_name www.kinloly.top;
location / {
root /data/web/kinloly;
index index.php index.html index.htm;
}
location /image/ {
alias /data/web/image/;
}
}
如上配置后,则:
访问http://www.kinloly.top/admin 就会找到/data/web/kinloly/admin目录;
访问http://www.kinloly.top/image就会找到/data/web/image目录 (里面是一些静态资源)

二、欢迎关注公众号及小程序

欢迎关注微信公众号【笑傲江湖工作室】

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值