Skip to content

shinobuffer/Von

Repository files navigation

Von

a personal blog for ACG lover

一个基于Vue开发的博客,献给所有热爱ACG,热爱生活的人;也算是给几月来坚持不懈的我的奖赏吧

该项目为重构优化之后的SSR版本,并且以后也只维护该项目,如对旧项目(SPA版本)有需要请转此处

Introduction

整个博客(下称Von)前端完全基于 Vue+Nuxt 开发,后端接口层 php 实现,python 辅助数据采集

除了一般博客有的功能,Von 还有如下特点

  • 技术上
    • 自适应宽度,双端适配(PC+移动)
    • 服务端渲染(SSR),更好的SEO
    • ...
  • 内容上
    • 追番页面(bangumi同步),记录追番进程
    • 动态页面(仿自B站),发送带图动态,分享日常
    • ...

版本更新记录 CHANGE_LOG

更详细的功能介绍转博客文章

Getting Started(待完善

该博客安装分为前端和后端两部分进行

Back-end

后端需要 LNPM 环境,宝塔之类的一键安装应该也可以吧(没试过),如果你喜欢折腾,可以参考这篇文章(我的生产环境就是基于此的)

LNPM 部署并配置好后

  • 执行sql脚本(见后端项目)初始化数据库
  • 在网站根目录中解压该压缩包以初始化文件资源
  • 下载对应版本的后端代码放在网站根目录,重命名为apis,并按照要求进行配置

接下来安装 nodejs,很简单这里就跳过了,下面给出之后要安装的模块

npm install pm2 -g

pm2 是用来托管进程的,能保证你和server的远程连接断开后 nuxt 还在运行。安装完pm2后把执行文件链到 bin 里以在命令行中使用:ln -s nodejs目录/bin/pm2 /usr/local/bin/pm2


最后是配置 Nginx 进行反向代理,把对页面的请求交给 nuxt 服务端,对静态资源和接口的请求进行拦截。向 http 块下添加以下配置,部分配置按实际情况添加 or 修改

upstream nuxtserver{
    server 127.0.0.1:8080;
    keepalive 64;
}
server {
    listen       80;
    # 网站域名
    server_name  www.xxx.com, xxx.com;
    index  index.html index.htm;
    # 禁止文件(夹)
    location ^~ /node_modules {
        return 404;
    }
    # 静态资源
    location ~ ^/(downloads|music|site|static|tmp|uploads)/ {
        # 网站根目录,下同
        root html_nuxt;
        access_log off;
        # 静态资源允许跨域,设置缓存
        expires 30d;
        add_header Access-Control-Allow-Origin *;
        add_header Access-Control-Allow-Headers X-Requested-With;
        add_header Access-Control-Allow-Methods GET,POST,OPTIONS;
    }
    # PHP CGI
    location ~ \.php$ {
        root           html_nuxt;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
    # 首先查看有没有该文件
    location / {
        root html;
        try_files $uri @nuxt;
    }
    # 最后交由代理
    location @nuxt{
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_read_timeout 1m;
        proxy_connect_timeout 1m;
        proxy_pass http://nuxtserver;
    }
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html_nuxt;
    }
}

另:如果你有 https 的需要可以参考申请免费证书的教程

Front-end

前端代码打包前进行自定义修改,都是些个人信息相关的东西(目前这部分信息的修改方式还未独立出来,只能改一次打包一次,未来版本会更新)

  • 按需修改 config/user.conf.js
  • 修改 pages/about/index.vue 的模板(关于页面)
  • 修改 pages/links/index.vue 的模板(友链页面)
  • 修改 staitc/robots.txt 中sitemap指向

修改完后对整个项目除nuxt.config.jsREADME.md的所有文件进行正则替换,把'/root'\+|/root替换为空(共47个分布在27个文件中),到此代码部分修改完成,进入打包环节。

npm install安装项目依赖,然后在项目根目录执行 npm run build 打包生成 .nuxt 文件夹。将 .nuxt, nuxt.config.js, package.json, package-lock.json, static下的所有文件 上传至服务器网站根目录

Run

到此网站根目录应该如下

www_root
  |--apis/
  |--apple-icon.png
  |--downloads/
  |--favicon.ico
  |--music/
  |--node_modules/
  |--.nuxt/
  |--nuxt.config.js
  |--package.json
  |--package-lock.json
  |--robots.txt
  |--site/
  |--sitemap.xml
  |--static/
  |--tmp/
  |--uploads/

再次检查php-fpm、nginx、mariadb/mysql服务是否已开启,如果没有问题,命令行执行pm2 start npm --name "自定名称" -- run start让pm2托管SSR服务,再执行pm2 save保存当前任务实现自启

Support

Nothing Yet

Author

Von © Bersder, Released under the MIT License

Blog · GitHub @Bersder · Twitter @nya_oshino · QQ 1747322151