NewsNow搭建喂饭级教程

大家在自媒体写文章里遇到最难的问题便是查找题材了,随便选择的题材没多少人会去看,平台也不会给流量推送,所以,只有围绕热门题材去进行文章创作,才能得到平台的重点推送以及大家的关注!

在做这个功能前,博主也查阅了很多聚合实时热点的工具,像目前比较火的一款DailyHot(源码地址:https://github.com/imsyy/DailyHotApi),星标也还可以有3K

界面如下,基本把国内的主流媒体内容全部聚合进来了!

不过,它的缺点也很明显,只有国内资讯信息,而且里面很多信息都是雷同的,对于咱搞AI的朋友们来说,做信息频道那必须和国际接轨,所以这个也就被我PASS了。经过一番查找,还真让我找到了一款**开源且支持全球各个频道的聚合资讯热榜网站**,而且星标也有12.7K之高。

相较于传统的聚合网站,它不仅除了有国内外新闻实时,还支持像github、稀土掘金、雪球股票推荐等不同类型的排行榜。

先来看下它的强大之处(截图只展示了一小部分信息,具体详情可以查看:NewsNow

好了,接下来,我将详细讲解如何从0到1部署一套这样的实时资讯聚合资讯系统

1、下载newsnow源码

执行以下命令克隆源码

复制代码
`git clone git@github.com:ourongxing/newsnow.git
`

本地无法访问github的有两种方式,一种是修改本地Host配置,添加下中转ip映射,ip具体如何找可以参考我之前分享的方法

另外一种方法是使用加速器,比如:虾壳(虾壳 - GitHub下载加速网站 GitHub Proxy加速器)把地址转一道

2、安装Node.js

因该工程使用的TypeScript编写的,需要使用npm(国内用户可以使用pnpm)安装相关的依赖包,如何安装nvm可以参考我之前的文章(不会装nvm?Node.js版本老旧?手把手带你升到node18+,高效搭建微信群聊机器人!),里面有详细介绍nvm安装多版本node的步骤,这里需要安装20或20以上的node版本,安装完成后,使用以下命令:node -v 查看,可以看到版本号即安装完成

3、安装包依赖

进到newsnow文件夹下,使用命令:**pnpm i **进行相关依赖安装,没有pnpm命令的可以到圈友互联AI(https://ai.quanyouhulian.com/#/chat/)去问AI如何安装该命令!

这里首次安装依赖时候我遇到了个问题,pinyin包安装不上去,可以使用以下命令先去单独安装这个特定的包

复制代码
`pnpm add @napi-rs/pinyin@1.7.5 -D
`

然后再重新执行下:pnpm i,可以看到所有包都成功安装了

4、本地启动开发环境

接下来,启用下开发环境:pnpm dev,可以看到项目已经成功启动了

本地浏览器也打开下,完美运行!

5、打包

接下来,就是进行项目打包了,使用命令:pnpm build,可以看到成功打出了dist文件夹,该文件夹下有两个文件夹,一个public(前端静态文件),一个server(使用node部署的后端文件)

6、推送dist文件夹内容到云服务器上

本地使用scp命令推送dist下全部文件及文件夹到:/usr/share/nginx/html/news/ 下,云服务器安装完nginx后,html的默认路径便是:/usr/share/nginx/html/

复制代码
`scp -r /newsnow/dist/* root@你的服务器ip地址:/usr/share/nginx/html/news/
`

7、启动后端服务

SSH登录云服务器后,切换到server目录下

复制代码
`cd /usr/share/nginx/html/news/output/server
`

使用pm2启动后端server服务,没有安装pm2的去圈友互联AI(圈友互联AI)问AI获取详细安装步骤

复制代码
`pm2 start "node ./index.mjs" --name newsnow
`

8、Nginx配置域名及代理

接下来就是配置域名了,这里域名使用你自己的地址,解析到对应的服务器。这里需要配置/api/指向到本地的3000端口,当前项目后端使用的是该接口,如果你改了端口就改成你对应的端口即可!

复制代码
`    server {
        listen 80;
        server_name news.quanyouhulian.com;

        # 网站根目录设置为前端静态文件的路径
        root /usr/share/nginx/html/news;
        index index.html;

        # 处理前端路由
        location / {
            try_files $uri $uri/ /index.html;
        }

        # 将所有 /api 的请求转发给后端 Node.js 服务
        location /api/ {
            proxy_pass http://127.0.0.1:3000; # 后端服务监听的地址和端口
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection 'upgrade';
            proxy_set_header Host $host;
            proxy_cache_bypass $http_upgrade;
        }

        listen 443 ssl;
        ssl_certificate /etc/letsencrypt/live/news.quanyouhulian.com/fullchain.pem;
        ssl_certificate_key /etc/letsencrypt/live/news.quanyouhulian.com/privkey.pem;
        include /etc/letsencrypt/options-ssl-nginx.conf;
        ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
    }
`

我这里SSL证书使用的是免费的,如何安装免费SSL证书可以参考我之前的文章:个人网站SSL证书太贵?30秒完成HTTPS证书配置,而且免费永不过期!

9、部分无法抓取的网站改用代理地址

因为里面的Hacker news和Product Hunt国内网络无法直接访问到,所以这里需要做一层反向代理,在海外云服务器搭一层nginx作反向代理即可,这里云服务器可以使用极速云联:极速云联-香港云服务器主机租用_美国免费高防服务器测试_最便宜的VPS云主机购买,这里把nginx.conf配置如下反向代理配置

复制代码
`    server {
        server_name 你自己的域名地址;

        location / {
            proxy_pass https://news.ycombinator.com;
            proxy_set_header Host news.ycombinator.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_ssl_server_name on;
            proxy_ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        }

        listen 443 ssl;
        ssl_certificate /etc/letsencrypt/live/xxxxxx.com/fullchain.pem;
        ssl_certificate_key /etc/letsencrypt/live/xxxxxx.quanyouhulian.com/privkey.pem;
        include /etc/letsencrypt/options-ssl-nginx.conf;
        ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
    }


    
    server {
        server_name 你自己的域名地址;

        location / {
            proxy_pass https://www.producthunt.com;
            proxy_set_header Host www.producthunt.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_ssl_server_name on;
            proxy_ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        }

        listen 443 ssl;
        ssl_certificate /etc/letsencrypt/live/xxxxxx.com/fullchain.pem;
        ssl_certificate_key /etc/letsencrypt/live/xxxxxx.com/privkey.pem;
        include /etc/letsencrypt/options-ssl-nginx.conf;
        ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
    }
`

10、修改代码地址并重新打包发布

把hackernews.ts和producthunt.ts改成新地址

重新打包推到云服务器发布后,可以看到数据成功刷出来了,完美搞定!

相关推荐
weixin_5824701718 分钟前
GS-IR:3D 高斯喷溅用于逆向渲染
人工智能·算法
GetcharZp1 小时前
玩转AI绘画,你只差一个节点式“魔法”工具——ComfyUI 保姆级入门指南
人工智能·stable diffusion
一休哥助手2 小时前
Naive RAG:简单而高效的检索增强生成架构解析与实践指南
运维·人工智能·架构
机器之心2 小时前
究竟会花落谁家?DeepSeek最新大模型瞄准了下一代国产AI芯片
人工智能·openai
赵英英俊2 小时前
Python day51
人工智能·pytorch·python
双向332 小时前
金融风控AI引擎:实时反欺诈系统的架构设计与实现
人工智能
星期天要睡觉2 小时前
计算机视觉(opencv)实战六——图像形态学(腐蚀、膨胀、开运算、闭运算、梯度、顶帽、黑帽)
人工智能·opencv·计算机视觉
悟纤2 小时前
AI翻唱实战:用[灵龙AI API]玩转AI翻唱 – 第6篇
人工智能·ai翻唱·ai cover
Dante但丁3 小时前
手扒Github项目文档级知识图谱构建框架RAKG(保姆级)Day5
人工智能