d-note 项目安装与部署指南
2025-07-10 18:16:45作者:袁立春Spencer
项目概述
d-note 是一个基于 Python Flask 框架开发的轻量级 Web 应用程序,主要用于安全笔记管理。本文将详细介绍如何在 Linux 系统上安装和部署 d-note 项目,包括 Apache 和 Nginx 两种主流 Web 服务器的配置方案。
环境准备
系统要求
- Debian/Ubuntu 系统(其他 Linux 发行版可参考类似步骤)
- Python 运行环境
- Web 服务器(Apache 或 Nginx)
依赖安装
首先需要安装必要的 Python 依赖包:
sudo apt-get install python-flask python-crypto
注意:python-crypto 包应确保来自官方源,这是加密功能正常运行的关键依赖。
项目配置
初始化安装
执行以下命令完成基础安装:
python setup.py install
此命令会创建必要的配置文件和数据存储目录。
配置文件设置
- 编辑项目目录中的
dnote.ini文件 - 修改
[default]部分下的config_path值- 推荐路径:
/etc/dnote或~/.dnote
- 推荐路径:
- 将修改后的
dnote.ini复制到指定目录
生成安全哈希
运行以下命令生成安全配置:
generate_dnote_hashes
此命令会在配置目录中创建 dconfig.py 文件,其中包含随机生成的十六进制字符串作为加密盐值,这是保证数据安全的重要步骤。
Apache 部署方案
安装必要组件
sudo apt-get install libapache2-mod-wsgi
创建 WSGI 入口文件
在 Web 根目录创建 /var/www/dnote.wsgi 文件,内容如下:
#!/usr/bin/python
import sys
import logging
logging.basicConfig(stream=sys.stderr)
from dnote import DNOTE as application
Apache 站点配置
创建 /etc/apache2/site-available/ 配置文件,以下是关键配置示例(强烈建议使用 SSL):
<Virtualhost *:443>
DocumentRoot /var/www/
ServerName www.example.com
WSGIScriptAlias / /var/www/dnote.wsgi
<Directory /var/www/>
Options -Indexes FollowSymLinks
</Directory>
Alias /d/static /var/www/dnote/static
<Directory /var/www/dnote/static/>
Order allow,deny
Allow from all
</Directory>
SSLEngine on
SSLCertificateFile /etc/ssl/certs/www_example_com.crt
SSLCertificateKeyFile /etc/ssl/private/www_example_com.key
SSLHonorCipherOrder On
</VirtualHost>
重启 Apache 服务
sudo service apache2 restart
Nginx 部署方案
安装 uWSGI
sudo apt-get install uwsgi uwsgi-core uwsgi-extra uwsgi-plugin-python
创建 uWSGI 配置文件
在应用目录创建 /var/www/dnote/uwsgi.ini:
[uwsgi]
socket = 127.0.0.1:8081
chdir = /python/path/site-packages/dnote-1.0.1-py2.7.egg/dnote
plugin = python
module = __init__:dnote
processes = 4
threads = 2
stats = 127.0.0.1:9192
uid = www-data
gid = www-data
logto = /var/log/dnote.log
启动 uWSGI
前台运行:
/usr/bin/uwsgi -c /var/www/dnote/uwsgi.ini
后台运行:
/usr/bin/uwsgi -d -c /var/www/dnote/uwsgi.ini
Nginx 配置
在站点配置中添加以下内容(示例为将应用部署在 /dnote 路径下):
location = /dnote { rewrite ^ /dnote/; }
location /dnote/ { try_files $uri @dnote; }
location @dnote {
include uwsgi_params;
uwsgi_param SCRIPT_NAME /dnote;
uwsgi_modifier1 30;
uwsgi_pass 127.0.0.1:8081;
}
重启 Nginx
sudo service nginx restart
常见问题排查
-
内部服务错误
- 检查
/var/www/dnote/dnote目录是否对 Web 服务器可读 - 确保
/var/www/dnote/dnote/data/hashcash.db文件可写
- 检查
-
uWSGI 启动问题
- 可尝试使用 WSGI 文件方式启动,修改
uwsgi.ini:替代原来的wsgi-file = /var/www/dnote.wsgimodule配置
- 可尝试使用 WSGI 文件方式启动,修改
-
权限问题
- 确保所有相关文件和目录的所有权和权限设置正确
- 特别是当使用不同用户运行 Web 服务器和 uWSGI 时
安全建议
- 始终使用 HTTPS 加密连接
- 定期备份
hashcash.db文件 - 限制对管理接口的访问
- 保持系统和依赖包的最新状态
通过以上步骤,您应该能够成功部署 d-note 项目。根据实际环境需求,可能需要对配置进行适当调整。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
CAP基于最终一致性的微服务分布式事务解决方案,也是一种采用 Outbox 模式的事件总线。C#00
热门内容推荐
最新内容推荐
3种实用方案解决软件试用期管理难题SMUDebugTool:重新定义AMD Ryzen硬件调试的开源解决方案企业级视频本地化:技术架构与商业落地指南4个效率优化维度:Kronos金融大模型资源配置与训练实战指南3步打造高效键盘效率工具:MyKeymap个性化配置指南RapidOCR:企业级本地化OCR工具的技术解析与应用实践开源小说下载工具:实现网络小说本地存储的完整方案Detect-It-Easy技术教程:精准识别PyInstaller打包文件的核心方法GDevelop零代码游戏开发:3大痛点解决方案与实战案例高效解决知识星球内容备份难题:完全掌握zsxq-spider从爬取到PDF的知识管理方案
项目优选
收起
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
650
4.23 K
deepin linux kernel
C
27
14
Ascend Extension for PyTorch
Python
487
596
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
390
279
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.53 K
886
Oohos_react_native
React Native鸿蒙化仓库
JavaScript
332
387
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
937
851
暂无简介
Dart
899
215
昇腾LLM分布式训练框架
Python
141
167
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
123
194