DarkTime
  • README
  • SpringBoot
    • spring boot 运维
    • Spring Boot 部署war包
    • springboot搭建
    • spring boot 读取配置文件
    • 简单总结
    • spring配置文件
    • spring boot Configuration
    • spring boot 配置文件
    • spring boot 配置mybatis
  • MacAwesome
    • markdown使用
    • MAC APP Awesome
    • [markdown使用](/MacAwesome/SUMMARY.md)
    • chrome
    • intellij idea
    • MacAwesome
    • VS Code 的使用
    • MAC Shell命令
  • database
    • druid使用
  • 框架
    • 项目拆析
    • 各种框架和工具
  • docker
    • kubernetes
    • docker
    • docker 常用镜像
  • 效率工具
    • 解决dns污染导致域名解析失败
    • sonarqube 相关配置
    • Iterm2 使用
    • gitbook
    • github awesome github资源推荐
    • playground 在线试用平台汇总
    • linux中的office
    • linux screen 工具
    • 简单Mock服务(moco)
    • npm
    • Visual Studio Code 的使用
    • 配置开发环境
    • homebrew的使用
    • 汇总
  • tomcat
    • tomcat目录规范
  • code_snippets
  • 专题
    • RESTful API
    • serveless服务
    • 搭建私有云主机 折腾记
    • 开发中的各种疑难杂症问题
    • spring 最佳实践
    • LLM 大语言模型
    • notelive
      • 文章框架
      • notelive vue版本开发
      • notelive 开发 札记
    • webrtc技术分析
    • 反向代理
    • spring-cloud
      • spring boot admin 监控服务
      • Spring Cloud 整理汇总
  • python
    • python 学习
    • Python 修饰器的一些小细节
  • 云主机
    • aliyun 主机的种种
  • maven
    • maven使用
    • maven项目增加编译版本号 buildnumber-maven-plugin
    • 仓库
  • java
    • java 开发常用工具类
    • java
    • apache commons pool 对象连接池
  • 大数据
    • kafka
    • gobblin
    • sqoop 简介及使用
    • hbase
    • gobblin
    • sqoop源码解析
    • hadoop map reduce
    • 大数据 学习札记
  • 脚本
    • python
      • 批量请求url 解析json数据
    • js
      • sheetjs-js读取excel
    • shell
      • 自动生成bitbook的summary文件
      • linux/mac 实用脚本
      • 自动创建tomcat项目脚本
      • 批量处理文件内容脚本
  • nginx
    • nginx
    • ngix 文件浏览器 文件服务器
  • linux
    • 群晖nas札记
    • ftp
    • linux 运维
    • 常用命令
    • linux
    • mysqldump脚本
    • 代理
    • 简易灰度部署脚本 不使用jenkins的纯shell方式
    • shell脚本
    • 附加文档
  • mysql
    • sql
  • 游戏开发
    • Unity 2020 学习笔记
  • 学习笔记
    • centos常用环境安装
    • gradle 学习
    • 建站经历
    • python
      • 爬虫教程
    • 如何解决百度爬虫无法爬取搭建在Github上的个人博客的问题? - 知乎
    • baas
      • 在本地部署Parse Server
    • mysql学习标记
    • java code snippets
    • 非Spring Boot Web项目 注册节点到Eureka Server并提供服务
    • kotlin
      • Kotlin 学习札记
    • spring cloud
    • vim配置
    • 前端
      • 开发PWA应用
  • jenkins
    • jenkins配置备份
    • gitlab触发Jenkins 自动构建
    • 安装与使用
  • npm
    • npm 使用
  • git
    • ignore
    • git使用总结
    • git配置多个远程仓库
  • 前端
    • swig
    • 解决跨域请求问题
    • angularjs 学习
    • scriptbot的前端开发经验总结
    • 各种资源
    • 一些有用的js代码
Powered by GitBook
On this page
  • 背景
  • 技术栈
  • 部署方案
  • 前端部署
  • 后端部署
  • 开发PWA应用
  • 参考资料
  • 一些零碎的知识点

Was this helpful?

  1. 专题
  2. notelive

notelive 开发 札记

Previousnotelive vue版本开发Nextwebrtc技术分析

Last updated 5 years ago

Was this helpful?

背景

之前采用leancloud+html页面写了一个简单的在线记事本工具,。现在得空准备重写该项目。一方面,之前因为受限于没有后台服务的纯前端页面因此无法实现更复杂的功能,所以这次准备在功能上进行一次迭代升级。另一方面,也是为了学习新的框架。这次采用的框架是 mongodb+nodejs+express+html,之所以这么选一方面这是市面上常见的方案,另一方面这些都是我没接触过的东西,后者原因最重要咯。

技术栈

docker:mongodb采用docker部署

数据库:mongodb 原因是存储json对象方便,毕竟只是个轻量级的小项目

