惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
V
Vulnerabilities – Threatpost
有赞技术团队
有赞技术团队
小众软件
小众软件
O
OpenAI News
C
Cyber Attacks, Cyber Crime and Cyber Security
I
Intezer
NISL@THU
NISL@THU
D
Darknet – Hacking Tools, Hacker News & Cyber Security
N
News and Events Feed by Topic
MongoDB | Blog
MongoDB | Blog
阮一峰的网络日志
阮一峰的网络日志
Hacker News: Ask HN
Hacker News: Ask HN
D
Docker
WordPress大学
WordPress大学
Security Archives - TechRepublic
Security Archives - TechRepublic
A
About on SuperTechFans
Stack Overflow Blog
Stack Overflow Blog
C
CERT Recently Published Vulnerability Notes
L
LINUX DO - 最新话题
Application and Cybersecurity Blog
Application and Cybersecurity Blog
M
MIT News - Artificial intelligence
Blog — PlanetScale
Blog — PlanetScale
S
Security @ Cisco Blogs
Cloudbric
Cloudbric
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
V
V2EX
Hacker News - Newest:
Hacker News - Newest: "LLM"
G
Google Developers Blog
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
W
WeLiveSecurity
Google DeepMind News
Google DeepMind News
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
H
Hackread – Cybersecurity News, Data Breaches, AI and More
G
GRAHAM CLULEY
S
Schneier on Security
T
Tor Project blog
Spread Privacy
Spread Privacy
PCI Perspectives
PCI Perspectives
Microsoft Security Blog
Microsoft Security Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
F
Fortinet All Blogs
L
Lohrmann on Cybersecurity
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
T
The Exploit Database - CXSecurity.com
TaoSecurity Blog
TaoSecurity Blog
Apple Machine Learning Research
Apple Machine Learning Research
T
Threat Research - Cisco Blogs
T
Troy Hunt's Blog
罗磊的独立博客

少数派

