资讯专栏INFORMATION COLUMN

关于 nginx 前端知道这些就够了

xiao7cn / 1459人阅读

摘要:我备案了个域名,买了一个阿里云服务器,想要搭建几个自己的网站,难免要接触。创建软链接假如我们每个网站程序放在一个文件夹里,该程序的配置文件也应该放在这个文件夹里才方便管理。

我备案了个域名,买了一个阿里云服务器,想要搭建几个自己的网站,难免要接触 nginx。

那么我用 nginx 来干嘛呢:

静态资源反向代理

将域名泛解析到服务器之后,通过 nginx 来给不同的二级域名分配服务器上的程序。

1、安装 nginx 1.1、centos7
yum install -y nginx
1.2、windows

到官网下载,安装包,解压即可使用:官网

1.3、centos7 中 nginx 常用命令
# 开机启动
systemctl enable nginx.service

# 启动
systemctl start nginx.service

# 使用某个配置文件启动(要先关闭 ngxin,不然会报错的)
nginx -c /etc/nginx/nginx.conf

# 关闭(如果这样关闭不了的话,就把 nginx 进程给杀掉)
nginx -s stop

# 查看 nginx 的进程 id
ps -ef | grep nginx

# 杀死进程(比如杀死进程1234)
kill -9 1234

nginx 的默认配置文件是:/etc/nginx/nginx.conf

这个配置文件会自动读取:/etc/nginx/conf.d/ 文件夹下的所有 .conf 文件。

假如你写了个网站,需要用到 nginx ,那么你就把配置文件丢到 /etc/nginx/conf.d/ 文件夹下,然后重启 nginx 就行了:

nginx -s stop
nginx -c /etc/nginx/nginx.conf
2、nginx 配置(反向代理设置 & 二级域名) 2.1 配置文件

假设我们有两个网站:
www.example.com
blog.example.com

它们分别有两个 ngxin 配置文件放在:
/home/www.example.com/www.example.com.nginx.conf
/home/blog.example.com/blog.example.com.nginx.conf

服务器对外开放 80 端口,两个网站对应的程序端口分别为:

www.example.com 程序 8000
www.example.com 静态资源 8080

blog.example.com 程序 8001
blog.example.com 静态资源 8081

那么他们的配置内容分别为:

# /home/www.example.com/www.example.com.nginx.conf
server {
    # 服务器对外只监听 80 端口
    listen 80;
    # 当 80 端口监听到了来自 www.example.com 的请求
    server_name www.example.com;
    # 那么把这个请求转到 http://localhost:8080
    location / {
        proxy_pass http://localhost:8080;
    }
}
server {
    # 监听到 8080 端口有人发起请求(其实就是上面转过来的↑,用户不能直接访问 8080 端口的)
    listen 8080;
    # 只允许本机访问
    server_name localhost;
    # 程序根目录
    root /home/www.example.com;
    # 默认的网页文件
    index index.html index.htm;
    # 匹配所有 uri (如果 url 为:http://www.example.com/hehe,那么 uri 为:/hehe)
    location / {
        # 我们的程序实际上是在 8000 端口上
        proxy_pass http://localhost:8000$request_uri;

        # 下面这一大堆,欲知详情自己查
        proxy_redirect     off;
        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_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
        proxy_max_temp_file_size 0;
        proxy_connect_timeout      90;
        proxy_send_timeout         90;
        proxy_read_timeout         90;
        proxy_buffer_size          4k;
        proxy_buffers              4 32k;
        proxy_busy_buffers_size    64k;
        proxy_temp_file_write_size 64k;
    }
    # 匹配首页
    location = / {
        proxy_pass http://localhost:8000;
    }
    # 匹配 /**.** 结尾的 uri,并且不是 /**.html、/**.htm
    location ~* ^.+/[^/]+(?=.)([^/](?!(html|htm)))+$ {
      # 匹配到的都定位到静态资源目录里
      root /home/www.example.com/static;
      etag         on;
      expires      max;
    }
}
# /home/blog.example.com/blog.example.com.nginx.conf
server {
    # 服务器对外只监听 80 端口
    listen 80;
    # 当 80 端口监听到了来自 blog.example.com 的请求
    server_name blog.example.com;
    # 那么把这个请求转到 http://localhost:8081
    location / {
        proxy_pass http://localhost:8081;
    }
}
server {
    # 监听到 8081 端口有人发起请求(其实就是上面转过来的↑,用户不能直接访问 8081 端口的)
    listen 8081;
    # 只允许本机访问
    server_name localhost;
    # 程序根目录
    root /home/blog.example.com;
    # 默认的网页文件
    index index.html index.htm;
    # 匹配所有 uri (如果 url 为:http://blog.example.com/hehe,那么 uri 为:/hehe)
    location / {
        # 我们的程序实际上是在 8001 端口上
        proxy_pass http://localhost:8001$request_uri;

        # 下面这一大堆,欲知详情自己查
        proxy_redirect     off;
        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_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
        proxy_max_temp_file_size 0;
        proxy_connect_timeout      90;
        proxy_send_timeout         90;
        proxy_read_timeout         90;
        proxy_buffer_size          4k;
        proxy_buffers              4 32k;
        proxy_busy_buffers_size    64k;
        proxy_temp_file_write_size 64k;
    }
    # 匹配首页
    location = / {
        proxy_pass http://localhost:8001;
    }
    # 匹配 /**.** 结尾的 uri,并且不是 /**.html、/**.htm
    location ~* ^.+/[^/]+(?=.)([^/](?!(html|htm)))+$ {
      # 匹配到的都定位到静态资源目录里
      root /home/blog.example.com/static;
      etag         on;
      expires      max;
    }
}

