• Windows上搭建一个网站(基本生产环境)


    前言

    本博客记录的是Windows上一次网站搭建的过程,主要是在前端采用的是React,后端采用的是Flask,记录一下生产版本搭建流程和坑点,供有缘人一起进步,当然本博客还存在很多不足。

    前端项目构建生产版本

    React为例,在终端运行npm run build后,在项目根目录会出现build文件夹

    npm run build

    build文件夹内的文件:

    配置运行前端的服务器(以apache为例)

    配置文件(httpd.conf)在apache安装目录下的conf目录内

    解除路由转发的限制:

    我们在开发环境中可能用到了一些路由转发的中间件,如在React开发中使用http-proxy-middleware(运行在node.js上时使用的),构建了生产版本以后这个是不能再使用了。所以需要找到以下两个模块,关闭注释即可。

    添加路由转发的规则:

    前端使用的接口是/api/test,后端使用的是/test,后端的运行地址是127.0.0.1:5000,所以设置如下规则。其他路由转发同理。

    配置文件最后一行修改超时时间:

    apache的超时时间,关系着一些耗时请求。原为60即一分钟,如果apache发出网络请求后在1分钟内没有收到响应,会自己响应一个错误响应。所以需要根据后端耗时操作自行修改:

    (这里是因为后端运行图像处理,所以设大了一点,具体的根据自己的实际情况设置即可)

    前端运行在服务器上

    配置apache的运行端口,如下设置在3000端口,根据自己的需要修改:

    在配置文件中找到服务器的网站目录(也可以自己修改):

    如果是使用的小皮面板,也可以在小皮面板上设置运行端口,并且查看服务器网站目录:

    将前端生产版本(build文件夹内的文件)放入apache的网站目录:

    启动服务器,并查看效果:

    如图使用的小皮面板启动,但是需要在一个apache上启动多个前端服务的话,还需自行学习一下(因为我偷懒没学习)。也可以自行安装多个apache,分别配置以启动多个服务。小皮面板好像不能启动多个服务器。

    查看3000端口,出现前端页面:

    启动后端(以Flask为例)

    这里还可以进一步升级,使用apache等服务器等运行,配置有一丢丢复杂,试了几次没成功就放弃了,可以自行学习一下。

    设定好后端的相关配置,如运行端口,与前端服务器上的路由转发相匹配:

    运行后端:

    再次打开前端页面,查看和后端通信是否正常:

    正常情况下是能完成通信的。至此,你已经完成了一个网站的搭建,如果是租用的公网服务器,只需要再将域名解析到服务器的IP即可。如果你是内网的服务器,你还需要进行如下内网穿透。

    内网穿透

    找到一个自己喜欢的内网穿透工具:

    如果不需要自定义域名的话,市面上大多数内网穿透根据都能满足你,但是需要自定义已购买的域名并且自定义域名不想备案的话,需要内网穿透平台具有香港或国外的节点(目前找到两个, Sunny-Ngrok内网转发内网穿透 - 国内内网映射服务器飞鸽内网穿透官网 (fgnwct.com),也可以自行查找。Tips:前一个应该稳妥一点。两个都买了,依据我使用的情况,后者可能会受限于网络,三台机子,只有一台能成功运行,可能是还需要根据网络进行配置。前者三台机子都成功运行。不过进了群发现,emmm,这两家的群主是一个人。)

    按相关官网进行实名认证,购买隧道,购买完成后将隧道的端口修改到前端运行的端口,如3000端口:

     查看内网穿透工具指明的cname地址,登录开通域名的平台,进入控制台修改域名解析,解析到该地址:

     

     填入内网穿透提供的解析地址(CNAME),确定后等待域名解析更新完成。

    到开通隧道的内网穿透平台,下载内网穿透客户端。有各种形式,下载自己喜欢的就行,客户端填入隧道ID,启动即可:

    进入域名查看效果:

    恭喜,你已经拥有一个可以通过域名访问的网站了(Tips:内网穿透注意别掉线咯)。不得不感叹,还是在Linux 上部署项目方便点,不过没办法,显卡在装了Windows的系统上。

  • 相关阅读:
    git提交代码实际操作
    Roblox 不但不支持 Linux,还屏蔽了 Wine
    SpringBoot结合Vue.js+axios框架实现增删改查功能+网页端实时显示数据库数据(包括删除多条数据)
    SpringMvc-HttpMessageConverter接口
    铭飞MCms不建议使用
    【MAPBOX基础功能】14、mapbox点击面图层高亮指定的面
    深度解析:什么是太爱速M抢单模式?
    区块链(8):p2p去中心化之websoket服务端实现业务逻辑
    [CSP-J 2022] 乘方
    一起误删cni0虚拟网卡引发的k8s事故
  • 原文地址:https://blog.csdn.net/weixin_52470573/article/details/134479730