派早报:Google 发布 Fitbit Air 等 - 少数派 「新人报到」確認需求,再開始 - 少数派 从 SOLO 独立开发者社区,我看到了越来越多开发者开始做自己的产品 - 少数派 我怎么管理那些"不常做,但总会忘"的生活事项 - 少数派 人形机器人量产元年,数据才是具身智能的“生死线” - 少数派 BuhoLaunchpad 高度还原 Mac 启动台:开发历程与思考 - 少数派 五年陪伴依然不舍,DIY 换壳后让罗技 MX Master 3 继续服役 - 少数派 新玩意 240|少数派的编辑们最近买了啥? - 少数派 一日一技|为什么你应该关闭 iOS 的键盘声音 - 少数派 我做了个插件和 Skills,一键提取任何网站的设计规范 Design.md - 少数派 住在三四线城市的你,该开始录播客了 - 少数派 甘南秘境,大白高国 - 少数派 AI的审美:谁让把我变成川内倫子 - 少数派 返工怎能不烦恼,打工人片单总有一部是你的「嘴替」 - 少数派 为了让「上厕所」更健康,我做了一个小工具 - 少数派 AI + Skill,能够让生成的文章去除 AI 味吗? - 少数派 新玩意|韶音OpenDots ONE 耳夹式耳机 - 少数派 《美满》| 在每一个春天的晚上相爱(362) - 少数派 新玩意|优篮子 PS01 MagSnap 磁吸支架 - 少数派 自我整合手记 | 我开始早睡了:用稳定规则,为自由托底 - 少数派 用龙虾(OpenClaw)两个多月,我最深的12个体会 - 少数派 听歌时间到,12 张你可能错过的 2025 华语乐坛好专辑 - 少数派 承诺能追吗 - 少数派 macOS 26启动台没了? 我做了个不一样的App启动器 - Keboard - 少数派 《四海为家的人》| INTJ对话INTJ(361) - 少数派 你发过的那些黑历史,是时候一次清干净了 - 少数派 新玩意:安安静静玩,越玩越专注:计客密码机 - 少数派 iPad 用户首次体验 Android 平板:vivo Pad6 Pro - 少数派 数据逻辑强 - 少数派 极北行+ | 一路向北,探访日本至北之地 | 001 - 少数派 万字剖析:千问App深度体验报告(2026) - 少数派 在2026年,如何真正防止别人抄袭你的作品 - 少数派 怎么用 50 块搭个 AI 语音助手?我踩了 3 天坑 - 少数派 YeeroAI:让 AI 对话真正成为知识管理的一部分 - 少数派 爬泰山 - 少数派 「旅图显影」 App 更新:这次,我们补上了一点「手感」 - 少数派 假期出门太折磨?我的 23 条经验帮你规划惬意旅行 - 少数派 工作流会变吗 - 少数派 Claude Opus 4.6 怎么用最省钱?我测了 5 种方案 - 少数派 GPT Image 2 让图文并茂不再稀罕 - 少数派 用户侧出发——什么是AI,我要不要学习? - 少数派 找片、转存、整理、播放一条龙!让你的付费网盘值回票价 - 少数派 欢迎试用!日课一问2.0插件 - 少数派 自己做的MDeditor,原本想购买 Typora 试了两次支付不成功,干脆自己做一个 - 少数派 vibe coding了一个 3MB 的小工具,让 ~/Downloads 彻底告别混乱 - 少数派 因为受不了 Mac 的风扇策略,我做了一个风扇控制工具 - 少数派 别只怪模型 - 少数派 Warp 终端的 AI 功能怎么用?我测了一周的体验 - 少数派 AI 写代码老是出 bug?这 5 个配置我后悔没早知道 - 少数派 「新玩意」苹果出相机可能就这样:Sigma BF + 45mm F2.8 DG Contemporary - 少数派 一个面向2030年的AI操作系统是什么样子的:浅谈cola这款有灵魂的Agent - 少数派 别只看写代码 - 少数派 每天解决10个问题,还是一口气攻坚解决400个? - 少数派 AI 交易机器人怎么搭?我用 Claude 跑了一周实盘 - 少数派 Maptoposter Online:把你爱的城市画成艺术海报 - 少数派 Function Calling 怎么用?我测了 3 个模型发现差距真大 - 少数派 Legend Talk:我做了个 AI 圆桌,让 160 位思想家围着你的问题转 - 少数派 如何找到自己的蓝方?在小县城寻找压力测试 - 少数派 语音输入与软件接口|2026年聊AI时,我们都聊些什么(上) - 少数派 混动已经卖爆,纯电又来补刀——钛7闪充版简直“不讲武德” - 少数派 本月玩什么|朋友收藏、识质存在、沙罗周期 - 少数派 为什么要每天坚持输出? - 少数派 Claude API 挂了好几个小时,你的项目有备用方案吗? - 少数派 Function Calling 没你想的复杂——我用它做了个有点用的工具 - 少数派 登录系统立即播放视频或者图片音乐的软件 - 少数派 我为什么创建 FlipHTML5 下载工具 - 少数派 残局没电?多品牌外设电量统一管理软件EasyBluetooth已支持RTSS游戏内显示以及AIDA64 - 少数派 前往通义路的路 - 少数派 太好看了,媲美Sun的个人导航页,NAS部署星云门户 - 少数派 乌黑嘴唇“一键检测”上线了 - 少数派 派早报:Claude AI 接入多个创意软件生态、FILCO 生产方接手品牌等 - 少数派 【更新】BearCLI、Claude 连接器与 MCP 服务器 - 少数派 记了上千条流水,还是看不懂财务?我做了一个让 AI 读懂账本的工作台 - 少数派 MINI R56 升级原厂 Sport 模式 - 少数派 新玩意 | 一棵柠檬树(仿真版) - 少数派 Momenta的“物理AI”野望,需迈过“含摩量”这道关 - 少数派 网页直接投屏控制手机!NAS一键部署PandaScrcpy,流畅丝滑可远程。 - 少数派 众测|邀你一同探索随身 AI 硬件入口 YoooClaw C·ONE - 少数派 2050大会:分享时间是真诚 参会记 - 少数派 iPad 赋能电影创作:国内首部宣纸手绘长片《燃比娃》的幕后故事 - 少数派 AI的审美:我用 8 个大模型给 100 张旅行照片打分 - 少数派 普通人如何破圈?去参加一个本地协会 - 少数派 把极空间的图标全换了,主题DIY全攻略打造你的专属NAS桌面 - 少数派 电子便签墙,帮你实现便签自由 - 少数派 我如何用三个 CLI 工具取代文档创建需求 - 少数派 原来真的有人可以玩一辈子 - 少数派 社区速递 139 | 派友热议三月买了啥、复古单反尼康 Df 体验 - 少数派 06 作品的赏析与评价 - 少数派 TDS REVIEW|索尼 WF-1000XM6 降噪真无线耳机体验 - 少数派 35.98万起售的第二代腾势D9,我看重的不是堆料,而是不凑合 - 少数派 鼠须管 Squirrel 皮肤配置指北 - 少数派 从watch ultra2换到redmi watch6 - 少数派 派早报:阿里巴巴发布视频生成模型 HappyHorse 1.0 等 - 少数派 别迷信1M - 少数派 家人们天塌了!网盘“大封杀”,多个渠道多条路,NAS部署PanHub - 少数派 AI与人勾心斗角!NAS一键部署AI狼人杀,假日休闲必备。 - 少数派 电商必备!Comfyui工作流批量生图插件,一次生成12张!支持Nano banana pro模型 - 少数派 Comfyui工作流配置Gpt-image-2模型教程,0.03/张 - 少数派 OpenClaw第三方APi怎么配置?可使用Gpt-image-2模型 - 少数派 会员社区话题精选 Ep. 103 - 少数派
使用Memos来搭建私人朋友圈说说 - 少数派
2024-09-27 · via 少数派

