当前位置: 首页 > news >正文

『亚马逊云科技产品测评』活动征文|通过Lightsail搭建个人笔记

提示:授权声明:本篇文章授权活动官方亚马逊云科技文章转发、改写权,包括不限于在 Developer Centre, 知乎,自媒体平台,第三方开发者媒体等亚马逊云科技官方渠道

在这里插入图片描述

文章目录

  • 前言
  • 实践知识储备
  • Lightsail介绍
  • Leanote介绍
  • 实践流程
  • 一、启动Lightsail实例
  • 二、开放Lightsail安全组
  • 三、下载 `leanote` 二进制版
  • 四、安装 `mongodb`
    • 4.1 测试`mongodb`安装
  • 五、导入初始数据
    • 六、配置`leanote`
    • 七、运行`leanote`
  • 总结
  • 部署常见问题
    • 1. no reachable server
    • 2. 修改Leanote运行端口
    • 3. 配置Nginx


前言

作为一个程序员,编写文档成为日常生活中必不可少的一件事情,有些是公司内部的文档资料,还有是希望写一些自己的学习笔记,我在撰写笔记的时候就发现那些笔记平台都渐渐走向付费模式了,图片上传要付费,同步也要付费,新增的功能更不必说,其实我只是想写个笔记而已,我一直在想能不能做一个自己的笔记平台。然后最近在开源社区发现了 Leanote,这是包含富文本编辑器和Markdown编辑器开源笔记系统,只要我们有自己的服务器就能搭建,可以把笔记和图片都放到自己的服务器,同时保障了隐私也避免了被笔记平台限制。刚好最近也注册了AWS,免费领取了12个月EC2和3个月Lightsail使用时间,于是我就把系统搭建在了 AWSLightsail 实例上,大家感兴趣的可以跟着我一起搭建!


提示:以下是本篇文章正文内容,下面案例可供参考

实践知识储备

在我们进行实践的时候,我们需要对AWSLightsail有一定了解,需要了解一些Linux的基本操作,如包管理、SSH连接等,因为笔记需要存储到数据库系统,所以你还需要了解一些关于MongoDB的基本操作

Lightsail介绍

AWS Lightsail是一项非常棒的云计算服务,可以帮助个人和小型企业快速启动和管理他们的应用程序和网站。

它提供了一种简单而强大的方式来启动虚拟服务器,并且我们可以选择多种不同的应用程序模板,比如WordPressGhost等,在几分钟内就能搭建起一个完整的网站。而且,AWS Lightsail还提供了一个直观的用户界面,让我们可以轻松管理服务器和网络设置。可以根据自己的需求选择不同的实例规格和存储选项,以及自动扩展功能来应对流量增长。

AWS Lightsail还具备出色的可靠性和安全性。它使用AWS云基础设施作为后盾,这意味着我们可以放心地将数据存储在高度安全的环境中,并且直接获得到可靠的性能和稳定性。

对于那些对成本敏感的朋友来说,AWS Lightsail也是一个不错的选择。它提供了灵活的计费模型,我们只需支付实际使用的资源,没有任何隐藏费用。而且,AWS Lightsail与其他AWS服务集成得非常方便快捷。

大家可以通过官网了解:https://aws.amazon.com/cn/lightsail/?nc2=h_ql_prod_fs_ls

在这里插入图片描述

Leanote介绍

介绍引用自官方开源文档

Leanote 是一个高效笔记开源系统,Leanote 有易操作的界面, 包含一款富文本编辑器和Markdown编辑器,让我们的笔记记录更轻松和高效。对高阶用户,还提供VimEmacs 编辑模式,助推写作速度更上层楼。

  • 知识管理: Leanote 灵活而强大的“笔记本-笔记-标签”系统,让它成为你个人知识管理的利器。
  • 分享: 你可以通过Leanote同好友分享知识、想法和经历, 邀请好友加入你的笔记簿,通过云端交流信息。
  • 协作: Leanote协助你与同事之间相互协作,激荡新思路,随时随地头脑风暴。
  • 博客: Leanote也可以作为你的个人博客, 把你的知识传播的更远!

其它特性

  • 支持Markdown编辑
  • 写作模式
  • VimEmacs 编辑模式
  • 支持PDF导出
  • 支持批量操作
  • 博客自定义主题, 实现高度定制化

一套完整的、全平台覆盖的软件套装,包括了web、桌面、安卓、IOS设备,而且全部开源!支持团队协同,企业级私有云部署。

  • 官方文档:https://leanote.com/

