一台阿里云服务器怎么部署多个网站?以CentOS系统为例

本文阿里云百科介绍如何在CentOS 7系统的ECS实例上使用Nginx搭建多个Web站点。本教程适用于熟悉Linux操作系统,希望合理利用资源、统一管理站点以提高运维效率的用户。比如,您可以在一台云服务器上配置多个不同分类的博客平台或者搭建多个Web站点实现复杂业务的网站系统。教程中,将在一台已部署LNMP环境的实例上同时搭建两个测试站点Testpage-1和Testpage-2,并访问对应的站点。

目录

前提条件

创建测试站点

配置Nginx

(可选)本地配置hosts

执行结果


前提条件

创建测试站点

  1. 远程连接已部署LNMP环境的ECS实例。 远程连接方式请参见通过密码或密钥认证登录Linux实例

  2. 运行以下命令进入已配置好的网站根目录。

    复制代码
    cd /usr/share/nginx/html
  3. 运行以下命令创建两个测试文件夹。文件夹中用于存放测试网站信息,即存放项目代码。

    复制代码
    mkdir Testpage-1
    mkdir Testpage-2
  4. 配置测试站点Testpage-1的信息。

    1. 运行以下命令进入Testpage-1。

      复制代码
      cd /usr/share/nginx/html/Testpage-1/
    2. 运行以下命令创建并编辑index.html文件。

      复制代码
      vim index.html
    3. 按i进入编辑模式,输入以下测试内容。

      复制代码
      Test page 1

      编辑完成后,按Esc键,并输入:wq后按下回车键,保存并退出。

  5. 配置测试站点Testpage-2的信息。

    1. 运行以下命令进入Testpage-2。

      复制代码
      cd /usr/share/nginx/html/Testpage-2/
    2. 运行以下命令创建并编辑index.html文件。

      复制代码
      vim index.html
    3. 按i进入编辑模式,输入以下测试内容。

      复制代码
      Test page 2

      编辑完成后,按Esc键,并输入:wq后按下回车键,保存并退出。

配置Nginx

  1. 运行以下命令查看nginx.conf配置文件。

    复制代码
    cat /etc/nginx/nginx.conf

    http{}模块内,查看include配置信息。

    本示例中配置如下图所示,include /etc/nginx/conf.d/*.conf;表示Nginx将会从该路径下的所有.conf文件获取站点信息。

  2. 运行以下命令进入/etc/nginx/conf.d路径下。

    复制代码
    cd /etc/nginx/conf.d
  3. 为测试站点Testpage-1创建并配置Nginx配置文件。

    1. 运行以下命令创建并编辑配置文件。

      复制代码
      vim Testpage1.conf
    2. 按i进入编辑模式,输入以下内容。在注释内容处,替换服务器域名参数信息与项目路径参数信息。

      复制代码
      server {
          listen       80;
          server_name  testpage1.com;    #此处使用测试域名。实际配置中使用您的服务器域名。
      
          #charset koi8-r;
          access_log  /var/log/nginx/b.access.log  main;
      
          location / {
              root   /usr/share/nginx/html/Testpage-1;    #测试站点路径。即您的项目代码路径。
              index  index.html index.htm;
          }
      
          #error_page  404              /404.html;
      
          error_page   500 502 503 504  /50x.html;
          location = /50x.html {
              root   /usr/share/nginx/html;
          }
      }

      编辑完成后,按Esc键,并输入:wq后按下回车键,保存并退出。

  4. 为测试站点Testpage-2创建并配置Nginx配置文件。

    1. 运行以下命令创建并编辑配置文件。

      复制代码
      vim Testpage2.conf
    2. 按i进入编辑模式,输入以下内容。在注释内容处,替换服务器域名参数信息与项目路径参数信息。

      复制代码
      server {
          listen       80;
          server_name  testpage2.com;    #此处使用测试域名。实际配置中使用您的服务器域名。
      
          #charset koi8-r;
          access_log  /var/log/nginx/b.access.log  main;
      
          location / {
              root   /usr/share/nginx/html/Testpage-2;    #测试站点路径。即您的项目代码路径。
              index  index.html index.htm;
          }
      
          #error_page  404              /404.html;
      
          error_page   500 502 503 504  /50x.html;
          location = /50x.html {
              root   /usr/share/nginx/html;
          }
      }

      编辑完成后,按Esc键,并输入:wq后按下回车键,保存并退出。

  5. 运行以下命令重启Nginx服务。

    复制代码
    systemctl restart nginx

也可以直接安装宝塔Linux面板,然后在宝塔面板上安装多个网站,详细参考:https://www.aliyunfuwuqi.com/ecs/3465/

(可选)本地配置hosts

由于本教程中全部使用的测试信息,因此需要在本地的hosts文件中配置IP映射。如果您在配置多个站点信息时使用的是真实的服务器域名,请忽略该步骤。教程中本地物理机使用Windows操作系统。

  1. 访问C:\Windows\System32\drivers\etc目录。

  2. 复制hosts文件进行备份。 保留hosts - 副本文件,在测试完成后使用该文件恢复hosts文件的初始状态。

  3. 修改hosts文件。在文件末尾追加以下内容。

    复制代码
    <ECS实例公网IP> testpage1.com
    <ECS实例公网IP> testpage2.com

    保存文件并退出。

  4. 返回Windows桌面,并按下Win + R组合键。

  5. 在运行对话框中输入cmd,并单击确定。

  6. 在命令行中运行以下命令,使hosts配置立即生效。

    复制代码
    ipconfig /flushdns

执行结果

在本地主机打开浏览器,成功访问到两个测试站点。

  • 访问testpage1.com/,查看Testpage-1站点内容如下所示。

  • 访问testpage2.com/,查看Testpage-2站点内容如下所示。

至此多个Web站点已搭建成功。在实际搭建站点场景中,您只需要将配置文件中的域名与项目路径配置正确,即可实现多站点的访问。

本文转自阿里云官方文档。

相关推荐
nihuhui6661 小时前
NFS服务器实验
运维·服务器
Serverless社区1 小时前
MCP Server 实践之旅第 3 站:MCP 协议亲和性的技术内幕
阿里云·云原生·serverless·函数计算
PWRJOY1 小时前
Flask-SQLAlchemy核心概念:模型类与数据库表、类属性与表字段、外键与关系映射
服务器·数据库·flask
三三十二2 小时前
Labview基础使用教程
服务器·前端·javascript
2302_799525742 小时前
【Linux】第二十五章 运行容器
linux·运维·服务器
朱包林2 小时前
day18-特殊符号
linux·运维·服务器·ubuntu·centos
m0_747124534 小时前
服务器并发实现的五种方法
服务器·网络编程
雨笋情缘5 小时前
【2025-05-22】centos 离线安装兼容node和npm版本的pm2 和 yarn
linux·npm·centos·node·yarn·pm2
无名之逆5 小时前
Build High-Performance Web Services with Hyperlane
服务器·开发语言·前端·http·rust
你是狒狒吗5 小时前
JWT了解
java·服务器·网络