前言

Memos 是一种隐私优先的轻量级笔记解决方案,可让您轻松捕捉和分享您的想法。它开源且免费支持自部署。生态上支持第三方的手机端APP、浏览器插件等方式记录笔记,优势是生态够强,缺点是开发者每次更新大版本后之前的API可能就直接废弃了。

我们先来了解下生态及项目

Memos 的官方文档:https://www.usememos.com/docs

开源地址:https://github.com/usememos/memos

静态带广场等模式:https://github.com/lmm214/memobbs

Memos API 渲染的静态网页:https://github.com/eallion/memos.top

基于 Bun + Hono + MongoDB 构建的页面:https://github.com/jakholuo/quest

第三方浏览器扩展:https://chromewebstore.google.com/detail/cbhjebjfccgchgbmfbobjmebjjckgofe

魔改版Memos:https://github.com/Vespa314/cflow

memos独立桌面及手机APP程序:https://memos.moe

TG机器人集成发布到memos:https://github.com/usememos/telegram-integration

1727431946267

1727431946267

我们将借助Memos API 渲染静态网页并优化页面来实现私人说说的构建,还可以添加自动化等实现推送及备份到其它程序

我喜欢这个项目的样式https://github.com/eallion/memos.top 就拿来用了,其它也有,不过样式上个人不太喜欢

如果你只想使用该项目的,请到项目仓库中自行查看如何部署

预览我的:https://www.noisework.cn/e/talk/

特征

可自定义顶部随机背景图,点击头像可进行切换

增加了友链、关于、留言的翻页页面

(目前的bug:无法点击标签后进行筛选)

你也可以直接使用我搭建的memos,但服务器容量有限,不支持上传过大的图片及文件,请尽量使用md格式的图床

预览1

2312312

预览2

206shots_so

搭建步骤

