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

【Docker项目实战】使用Docker部署Notepad轻量级记事本

【Docker项目实战】使用Docker部署Notepad轻量级记事本

  • 一、 Notepad介绍
    • 1.1 Notepad简介
    • 1.2 Notepad特点
    • 1.3 主要使用场景
  • 二、本次实践规划
    • 2.1 本地环境规划
    • 2.2 本次实践介绍
  • 三、本地环境检查
    • 3.1 检查Docker服务状态
    • 3.2 检查Docker版本
    • 3.3 检查docker compose 版本
  • 四、下载Notepad镜像
  • 五、部署Notepad应用
    • 5.1 创建部署目录
    • 5.2 编辑部署文件
    • 5.3 创建Notepad容器
    • 5.4 查看Notepad容器状态
    • 5.5 查看Notepad容器日志
  • 六、访问Notepad服务
    • 6.1 访问Notepad主页
    • 6.2 设置访问密码
    • 6.3 编辑笔记内容
  • 七、总结

一、 Notepad介绍

1.1 Notepad简介

Notepad:这是一个基于网络的轻量级记事本应用,专为需要在线书写和安全存储笔记的用户设计。它提供了一个简洁、易用的界面,让用户能够随时随地记录想法、任务列表或重要信息。通过使用现代加密技术,确保所有数据的安全性,使用户能够安心地保存私密内容。

1.2 Notepad特点

  • 无需注册: 用户只需设置一个密码即可开始使用服务,简化了初次使用的流程。
  • 端到端加密: 所有笔记从客户端到服务器全程采用高级别加密处理,保证只有拥有正确密码的人才能访问这些信息。
  • 跨平台兼容: 支持多种设备访问,包括但不限于PC、平板电脑以及智能手机等,让信息同步变得简单快捷。
  • 实时协作: 允许多人同时编辑同一份文档,并能看到彼此所做的更改,非常适合团队合作。
  • 极简主义设计: 界面清晰直观,没有过多复杂的选项干扰用户的创作过程。
  • 自动保存功能: 防止因意外关闭浏览器而丢失未保存的工作。
  • 搜索与标签系统: 便于管理和查找特定笔记,提高效率。
  • 导出选项: 支持将笔记导出为PDF或其他格式文件,方便离线查看或分享给不使用该服务的人士。

1.3 主要使用场景

  1. 个人日记/日志: 对于喜欢记录日常生活点滴的人来说,这是一个理想的工具。
  2. 项目管理: 团队成员可以利用其实时协作特性来共同维护项目进度表或讨论文档。
  3. 学习笔记: 学生们可以用它来整理课堂笔记,复习资料,甚至创建自己的知识库。
  4. 旅行规划: 记录旅行中的所见所闻或是制定行程安排的好帮手。
  5. 创意灵感收集: 对艺术家、作家而言,随时捕捉脑海里闪现的想法非常重要,这个应用程序正好满足了这方面的需求。
  6. 会议纪要: 在会议中快速做笔记并立即与同事共享成为可能。
  7. 待办事项清单: 创建每日/每周的任务列表帮助保持生活的条理性。

二、本次实践规划

2.1 本地环境规划

本次实践为个人测试环境,操作系统版本为|Ubuntu 22.04.1。

hostnameIP地址操作系统版本Docker版本镜像版本
jeven01192.168.3.88Ubuntu 22.04.1 LTS27.1.1latest

2.2 本次实践介绍

1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署Notepad轻量级记事本。

三、本地环境检查

3.1 检查Docker服务状态

检查Docker服务是否正常运行,确保Docker正常运行。

root@jeven01:~# systemctl status docker
● docker.service - Docker Application Container EngineLoaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)Active: active (running) since Mon 2024-09-09 10:43:35 CST; 3 weeks 5 days agoDocs: https://docs.docker.comMain PID: 695 (dockerd)Tasks: 135 (limit: 9387)Memory: 4.0GCPU: 46min 46.854sCGroup: /system.slice/docker.service├─  695 /usr/bin/dockerd├─  846 containerd --config /var/run/docker/containerd/containerd.toml

3.2 检查Docker版本

检查Docker版本

root@jeven01:~# docker -v
Docker version 27.1.1, build 6312585

3.3 检查docker compose 版本

检查Docker compose版本,确保2.0以上版本。

root@jeven01:~# docker compose version
Docker Compose version v2.19.1

四、下载Notepad镜像

拉取Notepad镜像,镜像名称为: athlon1600/notepad

root@jeven01:~#  docker pull athlon1600/notepad
Using default tag: latest
latest: Pulling from athlon1600/notepad
619be1103602: Pull complete
954955a228a0: Pull complete
0de7cfe8bcac: Pull complete
eaa999f9ffef: Pull complete
5527bcbb6042: Pull complete
084990fc2f26: Pull complete
80c10377bd52: Pull complete
a34590b58af6: Pull complete
0ecf9d73ed27: Pull complete
a0c372a77070: Pull complete
Digest: sha256:16d60bb0cbdd6b90f5c441ba20a6759d8c832ebda1d5af40fb1e11b32e02857d
Status: Downloaded newer image for athlon1600/notepad:latest
docker.io/athlon1600/notepad:latest

五、部署Notepad应用

5.1 创建部署目录

  • 创建部署目录
mkdir -p /data/nodepad && cd /data/nodepad 

5.2 编辑部署文件

  • 如果使用docker-cli部署,可参考以下命令:
docker run -d \--restart always  \--name notepad \-p 3700:3000 \-v /data/nodepad/storage:/app/backend/storage \-v /data/nodepad/public:/app/backend/public \-e NODE_ENV=production \athlon1600/notepad:latest