实践流程

  1. 启动Lightsail实例
  2. 开放Lightsail安全组
  3. 下载 leanote 二进制版。
  4. 安装 mongodb
  5. 导入初始数据。
  6. 配置 leanote
  7. 运行 leanote

一、启动Lightsail实例

从首页进入控制台后,在搜索框输入:Lightsail,进入Lightsail控制台

在这里插入图片描述
进入到 instance 列表页后,我们会看到右上角有一个 Create instance,点击进入开始创建实例

在这里插入图片描述

根据我们擅长的系统进行选择,这里我们的环境是:

  • 平台:Linux
  • 系统:Ubuntu20.04LTS

在这里插入图片描述
选择套餐3,2GB 2CPU

滑到最下点击 Create instance 就可以开始创建实例,创建完成后返回列表页就可以看到我们的实例了

在这里插入图片描述

二、开放Lightsail安全组

为了保证笔记搭建起来能被公网访问,我们需要对防火墙进行开放,默认 Lightsail 是只开放了 8022 端口的

点击实例,然后点击 Networking

在这里插入图片描述
我们会看到有一个 IPv4 Firewall,是用来配置流量进出的,这里我们添加一个规则 Add rule,选择 All TCP ,点击 Create 即可,这样就把我们所有的流量开放了,但是在生产环境不建议咱们这么做,还是需要对每个服务需要开放的端口进行控制,而不是全部放开。

三、下载 leanote 二进制版

配置好Lightsail后,我们就可以对 leanote 进行部署了,我们需要先下载我们需要部署的应用代码,可以从这里下载 leanote 最新二进制版。

这里我们安装一个 v2.6.1 的最新版:

wget http://sourceforge.net/projects/leanote-bin/files/2.6.1/leanote-linux-amd64-v2.6.1.bin.tar.gz
tar -xzvf leanote-linux-amd64-v2.6.1.bin.tar.gz 

在这里插入图片描述

代码下载好后,因为运行起来还需要环境依赖,所以我们先接着往下进行配置

四、安装 mongodb

到 mongodb 官网 下载相应系统的最新版安装包,或者从以下链接下载旧版本:

  • 64位 linux mongodb 5.0.22 下载链接: https://repo.mongodb.org/apt/ubuntu/dists/focal/mongodb-org/5.0/multiverse/binary-amd64/mongodb-org-server_5.0.22_amd64.deb
    在这里插入图片描述
  • 下载下来是一个 deb:
wget https://repo.mongodb.org/apt/ubuntu/dists/focal/mongodb-org/5.0/multiverse/binary-amd64/mongodb-org-server_5.0.22_amd64.deb
  • 通过 dpkg安装
dpkg -i mongodb-org-server_5.0.22_amd64.deb

4.1 测试mongodb安装

  • 先在/home/root下新建一个目录data存放mongodb数据:
mkdir /root/data
  • 用以下命令安装客户端启动mongod 测试:
# 需要先安装客户端
apt update
apt install mongodb-clients
mongod --dbpath /root/data

在这里插入图片描述

这时mongod已经启动,重新打开一个终端, 键入mongo进入交互程序:

mongo
> show dbs
...数据库列表

mongodb安装到此为止, 下面为mongodb导入leanote初始数据。


五、导入初始数据

leanote 初始数据存放在 /root/leanote/mongodb_backup/leanote_install_data中。

  • 打开终端, 输入以下命令导入数据。
mongorestore -h localhost -d leanote --dir /root/leanote/mongodb_backup/leanote_install_data/

这里大家可能会出现: Command 'mongorestore' not found, but can be installed with ,我们需要先安装一下 mongo-tools,然后再重新运行导入数据

apt update
apt install mongo-tools
#重新导入数据
mongorestore -h localhost -d leanote --dir /root/leanote/mongodb_backup/leanote_install_data/

在这里插入图片描述

看到 done ,即表示完成了,现在在mongodb中已经新建了leanote数据库, 可用命令查看下leanote有多少张"表":

# 通过client连接
mongo# 查看数据库
show dbs admin    0.000GB
config   0.000GB
leanote  0.002GB
local    0.000GB# 切换到leanote数据库
use leanote# 查看表
show collections 
album
sattachs
blog_comments
blog_likes
blog_singles
configs
email_logs
....

在这里插入图片描述

初始数据的users表中已有2个用户:

  • 账号:admin, 密码: abc123 (管理员, 只有该用户才有权管理后台, 请及时修改密码)
  • 账号:demo@leanote.com, 密码: demo@leanote.com (仅供体验使用)

六、配置leanote