先部署Meomes(推荐docker快速部署),如果你已经有自己的Meomes或者在使用官方demo或使用他人的实例可以跳过memos的部署,【直接查看修改静态文】部署后拿到自己的服务端地址及用户名和密码等必要变量坐几路车,然后在静态页的文件中添加修改,最后放入你的服务运行即可,运行成功后可再进行自动化等操作的调试

Docker 运行Meomes

要使用 设置 Memos,请执行以下一个命令来启动 Memos:docker run

docker
 run 
-d
 
\


  
--init
 
\


  
--name
 memos 
\


  
--publish
 
5230
:5230 
\


  
--volume
 ~/.memos/:/var/opt/memos 
\


  neosmemo/memos:stable

此命令将在后台启动 Memos,并在端口 5230 上公开它。数据将存储在 ~/.memos/ 中,这是用户主目录中的一个隐藏目录。如果你使用宝塔面板会在/root/.memos文件夹中找到存放的数据库文件

⚠️

如果你想使用Mysql部署可查看官方文档:https://www.usememos.com/docs/install/database

但目前来说,官方的容器并不支持外部mysql的连接,需要docker版mysql的运行和保持连接

改善:通过拉取官方仓库自己构建容器,并设置docker-compose.yml

version
:
 
'3.8'




services
:


  
memos
:


    
build
:


      
context
:
 
.


      
dockerfile
:
 
Dockerfile


    
ports
:


      
-
 
"5250:5230"


    
environment
:


      
MYSQL_HOST
:
 
"外部数据库IP或域名"
  # 替换为你的 
MySQL
 地址

      
MYSQL_PORT
:
 
"3306"


      
MYSQL_USER
:
 
"你的用户名"
           # 替换为你的 
MySQL
 用户名

      
MYSQL_PASSWORD
:
 
"你的密码"
         # 替换为你的 
MySQL
 密码

      
MYSQL_DB
:
 
"你的数据库名"
           # 替换为你的数据库名

      
MEMOS_MODE
:
 
"prod"


      
MEMOS_PORT
:
 
"5230"


      
MEMOS_DRIVER
:
 
"mysql"
              # 指定使用 
MySQL
 驱动

    
volumes
:
                             # 如果你不需要本地数据库的挂载可以删除此行及以下

      
-
 memos_data
:
/
var
/
opt
/
memos



volumes
:


  
memos_data
:


    
driver
:
 local


Sp数据库导入Mysql数据库

如果你想将本地数据库备份到Mysql,可以使用python来完成

本地新建main.py文件

import
 sqlite3

import
 mysql
.
connector




# 
SQLite
 数据库连接信息

sqlite_db_path 
=
 
'memos_prod.db'
  # 修改为你的 
SQLite
 文件路径

sqlite_conn 
=
 sqlite3
.
connect
(
sqlite_db_path
)


sqlite_cursor 
=
 sqlite_conn
.
cursor
(
)




# 
MySQL
 数据库连接信息

mysql_conn 
=
 mysql
.
connector
.
connect
(


    host
=
'127.0.0.1'
,
   # 修改为你自己的服务端地址

    port
=
3306
,
  # 
MySQL
 默认端口是整数类型,不能加引号

    user
=
'test'
,
   #数据库用户名

    password
=
'123456'
,
   #数据库密码

    database
=
'test'
      #数据库名

)


mysql_cursor 
=
 mysql_conn
.
cursor
(
)




# 获取 
SQLite
 数据库中的所有表名

sqlite_cursor
.
execute
(
"SELECT name FROM sqlite_master WHERE type='table';"
)


tables 
=
 sqlite_cursor
.
fetchall
(
)




# 遍历 
SQLite
 中的每个表

for
 table 
in
 
tables
:


    table_name 
=
 table
[
0
]


    

    # 获取表结构

    sqlite_cursor
.
execute
(
f
"PRAGMA table_info({table_name});"
)


    columns 
=
 sqlite_cursor