在`部署目录下,创建docker-compose.yaml文件,其中宿主机映射端口等可以自定义配置。

vim docker-compose.yaml
version: '3.9'
services:notepad:image: 'athlon1600/notepad:latest'environment:- NODE_ENV=productionvolumes:- '/data/nodepad/public:/app/backend/public'- '/data/nodepad/storage:/app/backend/storage'ports:- '3700:3000'container_name: notepadrestart: always

5.3 创建Notepad容器

执行以下命令,创建Notepad容器。

root@jeven01:/data/nodepad# docker compose up -d
[+] Running 2/2✔ Network nodepad_default  Created                                                                                                                      0.1s✔ Container notepad        Started                                                                                                                      0.3s

5.4 查看Notepad容器状态

检查Notepad容器状态状态,确保Notepad容器正常启动。

root@jeven01:/data/nodepad# docker compose ps
NAME                IMAGE                       COMMAND                  SERVICE             CREATED             STATUS              PORTS
notepad             athlon1600/notepad:latest   "docker-entrypoint.s…"   notepad             4 minutes ago       Up 4 minutes        0.0.0.0:3700->3000/tcp, :::3700->3000/tcp

5.5 查看Notepad容器日志

检查Notepad容器日志,确保Notepad服务正常运行。

root@jeven01:/data/nodepad# docker compose logs
notepad  |
notepad  |
notepad  | > frontend@0.1.0 copy:backend
notepad  | > copyfiles -u 1 "dist/**/*" ../backend/public
notepad  |
notepad  |
notepad  |
notepad  |
notepad  | > backend@0.1.0 serve
notepad  | > nodemon -e js,html,css dist/index.js
notepad  |
notepad  |
notepad  | [nodemon] 3.1.0
notepad  | [nodemon] to restart at any time, enter `rs`
notepad  | [nodemon] watching path(s): *.*
notepad  | [nodemon] watching extensions: js,html,css
notepad  | [nodemon] starting `node dist/index.js`
notepad  | Node Express Server listening on port: 3000!

在这里插入图片描述

六、访问Notepad服务

6.1 访问Notepad主页

访问地址:http://192.168.3.88:3700,将IP替换为自己服务器IP地址。如果无法访问到以下页面,则检查宿主机的防火墙是否关闭或者放行相关端口,云服务器则还需要设置安全组规则。

在这里插入图片描述

6.2 设置访问密码

设置Notepad轻量级记事本主页的访问密码,按回车键确认访问密码,进入编辑器页面。

在这里插入图片描述

6.3 编辑笔记内容

在文本编辑器中,编辑笔记内容,如下所示:

在这里插入图片描述

在另外一台电脑或浏览器,重新打开链接,输入访问密码,可以在线编辑该文本内容。

在这里插入图片描述

七、总结

通过本次Docker项目实战,我们成功部署了一个轻量级记事本应用,实现了跨设备的临时文本存储与编辑功能。尽管存在忘记密码会导致内容丢失的风险及一些小bug,但这次实践显著加深了我们对Docker容器化技术的理解。项目不仅达到了学习和实践的目的,还明确了未来在安全性和用户界面方面需要改进的方向。这是一次极具价值的经验,为后续更复杂的应用开发奠定了坚实基础。

http://www.lryc.cn/news/622686.html

相关文章:

  • 《吃透 C++ 类和对象(中):const 成员函数与取地址运算符重载解析》
  • js原生实现手写签名与使用signature_pad库实现手写签名
  • 【Java Web 快速入门】十一、Spring Boot 原理
  • Flutter开发 网络请求
  • Flutter InheritedWidget 详解:从生命周期到数据流动的完整解析
  • Flutter Provider 模式实现:基于 InheritedWidget 的状态管理实现
  • SQL183 近三个月未完成试卷数为0的用户完成情况
  • 力扣(LeetCode) ——142. 环形链表 II(C语言)
  • JavaWeb 30 天入门:第十一天 ——Java 反射机制详解
  • 【环境变量与程序地址空间详解】
  • vue3动态的控制表格列的展示简单例子
  • 从希格斯玻色子到 QPU:C++ 的跨维度征服
  • KingbaseES高可用架构深度解析——从读写分离到异地灾备的全方位守护
  • 【C++】异常详解(万字解读)
  • 力扣hot100 | 矩阵 | 73. 矩阵置零、54. 螺旋矩阵、48. 旋转图像、240. 搜索二维矩阵 II
  • [1Prompt1Story] 生成行为控制器 | 语义向量重加权(SVR)
  • 第七十五章:AI的“思维操控师”:Prompt变动对潜在空间(Latent Space)的影响可视化——看懂AI的“微言大义”!
  • Netty 的 Select/Poll 机制核心实现主要在 NioEventLoop 的事件循环
  • Horse3D游戏引擎研发笔记(六):在QtOpenGL环境下,仿Unity的材质管理Shader绘制四边形
  • Nginx域名和IP兼容双方的API地址
  • JavaScript forEach() 与 for 循环 return 行为全解析
  • 1083. 数列极差问题
  • 2025暑期—10ROS系统实现-计算图
  • Linux sar命令详细使用指南
  • 【CV 目标检测】Fast RCNN模型①——与R-CNN区别
  • 【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
  • VUE+SPRINGBOOT从0-1打造前后端-前后台系统-用户管理
  • 基于Python的课程作业管理系统 Python+Django+Vue.js
  • .net印刷线路板进销存PCB材料ERP财务软件库存贸易生产企业管理系统
  • 《Python 单例模式(Singleton)深度解析:从实现技巧到争议与最佳实践》