leanote的配置存储在文件 conf/app.conf 中。我们需要修改配置中的app.secret,这是一个密钥,不能用默认的, 否则会有安全隐患!我这里随便把他改成了一个字符

在这里插入图片描述

其他配置可以暂时不修改


七、运行leanote

注意: 在此之前请确保mongodb已在运行!

  • 执行以下命令:
cd /root/leanote/bin
bash run.sh

最后出现以下信息证明运行成功:

...
DEBUG 06:04:21  revel controller.go:523: RegisterController:Registered controller  section=controller controller=App\\memberuser
DEBUG 06:04:21  revel server.go:106: InitServerEngine: Found server engine and invoking  section=server name=go 
Listening on.. 0.0.0.0:9000

在这里插入图片描述

恭喜你, 打开浏览器输入: http://localhost:9000 体验leanote吧!效果如下:

在这里插入图片描述
我们使用管理员账号登录一下:

  • 账号:admin, 密码: abc123

在这里插入图片描述

总结

实践到这里就已经是成功基于AWS Lightsail部署Leanote,并且实现了笔记的私有化。通过利用AWS Lightsail提供了简单而强大的云计算服务,让我们在几分钟内轻松搭建起Leanote实例。而且Leanote是一个开源的笔记应用程序,我可以完全控制我的笔记数据,数据存储也在高度安全的AWS云环境中,我再也不用担心隐私问题了。

AWS Lightsail 特别适合个人开发者进行快速测试和验证想法,可以让我们在几分钟内启动一个完整的应用程序。这大大加快了开发周期,能够迅速构建原型、测试功能和验证概念。AWS Lightsail 还提供了直观的用户界面和简化的管理工具,我们可以轻松管理他们的应用程序和服务器设置。通过几个简单的步骤启动、监控和扩展应用程序,而无需深入了解复杂的云基础设施。

部署常见问题

1. no reachable server

请确保数据库是否启动, 如果确定已启动 可以 尝试将 conf/app.conf db.host=localhost 改为 db.host=127.0.0.1

修改后请重新启动Leanote.

2. 修改Leanote运行端口

比如想以8080端口启动.

修改conf/app.conf:

http.port=8080
site.url=http://localhost:8080

请重启Leanote, 使用http://localhost:8080访问.

3. 配置Nginx

假设Leanote运行的端口是9000, 域名为a.com, 那么nginx.conf可以配置如下:

# 本配置只有http部分, 不全
http {include       /etc/nginx/mime.types;default_type  application/octet-stream;upstream  a.com  {server   localhost:9000;}# httpserver{listen  80;server_name  a.com;# 强制https# 如果不需要, 请注释这一行rewriterewrite ^/(.*) https://jp_linode2.com/$1 permanent;location / {proxy_pass        http://a.com;proxy_set_header   Host             $host;proxy_set_header   X-Real-IP        $remote_addr;proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;}}# httpsserver{listen  443 ssl;server_name  a.com;ssl_certificate     /root/a.com.crt; # 修改路径, 到a.com.crt, 下同ssl_certificate_key /root/a.com.key;location / {proxy_pass        http://a.com;proxy_set_header   Host             $host;proxy_set_header   X-Real-IP        $remote_addr;proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;}}
}

相关文章:

『亚马逊云科技产品测评』活动征文|通过Lightsail搭建个人笔记

提示:授权声明:本篇文章授权活动官方亚马逊云科技文章转发、改写权,包括不限于在 Developer Centre, 知乎,自媒体平台,第三方开发者媒体等亚马逊云科技官方渠道 文章目录 前言实践知识储备Lightsail介绍Leanote介绍实践…...

基于JavaWeb+SSM+Vue家庭记账本微信小程序系统的设计和实现

基于JavaWebSSMVue家庭记账本微信小程序系统的设计和实现 源码获取入口前言主要技术系统设计功能截图Lun文目录订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 前言 1.1选题背景 互联网是人类的基本需求,特别是在现代社会,个人…...

十二、h.264解码

前言 测试环境&#xff1a; ffmpeg的4.3.2自行编译版本windows环境qt5.12 完整代码&#xff1a; H264DncodeThread.h #ifndef H264DNCODETHREAD_H #define H264DNCODETHREAD_H#include <QObject> #include <QThread>extern "C" { #include <libavu…...

springboot前后端分离项目配置https接口(ssl证书)

文章目录 说明vue.js前端部署vue.js项目axios请求配置本地创建日志文件创建Dockerfile文件配置ssl证书nginx.confvue项目打包上传创建容器部署 后端springboot项目部署配置ssl证书打包部署 补充&#xff1a;jsk证书和pfx证书补充&#xff1a;两种证书的转化JKS转PFXPFX 转 JKS …...