.
fetchall
(
)




    # 构建 
MySQL
 创建表的 
SQL
 语句

    create_table_sql 
=
 f
'CREATE TABLE IF NOT EXISTS `{table_name}` ('


    
for
 column 
in
 
columns
:


        column_name 
=
 column
[
1
]


        column_type 
=
 column
[
2
]
.
upper
(
)
  # 
SQLite
 类型与 
MySQL
 类型的映射



        # 简单的类型映射,可以根据需要扩展

        
if
 column_type 
==
 
"TEXT"
:


            column_type 
=
 
"VARCHAR(255)"


        elif column_type 
==
 
"INTEGER"
:


            column_type 
=
 
"INT"


        elif column_type 
==
 
"REAL"
:


            column_type 
=
 
"DOUBLE"


        elif column_type 
==
 
"BLOB"
:


            column_type 
=
 
"BLOB"


        

        create_table_sql 
+=
 f
'`{column_name}` {column_type}, '


    

    create_table_sql 
=
 create_table_sql
.
rstrip
(
", "
)
 
+
 
");"


    

    # 执行创建表的 
SQL
 语句

    
try
:


        
print
(
f
"正在创建表: {table_name}"
)


        mysql_cursor
.
execute
(
create_table_sql
)


    except mysql
.
connector
.
Error
 
as
 
e
:


        
print
(
f
"创建表 {table_name} 时发生错误: {e}"
)


        
continue




    # 将数据导入 
MySQL
 表

    sqlite_cursor
.
execute
(
f
'SELECT * FROM "{table_name}";'
)


    rows 
=
 sqlite_cursor
.
fetchall
(
)


    

    # 打印行数进行调试

    
print
(
f
"表 {table_name} 包含 {len(rows)} 行数据."
)


    

    
for
 row 
in
 
rows
:


        # 处理空值(None)转为 
MySQL
 兼容的 
NULL


        row 
=
 
[
None
 
if
 value is 
None
 
else
 value 
for
 value 
in
 row
]


        placeholders 
=
 
', '
.
join
(
[
'%s'
]
 
*
 
len
(
row
)
)


        insert_sql 
=
 f
'INSERT INTO `{table_name}` VALUES ({placeholders});'


        

        
try
:


            
print
(
f
"正在插入数据到 {table_name}: {row}"
)


            mysql_cursor
.
execute
(
insert_sql
,
 row
)
  # 使用参数化查询

        except mysql
.
connector
.
Error
 
as
 
e
:


            
print
(
f
"插入数据到 {table_name} 时发生错误: {e}"
)


            
continue




    # 每次插入表数据后提交事务

    mysql_conn
.
commit
(
)




# 提交所有事务并关闭连接

mysql_conn
.
commit
(
)


sqlite_conn
.
close
(
)


mysql_conn
.
close
(
)




print
(
"SQLite 数据库已成功导入到 MySQL。"
)



新建requirements.txt

mysql
-
connector
-
python

安装依赖

pip install -r requirements.txt

最后运行python3 main.py即可

3343434t

3343434t

修改静态文件

使用我的静态文件可以在我的个人主页开源仓库中找到,位置在/e/talk/文件夹中

或者你也可以直接下载:https://pan.quark.cn/s/f6a4049fe509

主要有几处需要修改,在index.html中修改你部署的memos服务端地址及waline评论服务端地址

<
script type
=
"text/javascript"
>


        
var
 memos 
=
 
{


            
host
:
 
'https://demo.usememos.com/'
,
 
//修改为你自己的memos服务地址,结尾要有/


            
limit
:
 
'10'
,
 
//每页显示数量


            
creatorId
:
 
'1'
,


            
domId
:
 
'#memos'
,


            
username
:
 
'noise'
,


            
name
:
 
'诺伊斯'
,


            
language
:
 
'zh-CN'
,


            
APIVersion
:
 
'new'
,


            
total
:
 
true
,


        
}


    
<
/
script
>




    
<
script type
=
"module"
>


        
import
 