后端:nodejs 使用express框架。express框架封装了http模块,使得开发后台服务变得更简单。

部署方案

前端部署到到支持静态网站的代码托管平台,比如国内的coding,国外的github page。 后台代码部署到自己的云服务器上,mongodb数据库使用docker部署。后端与mongodb为内网连接。

前端部署

后端部署

好一些的方案是借助pm2工具管理服务,

pm2管理项目

全局安装pm2npm install -g pm2 启动服务pm2 start ./bin/server.js 查看所有服务pm2 list 查看服务详情pm2 show <id|name> 查看日志 pm2 logs <id|name> [--lines 1000]

pm2 startOrRestart ./app.json 通过配置文件启动

{
  "apps": [
    {
      "name": "notelive",
      "max_memory_restart": "100M",
      "script": "./bin/server",
      "log_date_format": "YYYY-MM-DD HH:mm:ss",
      "out_file": "./logs/out.log",
      "error_file": "./logs/error.log",
      "instances": 2,
      "exec_mode": "cluster",
      "env": {
        "NODE_ENV": "production",
        "PORT": 8805,
        "AllowOrigin": "http://live.rizon.top"
      },
      "env_dev": {
        "NODE_ENV": "develop",
        "PORT": 8808,
        "AllowOrigin": "*",
        "mongo":{
          "url": "mongodb://localhost:8907/",
          "db": "demo",
          "col": "note"
        }
      }
    }
  ]
}

env为默认的环境配置(生产环境),env_dev、env_test来指定不同环境的环境变量配置,通过参数--env指定环境:pm2 start app.js --env dev

开发PWA应用

参考:

使用localStorage存储当前工作内容,localStorage比cookie更适合存储当前会话的数据。

参考资料

一些零碎的知识点

  1. JavaScript的函数声明与函数表达式的区别

    // 1,函数声明(Function Declaration)
    function funDeclaration(type){
        return type==="Declaration";
    }
    // 2,函数表达式(Function Expression)。
    var funExpression = function(type){
        return type==="Expression";
    }

前端:html,会使用lodash的throttle函数来进行函数节流,参考:

1.配置托管 本次前端代码部署到github pages。 push前端代码到github之后,打开repository->settings,往下翻找到GitHub Pages,开启服务,默认给你提供了一个username.github.io的三级域名,这里我们绑定自定义域名(Custom domain)。 2.配置域名解析 保存后,打开你购买的域名的管理后台,配置域名解析,有两种配置方案一个是CNAME一个是A记录,A记录的对应IP可以查看githubpages的帮助文档,这里采用CNAME配置,比较简单。

1.docker部署mongodb数据库 安装好docker环境,安装帮助可以参考: 1)拉取mongo镜像docker pull mongo 2)启动镜像docker run -d --name notelive-mongo --hostname notelive-mongo -p 127.0.0.1:8807:27017 mongo -d参数后台运行,-p 127.0.0.1:8807:27017将容器内的27017端口绑定到宿主机的127内网ip的8807端口上,这样在机器上就可以用8807端口访问服务,而且即使当你的8807端口可以外网访问,也无法在外网请求到该服务。 3)部署后台代码,npm安装依赖 简单的启动服务方案是直接node命令启动:PORT=8805 AllowOrigin=http://live.rizon.top nohup node ./bin/www >>log.log 2>&1 &,写入环境变量并将日志重定向到文件后在后台运行服务。

参考:

mongodb:

nodejs:

Javascript 中函数声明和函数表达式是存在区别的,函数声明在JS解析时进行函数提升,因此在同一个作用域内,不管函数声明在哪里定义,该函数都可以进行调用。而函数表达式的值是在JS运行时确定,并且在表达式赋值完成后,该函数才能调用。来源: 2. js异步函数同步调用 Promise

notelive 开发 札记
背景
技术栈
部署方案
前端部署
后端部署
pm2管理项目
开发PWA应用
参考资料
一些零碎的知识点
note.rizon.top
debounce与throttle区别
centos常用环境安装#安装docker
pm2使用心得
使用PM2来部署nodejs项目
pm2配置文件介绍 - CSDN博客
PM2实用入门指南 - 程序猿小卡 - 博客园
PWA介绍及快速上手搭建一个PWA应用 - 游魂的技术日志 - SegmentFault 思否
使用offline-plugin搭配webpack轻松实现PWA - Jrain-前端玩具盆 - SegmentFault 思否
Node.js 连接 MongoDB | 菜鸟教程
Node.js MongoDB
Nodejs进阶:用debug模块打印调试日志 - 程序猿小卡的前端专栏 - SegmentFault 思否
JavaScript的函数声明与函数表达式的区别
Node.js的那些坑(三)——如何在异步方法都执行后再执行 - CSDN博客
JS - Promise使用详解--摘抄笔记 - sweeeper - 博客园