智能小车速通版——手把手教程

考虑到大部分学校&#xff0c;会发放简易小车来作为智能车初期培训和筛选的工具&#xff0c; 于是&#xff0c;我写一个简单的教程&#xff0c;能够实现简单小车的电磁循迹。 通过这个教程&#xff0c;能够通过简化的步骤搭建寻迹小车&#xff0c;进而了解整个智能车是如何实…...

【C++】vector的介绍与使用

&#x1f9d1;‍&#x1f393;个人主页&#xff1a;简 料 &#x1f3c6;所属专栏&#xff1a;C &#x1f3c6;个人社区&#xff1a;越努力越幸运社区 &#x1f3c6;简 介&#xff1a;简料简料&#xff0c;简单有料~在校大学生一枚&#xff0c;专注C/C/GO的干货分…...

【libGDX】使用Mesh绘制圆形

1 前言 使用Mesh绘制三角形 中介绍了绘制三角形的方法&#xff0c;使用Mesh绘制矩形 中介绍了绘制矩形的方法&#xff0c;本文将介绍绘制圆形的方法。 libGDX 以点、线段、三角形为图元&#xff0c;没有提供绘制圆形的接口。要绘制圆形边框&#xff0c;必须通过割圆法逼近圆形&…...

一个测试驱动的Spring Boot应用程序开发

文章目录 系统任务用户故事搭建开发环境Web应用的框架Spring Boot 自动配置三层架构领域建模域定义与领域驱动设计领域类 业务逻辑功能随机的Challenge验证 表示层RESTSpring Boot和REST API设计API第一个控制器序列化的工作方式使用Spring Boot测试控制器 小结 这里采用面向需…...

简单几步,借助Aapose.Cells将 Excel XLS 转换为PPT

数据呈现是商业和学术工作的一个重要方面。通常&#xff0c;您需要将数据从一种格式转换为另一种格式&#xff0c;以创建信息丰富且具有视觉吸引力的演示文稿。当您需要在幻灯片上呈现工作表数据时&#xff0c;需要从 Excel XLS 转换为 PowerPoint 演示文稿。在这篇博文中&…...

CSS特效016:天窗扬起合上的效果

CSS常用示例100专栏目录 本专栏记录的是经常使用的CSS示例与技巧&#xff0c;主要包含CSS布局&#xff0c;CSS特效&#xff0c;CSS花边信息三部分内容。其中CSS布局主要是列出一些常用的CSS布局信息点&#xff0c;CSS特效主要是一些动画示例&#xff0c;CSS花边是描述了一些CSS…...

基于SSM的济南旅游网站设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…...

【ArrayList是如何扩容(ArrayList、LinkedList、与Vector的区别)】

ArrayList、LinkedList、与Vector的区别 解读ArrayList 是一个可改变大小的数组LinkedList 是一个双向链表Vector 属强同步类 拓展知识面ArrayList是如何扩容&#xff1f;如何利用List实现LRU&#xff1f; 解读 List主要有ArrayList、LinkedList与Vector几种实现。这三者都实现…...

STM32_3(GPIO)

GPIO简介 GPIO&#xff08;General Purpose Input Output&#xff09;通用输入输出口8种输入输出模式输出模式可控制端口输出高电平&#xff0c;驱动LED、蜂鸣器、模拟通信协议输出时许等输入模式可读取端口的高低电平或电压&#xff0c;用于读取按键输入、外接模块电平信号输…...

【技巧】PDF文件如何编辑?

日常办公中我们经常会用到PDF文件&#xff0c;PDF具备很好的兼容性、稳定性及安全性&#xff0c;但却不容易编辑&#xff0c;那PDF要如何编辑呢&#xff1f; 如果打开PDF文件就只是只读的性质&#xff0c;说明文件是在线打开&#xff0c;或者通过PDF阅读器打开的&#xff0c;这…...

AR道具特效制作工具

AR&#xff08;增强现实&#xff09;技术已经逐渐渗透到各个行业&#xff0c;为企业带来了全新的营销方式和用户体验。在这个背景下&#xff0c;美摄科技凭借其强大的技术实力和创新精神&#xff0c;推出了一款专为企业打造的美摄AR特效制作工具&#xff0c;旨在帮助企业轻松实…...

鸿蒙4.0开发笔记之DevEco Studio页面操作router的pushUrl页面跳转与back返回上一页(五)

