DailyHot今日热榜部署教程

DailyHot 今日热榜:聚合了多个平台的热搜,一页尽知天下事,推荐部署!

项目均来自于imsyy大佬,后端项目:DailyHotApi,前端项目:DailyHot

一、准备工作

  • 1、一台VPS,安装了基本环境,本教程以宝塔面板为例
  • 2、如果打算前后端分离,需要准备两个二级域名,本教程后端域名:hot-api.bbit.fun,前端域名:hot.bbit.fun

二、后端API部署

1、源码部署

clone项目

bash 复制代码
 cd /www/wwwroot
 git clone https://github.com/imsyy/DailyHotApi.git

Tips:服务端口以及允许的域名可在根目录下的.evn文件内修改

安装Node.js、npm、pnpm

sql 复制代码
 apt update -y
 apt install nodejs npm -y

 npm install -g pnpm

切换到项目路径、安装依赖

bash 复制代码
 cd DailyHotApi
 pnpm install

安装【PM2管理器5.5】

我们先到宝塔的软件管理,搜索pm2,安装【PM2管理器5.5】

点击PM2管理器 5.5右边的设置,点击Node版本,我选择了v18.19.0,等待切换完成

点击【模块管理】,在搜索框输入pnpm,点击【安装】

前往 PM2管理器 ---项目列表--- 添加项目

启动文件:选择网站根目录的index.js,比如我的:/www/wwwroot/DailyHotApi/index.js,其他的默认不用管,点击提交

最后前往项目列表--- 为该项目映射添加域名

Tips:如果前端根目录下的.evn文件内是https协议,必须用宝塔申请部署免费SSL证书

温馨提醒: 如果使用的是如 腾讯云 阿里云 华为云等服务器,需要前往安全组/防火墙 添加设置的服务器端口6688,其它服务器需要在宝塔面板 -- 安全 -- 添加端口规则

至此,API就部署好了

测试

在浏览器输入:http://你的小鸡ip:6688/,出现以下界面说明成功:

2、Docker部署

安装及配置 Docker 将不在此处说明,请自行解决

本地构建

拉取源代码

bash 复制代码
 git clone https://github.com/imsyy/DailyHotApi.git

构建

bash 复制代码
 cd DailyHotApi
 docker build -t dailyhot-api .

运行

arduino 复制代码
 docker run -p 6688:6688 -d dailyhot-api

在线部署

arduino 复制代码
// 拉取
docker pull imsyy/dailyhot-api:1.0.5
// 运行
docker run -p 6688:6688 -d imsyy/dailyhot-api:1.0.5

后续可以加上cf域名解析+nginx反代

三、前端部署

前端编译比较耗费内存,请使用至少有2G内存的小鸡或在本地编译

1、源码部署

clone项目

bash 复制代码
git clone https://github.com/imsyy/DailyHot.git

如果是在本地编译,要确保node版本>16.x.x,具体可以看编译时的提示信息

修改.env文件

将VITE_GLOBAL_API改为你的后端api的url,并修改备案号

Tips:如果后端根目录下的.evn文件内是https协议,必须申请部署免费SSL证书

编译打包项目

bash 复制代码
cd DailyHot
pnpm install
pnpm build

或者npm打包

arduino 复制代码
cd DailyHot
npm install
npm run build

编译完成,没有报错的话,项目目录下会有一个dist目录

Nginx部署

在宝塔中新建站点,将dist目录下的文件全部复制到宝塔站点根目录中即可

2、Docker部署

拉取源代码

bash 复制代码
git clone https://github.com/imsyy/DailyHot.git

进入目录

bash 复制代码
cd DailyHot

编辑start.sh脚本

vim start.sh

要将API 地址及备案号作为环境变量传入打包好的静态资产并构建镜像需要写一个脚本,内容如下:

bash 复制代码
#!/bin/ash

# 替换 API 地址及备案号
find '/app' -name '*.js' -exec sed -i -e 's,http://localhost:6688,'"$API"',g' {} ;
find '/app' -name '*.js' -exec sed -i -e 's,豫ICP备2022018134号-1,'"$ICP"',g' {} ;

# # 启动 httpd 服务器
httpd -f -p 80 -h /app

添加执行权限

bash 复制代码
chmod +x start.sh

编辑Dockerfile

ini 复制代码
FROM node:16-alpine

WORKDIR /app

COPY package.json .

RUN npm install

COPY . .

RUN npm run build

FROM busybox:1.35.0-uclibc

WORKDIR /app

COPY --from=0 /app/dist .

COPY --from=0 /app/start.sh .

ENV API="https://api-hot.imsyy.top"

ENV ICP="豫ICP备2022018134号-1"

CMD ["/app/start.sh"]

构建镜像

erlang 复制代码
docker build -t dailyhot-web .

运行

ini 复制代码
docker run -d \
    --name dailyhot-web \
    -p 6677:80 \
    -e API="https://hot-api.bbit.fun" \
    -e ICP="没有备案捏" \
    --restart always \
    dailyhot-web

修改刚刚搭建的api地址以及备案号,访问ip:6677即可看到热榜

后续可以加上cf域名解析+nginx反代

参考文档

在宝塔面板上部署DailyHotApi

Docker部署"dailyhot"

部署一个自己的今日热榜(后端+前端)

相关推荐
2401_857600956 小时前
电商系统开发:Spring Boot框架实战
java·spring boot·后端
天草二十六_简村人7 小时前
spring-data-elasticsearch 3.2.4 实现桶bucket排序去重,实现指定字段的聚合搜索
java·spring boot·后端·spring·elasticsearch·架构·jenkins
拔剑纵狂歌8 小时前
ZooKeeper单机、集群模式搭建教程
分布式·后端·学习·zookeeper·中间件·架构·服务发现
jokerest1238 小时前
web——upload-labs——第五关——大小写绕过绕过
前端·后端
java_python源码9 小时前
[含文档+PPT+源码等]精品基于springboot实现的原生Andriod手机使用管理软件
java·spring boot·后端
技术猿1887027835110 小时前
Spring Boot应用中的文件压缩与解压技术实践
java·spring boot·后端
码哥字节10 小时前
30+ 程序员降薪跳槽到银行,技术优势成了空谈。银行的职场环境,远比想象中的要复杂
后端
hlsd#10 小时前
go 集成swagger 在线接口文档
开发语言·后端·golang
大脑经常闹风暴@小猿11 小时前
Django 启用国际化支持—实现配置多国语言
后端·python·django
计算机-秋大田11 小时前
基于微信小程序的在线疫苗预约的设计与实现,LW+源码+讲解
spring boot·后端·微信小程序·小程序·vue