{
 init 
}
 
from
 
'https://unpkg.com/@waline/client@v3/dist/waline.js'
;


        
init
(
{


            
el
:
 
'#waline'
,


            
serverURL
:
 
'https://ment.noisework.cn'
,
 
//修改为你自己的waline服务端地址


            
meta
:
 
[
'nick'
,
 
'mail'
,
 
'link'
]
,


            
requiredMeta
:
 
[
'mail'
,
 
'nick'
]
,


            
pageview
:
 
true
,


            
search
:
 
false
,


            
wordLimit
:
 
200
,


            
pageSize
:
 
5
,


            
avatar
:
 
'monsterid'
,


            
emoji
:
 
[


                
'https://unpkg.com/@waline/emojis@1.2.0/tieba'
,


            
]
,


            
imageUploader
:
 
false
,


            
copyright
:
 
false
,


        
}
)
;


    
<
/
script
>

评论区配置修改请查看官方指南:https://waline.js.org

在js文件夹中找到main.js修改评论初始化,278行左右

// 初始化 Waline 评论框


function
 
initWaline
(
container
,
 host
)
 
{


    
const
 commentId 
=
 
`
waline-
${
host
}
`
;
 
// 使用 host 生成唯一 ID


    container
.
innerHTML
 
=
 
`
<
div
 
id
=
"
${
commentId
}
"
>
</
div
>
`
;


    
import
(
'https://unpkg.com/@waline/client@v3/dist/waline.js'
)
.
then
(
(
{
 init 
}
)
 
=>
 
{


        
const
 uid 
=
 host
.
split
(
'-'
)
.
pop
(
)
;
 
// 从 host 中提取 uid


        
init
(
{


            
el
:
 
`
#
${
commentId
}
`
,
 
// 使用生成的唯一 ID


            
serverURL
:
 
'https://ment.noisework.cn'
,
 
//修改为你自己的地址


            
meta
:
 
[
'nick'
,
 
'mail'
,
 
'link'
]
,


            
requiredMeta
:
 
[
'mail'
,
 
'nick'
]
,


            
pageview
:
 
true
,


            
search
:
 
false
,


            
wordLimit
:
 
200
,


            
pageSize
:
 
5
,


            
avatar
:
 
'monsterid'
,


            
emoji
:
 
[


                
'https://unpkg.com/@waline/emojis@1.2.0/tieba'
,


            
]
,


            
imageUploader
:
 
false
,


            
copyright
:
 
false
,


            
// 使用 path 参数来确保评论区的唯一性


            
path
:
 
`
/m/
${
uid
}
`
,
 
// 指向实际链接


        
}
)
;


    
}
)
;


}

然后再根据自己需要调整html文件的名称头像等

配置自动化

1727426128257

1727426128257

我们使用https://cloud.activepieces.com 来配置自动化

新建一个以webhook为开始的工作流

记录该test的url并在memos中新建一个webhook填入该地址

1727431043530

在手机端或网页端发布信息进行测试该地址

如果显示推送成功后就在memos中将webhook-test测试url更换为正式的live url地址

新建创造新数据的Notion工作流

授权notion页面并选择数据库信息,字段可自定义

你可以参考我的说说https://ppnoise.notion.site/5facadd932ea418b86be5e658e98d9e8?v=98c9cc3d3ebe453db25443796abc7e93&pvs=4

然后将发布的信息按这些字段进行填入

测试运行,这样就能自动备份信息到NOTION中了,其它同理

推送其它

新建一个IF判断工作流,内容为判断文本数据中是否包括#字符

如果包含,你可以再设置一个post发送(比如推送到微信群等)

总结

至此,你就完成了从部署memos到发布到自动化推送备份的步骤,但还需要完善及优化

这需要看你个人的需求,期待你的个人优化修改,也欢迎随时来我的主页www.noisework.cn 来讨论