一、认识组件 关于HarmonyOS中ArkTS的基础组件请参见文章鸿蒙4.0开发笔记之ArkTs语言基础与基本组件结构&#xff08;四&#xff09; 二、实现页面跳转pushUrl 1、操作说明 实现页面跳转的核心便是router.pushUrl的调用&#xff0c;操作起来也很简单&#xff0c;总共就四步…...

20个CSS函数-释放设计创造力和响应能力

20个CSS函数-释放设计创造力和响应能力 CSS是网页设计的核心&#xff0c;使开发者和设计者能够制作出令人叹为观止和反应迅速的网页布局。CSS函数通过引入动态性和多功能性提升了我们的设计能力。在本文中&#xff0c;我们将开始讲解20个CSS函数。 1.rgba()&#xff1a;定义颜…...

Dubbo从入门到上天系列第十八篇:Dubbo引入注册中心简介以及DubboAdmin简要介绍,为后续详解Dubbo各种注册中心做铺垫!

一&#xff1a;Dubbo注册中心引言 1&#xff1a;什么是Dubbo的注册中心&#xff1f; Dubbo注册中心是Dubbo服务治理中极其重要的一个概念。它主要是用于对Rpc集群应用实例进行管理。 对于我们的Dubbo服务来讲&#xff0c;至少有两部分构成&#xff0c;一部分是Provider一部分是…...

CentOS8安装MySQL

选择MySQL数据库的原因&#xff1a; 1、运行速度快&#xff1b; 2、开源免费&#xff1b; 3、易学易用&#xff1b; 4、可移植性&#xff0c;能够在众多不同的系统上工作&#xff1b; 5、丰富的接口&#xff0c;提供了用于C、C等语言的API&#xff1b; 6、支持查询语言&#xf…...

Java集合拓展01

1、List&#xff0c;Set&#xff0c;Map三者的区别 List&#xff1a;一个有序&#xff08;元素存入集合的顺序和取出的顺序一致&#xff09;容器&#xff0c;元素可以重复&#xff0c;可以插入多个null元素&#xff0c;元素都有索引。常用的实现类有 ArrayList、LinkedList 和…...

Admin.Net中的消息通信SignalR解释

定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...

Debian系统简介

目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版&#xff…...

Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)

概述 在 Swift 开发语言中&#xff0c;各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过&#xff0c;在涉及到多个子类派生于基类进行多态模拟的场景下&#xff0c;…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:

根据万维钢精英日课6的内容&#xff0c;使用AI&#xff08;2025&#xff09;可以参考以下方法&#xff1a; 四个洞见 模型已经比人聪明&#xff1a;以ChatGPT o3为代表的AI非常强大&#xff0c;能运用高级理论解释道理、引用最新学术论文&#xff0c;生成对顶尖科学家都有用的…...

AspectJ 在 Android 中的完整使用指南

一、环境配置&#xff08;Gradle 7.0 适配&#xff09; 1. 项目级 build.gradle // 注意&#xff1a;沪江插件已停更&#xff0c;推荐官方兼容方案 buildscript {dependencies {classpath org.aspectj:aspectjtools:1.9.9.1 // AspectJ 工具} } 2. 模块级 build.gradle plu…...

ABAP设计模式之---“简单设计原则(Simple Design)”

“Simple Design”&#xff08;简单设计&#xff09;是软件开发中的一个重要理念&#xff0c;倡导以最简单的方式实现软件功能&#xff0c;以确保代码清晰易懂、易维护&#xff0c;并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计&#xff0c;遵循“让事情保…...

Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信

文章目录 Linux C语言网络编程详细入门教程&#xff1a;如何一步步实现TCP服务端与客户端通信前言一、网络通信基础概念二、服务端与客户端的完整流程图解三、每一步的详细讲解和代码示例1. 创建Socket&#xff08;服务端和客户端都要&#xff09;2. 绑定本地地址和端口&#x…...

20个超级好用的 CSS 动画库

分享 20 个最佳 CSS 动画库。 它们中的大多数将生成纯 CSS 代码&#xff0c;而不需要任何外部库。 1.Animate.css 一个开箱即用型的跨浏览器动画库&#xff0c;可供你在项目中使用。 2.Magic Animations CSS3 一组简单的动画&#xff0c;可以包含在你的网页或应用项目中。 3.An…...

Webpack性能优化:构建速度与体积优化策略

一、构建速度优化 1、​​升级Webpack和Node.js​​ ​​优化效果​​&#xff1a;Webpack 4比Webpack 3构建时间降低60%-98%。​​原因​​&#xff1a; V8引擎优化&#xff08;for of替代forEach、Map/Set替代Object&#xff09;。默认使用更快的md4哈希算法。AST直接从Loa…...