5

最近捣鼓了不少时间,起初想到要弄这个就是因为 node 直接起 server 的方式有点暴力,因为占用了 80 端口就是真的占用了,很难在用一个 80 端口挂多个 WebServer。你只能挂载在多个端口上,访问起来后面还得加个端口,太丑了,所以摸索了一下,用 Nginx 配置了一个多服务结构。这样就能通过不同的子域名来访问不同的应用了!

大致的结构

本质上就是 nginx 负责转发进来的请求,那么转发的依据就是判断不同的子域名

STEP 1 Install Nginx

第一步当然是安装 nginx,各个平台不太一样,也没法分享了。我自己的 ubuntu 的环境

apt-get isntall nginx

STEP 2 Set DNS AND PORT

去你的域名管理商那里分配你想要的子域名,当然都是 A 记录并全部解析到你的 VPS 公网 IP 上.

另外一个准备就是修改你所有的 NodeWebServer 的端口,可以按你的爱好设置,但是不要占用 80 以及 443 端口

STEP 3 nginx config Node.js

切换到你的nginx 配置目录

我的目录位置

/etc/nginx/

这里要说明 nginx 是拥有 Include 机制的,他会自动加载 conf.d 目录下的所有 _.conf_(默认配置下) ,所以我们并不需要修改 nginx.conf 文件。我们接下来需要在 conf.d 目录下创建一系列的配置文件,文件名请使用你相应的工程名,比如 project1.conf

如果没有请手动加入

        include /etc/nginx/conf.d/*.conf;
        # include /etc/nginx/sites-enabled/*; // 最好给他注释了 默认页面没啥用

开始编写项目配置

cd conf.d

touch project1.conf

vim project1.conf

让我们编写详细的转发规则

// 这是一个NODE Web Server
// 我已经将这个服务的端口改成了8000端口
// 当nginx捕获到访问域名为api.yinode.tech的时候
// 就会转发到本地的8000端口
server{
    server_name api.yinode.tech;
    listen 80;
    location / {
        # proxy_http_version 1.1;
        proxy_set_header Connection "";
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header X-NginX-Proxy true;
        proxy_pass http://127.0.0.1:8000$request_uri;
        proxy_redirect off;
    }
}

如果你需要转发 HTTPS,请复制一份上面的内容粘贴到下面,修改监听端口为 443,转发端口就是你监听的 https 端口!

STEP 4 nginx config PHP

php 的转发设置会稍有一些不同,(默认你已经安装好了 PHP)

server {
  listen 80;
  root /var/www/longqiyoutian/wordpress; // 你的根目录
  index index.php;
  server_name dragon.yinode.tech;
  error_page 404 /404.html;
  location ~ \.php$ {
    try_files $uri = 404;
    fastcgi_pass unix:/var/run/php/php7.0-fpm.sock; // 你的fpm地址
    fastcgi_index index.php;
    include fastcgi_params;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name; // 必须填写,注意顺序
  }
}

逐个讲解,首先我们的 Root 目录会变的重要,Nginx 将会把这个目录转发给 FPM 来跑 PHP 代码,所以不要写错了,第二是后面的转发必须加上 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;这能引导 fpm 进行正确的地址拼接

TIPS:提醒

nginx 和 FPM 的默认启动用户都是 www-data,所以你的网站根目录请务必修改所属者为 www-data,并且不要将这个目录放置到/root/ 下,会出现权限问题,最好复制到/var/www 目录下,并设置所属者!

STEP 5 Repeat

重复 3 4 步骤,创建所有你需要的项目配置

STEP 6 Restart nginx

service nginx restart

如果出现报错,仔细查看信息,去网上找,一般都是因为配置文件格式错误。

STEP 7 Run

打开你的网站吧,应该可以正常运行了!以后新增 Server 其实也只要增加一个对应的 conf 文件,可以很方便的横向扩展,并且整个网站访问起来也会比较美观!

最后 附上我的博客地址,可以来看看

Blog


laoLiueizo
318 声望4 粉丝