注意看两个配置的区别。

2.2 创建软链接

假如我们每个网站程序放在一个文件夹里,该程序的 nginx 配置文件也应该放在这个文件夹里才方便管理。但前面提到,我们需要把配置文件丢到 /etc/nginx/conf.d/ 文件夹下,怎样才能使这个配置文件既在程序文件夹下,又在 /etc/nginx/conf.d/文件夹下呢?

假如我们在程序文件夹下有一个 ngxin 配置文件:/home/www.example.com/www.example.com.nginx.conf

我们需要给这个文件创建一个软链接到 /etc/nginx/conf.d/ 下:

ln -s /home/example/example.nginx.conf /etc/nginx/conf.d/www.example.com.nginx.conf

这样操作之后,当我们改程序文件夹下的配置文件,/etc/nginx/conf.d/ 下与之对应的配置文件也会被修改,修改后重启 nginx 就能够使新的 ngxin 配置生效了。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/39928.html

相关文章

  • 关于 nginx 前端知道这些够了

    摘要:我备案了个域名,买了一个阿里云服务器,想要搭建几个自己的网站,难免要接触。创建软链接假如我们每个网站程序放在一个文件夹里,该程序的配置文件也应该放在这个文件夹里才方便管理。 我备案了个域名,买了一个阿里云服务器,想要搭建几个自己的网站,难免要接触 nginx。 那么我用 nginx 来干嘛呢: 静态资源反向代理 将域名泛解析到服务器之后,通过 nginx 来给不同的二级域名分配服务器...

    Alfred 评论0 收藏0
  • 前端基础汇总

    摘要:及相关问题数据类型函数中指向原型作用域闭包面向对象对象创建模式继承严格模式与对象转换的方法添加属性,根据原型创建区别新特性解构赋值简化对象写法剪头函数三点运算符模板字符串形参默认值异步过程深拷贝与浅拷贝赋值与浅拷贝的区别浅拷贝的几种方法实现 js及es相关问题 数据类型函数中this指向——————原型作用域闭包——————面向对象对象创建模式继承——————Es5严格模式Json与j...

    2json 评论0 收藏0
  • 前端基础汇总

    摘要:及相关问题数据类型函数中指向原型作用域闭包面向对象对象创建模式继承严格模式与对象转换的方法添加属性,根据原型创建区别新特性解构赋值简化对象写法剪头函数三点运算符模板字符串形参默认值异步过程深拷贝与浅拷贝赋值与浅拷贝的区别浅拷贝的几种方法实现 js及es相关问题 数据类型函数中this指向——————原型作用域闭包——————面向对象对象创建模式继承——————Es5严格模式Json与j...

    laznrbfe 评论0 收藏0
  • 企业只能申请两个微信公众号,微信开发不够用?不,一个公众号够了

    摘要:微信年月日发公告称,个人主体注册公众号数量上限由个调整为个。大家都知道每个微信公众号在进行开发时,授权回调的域名只能设置一个,正常的开发一般一套环境就对应一个域名。 微信2018年11月16日发公告称,个人主体注册公众号数量上限由2个调整为1个。企业类主体注册公众号数量上限由5个调整为2个。这个对马上要注册公众号的企业来说顿时心情不好了。 大家都知道每个微信公众号在进行开发时,授权回调...

    wthee 评论0 收藏0
  • 提高代码可读性,掌握这些够了

    摘要:提高代码可读性掌握这些就够了今天看到一篇关于代码优化的文章写得十分实用在学习总结后梳理出思维结构图将收货的分享一下原作者方应杭原文地址注意这篇文章所指的代码优化特指的是代码可读性方面的一些写法优化而不是指的性能优化。 提高代码可读性,掌握这些就够了 今天看到一篇关于代码优化的文章,写得十分实用,在学习总结后,梳理出思维结构图,将收货的分享一下 原作者:方应杭 原文地址:https://...

    khs1994 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<