【Docker项目实战】使用Docker部署DailyTxT加密日记网络应用程序

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: 【4月更文挑战第6天】使用Docker部署DailyTxT加密日记网络应用程序

一、DailyTxT介绍

1.1 DailyTxT简介

  • DailyTxT简介

DailyTxT 是一个加密的日记网络应用程序,可以写下您当天的故事并轻松再次找到它们。 它是用Python Flask(后端)和Vue.JS(前端)编写的,旨在由Docker运行 - 支持AMD64和ARM64。

1.2 DailyTxT特点

  • 加密:您写入的所有内容在写入服务器存储之前都会进行加密。即使是管理员也无法读取您的私人内容!
  • 文件上传:您可以每天上传任意文件(每个文件最大 128 MB)。它们也以加密方式存储在服务器上。
  • 搜索:通过轻松扫描笔记中的任何关键字并重新发现您可能几乎忘记的细节来支持您的记忆。
  • 多语言支持:该网络应用程序目前提供德语、英语、西班牙语和中文(简体)翻译版本。系统会根据浏览器的设置自动检测和选择语言。- - 添加更多语言很容易 - 如果您向我提供语言文件!看client/src/lang/translations
  • 移动:响应式设计,便于在移动屏幕上使用。此外:允许安装“A2HS”(添加 2 个主屏幕)
  • 多用户接口:您可以创建多个用户帐户。每个帐户都使用自己的加密密钥,因此不存在数据泄露的风险。
  • 备份和恢复:出于备份原因,您可以将所有数据(解密)导出到 zip 文件中,稍后通过上传 zip 重新导入数据。
  • 模板:创建模板,您可以每天重复使用这些模板。

1.3 DailyTxT使用场景

  • 个人日记:DailyTxT可以作为个人记录和回顾日常生活的工具。用户可以在应用程序中写下每天的故事、感受和思考,并通过加密保护其隐私。

  • 团队协作:DailyTxT可以用作团队协作工具,团队成员可以在应用程序中分享和讨论每天的进展、问题和想法。每个团队成员都可以保持自己的日记本,而且由于加密保护,只有被授权的团队成员可以访问他人的日记。

  • 学生记录:学生可以使用DailyTxT来记录学习的进展和经验,以及记录每天的问题和解决方案。这有助于学生跟踪他们的学习过程,并提供一个地方来回顾和反思他们的学习经历。

  • 情感日记:DailyTxT可以作为情感日记的工具,用户可以在应用程序中记录自己的情感状态、心情和思考。这可以帮助用户更好地了解自己的情绪变化和情感发展,并提供一个安全的空间来表达和处理情感。

  • 心理健康和治疗支持:DailyTxT可以用作心理健康和治疗支持的工具。用户可以在应用程序中写下他们的心理状态、挑战和进步,并与治疗师或医生分享。DailyTxT的加密功能可确保用户的隐私和保密性。

二、本地环境介绍

2.1 本地环境规划

本次实践为个人测试环境,操作系统版本为centos7.6。

hostname IP地址 操作系统版本 Docker版本
dokcer 192.168.3.166 centos 7.6 2 20.10.17

2.2 本次实践介绍

1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署DailyTxT加密日记网络应用程序。

三、本地环境检查

3.1 检查Docker服务状态

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

[root@jeven ~]#  systemctl status docker
● docker.service - Docker Application Container Engine
   Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)
   Active: active (running) since Thu 2024-01-04 22:20:00 CST; 12h ago
     Docs: https://docs.docker.com
 Main PID: 11192 (dockerd)
    Tasks: 36
   Memory: 258.5M
   CGroup: /system.slice/docker.service

3.2 检查Docker版本

检查Docker版本,当前Docker版本为20.10.17。

[root@jeven ~]# docker -v
Docker version 20.10.17, build 100c701

3.3 检查docker compose 版本

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

[root@jeven ~]# docker compose version
Docker Compose version v2.6.0

四、下载DailyTxT镜像

从docker hub拉取DailyTxT镜像,如果镜像拉取过慢,可尝试更换国内镜像加速源。

[root@jeven dailytxt]# docker pull phitux/dailytxt:latest
latest: Pulling from phitux/dailytxt
Digest: sha256:fe39d699b7af49e6dd6b670300a9e3816fa36b8479fe9aeba9fe5eda0aa85d96
Status: Image is up to date for phitux/dailytxt:latest
docker.io/phitux/dailytxt:latest

五、部署DailyTxT应用

5.1 创建部署目录

创建DailyTxT部署目录/data/dailytxt/

mkdir -p /data/dailytxt/data  && cd /data/dailytxt/

5.2 编辑docker-compose.yaml文件

如果需要使用docker-cli命令部署,执行以下命令,设置host_port与SECRET_KEY后即可。

docker run -p 127.0.0.1:<host_port>:8765 -e "PORT=8765" -e "SECRET_KEY=<openssl rand -base64 32>" -e "ALLOW_REGISTRATION=True" -v </save/my/dailytxt-files/here/>:/app/data --name dailytxt -d phitux/dailytxt:latest

本次实践部署使用docker compose方式,编辑docker-compose.yaml文件。

version: "3"

services:
  dailytxt:
    image: phitux/dailytxt:latest
    container_name: dailytxt
    restart: always
    environment:
      # That's the internal container-port. You can actually use any portnumber (must match with the one at 'ports')
      - PORT=8765

      - SECRET_KEY=HANEZfT3CWsWOUf/5rtXqL4E2HfwquXzeCNUwoovL20=

      # Set it to False or remove the line completely to disallow registration of new users.
      - ALLOW_REGISTRATION=True

      # Use this if you want the json log file to be indented. Makes it easier to compare the files. Otherwise just remove this line!
      - DATA_INDENT=2

      # Set after how many days the JWT token will expire and you have to re-login. Defaults to 30 days if line is ommited.
      - JWT_EXP_DAYS=60

      # Enable/disable a feature of DailyTxT to auto-check maximal once per hour if there's a newer version of DailyTxT available. Defaults to True if line is ommited.
      - ENABLE_UPDATE_CHECK=True
    ports:
      - 9809:8765
      # perhaps you only want:
      # "<host_port>:8765"
    volumes:
      - /data/dailytxt/data:/app/data/
      # Or perhaps if using on a windows enviroment:
      # "C:/Users/example/dailytxt/:/app/data"

5.3 创建DailyTxT容器

使用docker-compose.yaml文件创建DailyTxT容器

[root@jeven dailytxt]# docker compose up -d
[+] Running 2/2
 ⠿ Network dailytxt_default  Created                                                                                    0.1s
 ⠿ Container dailytxt        Started                                                                                    1.9s

5.4 检查DailyTxT容器状态

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

[root@jeven dailytxt]# docker ps
CONTAINER ID   IMAGE                    COMMAND                  CREATED          STATUS          PORTS                 NAMES
59fcd18d1090   phitux/dailytxt:latest   "/bin/sh -c 'gunicor…"   31 seconds ago   Up 28 seconds   0.0.0.0:9809->8765/tcp, :::9809->8765/tcp   dailytxt

六、访问DailyTxT首页

6.1 注册账号

访问地址:http://192.168.3.166:9809,将IP替换为自己服务器IP地址,进入到DailyTxT首页。如果无法访问,则检查服务器防火墙是否设置,云服务器的安全组端口是否放行等。

在这里插入图片描述

点击注册账号,自定义设置账号密码登录即可。

在这里插入图片描述
在这里插入图片描述

七、DailyTxT的基本使用

7.1 上传文件

在DailyTxT右侧的文件区,点击上传文件。

在这里插入图片描述

点击文件区的上传文件,则可在当前浏览器直接下载。

在这里插入图片描述

7.2 图片预览

点击上传的图片文件,可以在线预览和下载。

在这里插入图片描述

7.3 编辑日记

可以在日记编辑区,编辑当天日记。

在这里插入图片描述

7.4 日记标记

可以标记某天日期,作为重要日记来标记。

在这里插入图片描述

7.5 日记搜索

可以在搜索栏内,搜索日记内容的关键字。

在这里插入图片描述

八、总结

DailyTxT是一款方便实用的日记工具,特别适合个人日常工作与学习使用。DailyTxT使用docker方式部署非常简单,界面美观简洁。通过左侧的日历栏,可以快速查看每日日记,搜索功能也非常强大,能够通过关键字快速找到相关日记。DailyTxT还具有加密功能,保障了我们的日记安全性。无论是记录日常生活还是重要事件,DailyTxT都是一个值得尝试的应用程序,它的易用性和加密功能让我们能够方便地记录日记笔记等。

相关文章
|
19天前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
132 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
10天前
|
安全 算法 网络协议
【网络原理】——图解HTTPS如何加密(通俗简单易懂)
HTTPS加密过程,明文,密文,密钥,对称加密,非对称加密,公钥和私钥,证书加密
|
30天前
|
存储 SQL 安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将介绍网络安全的重要性,分析常见的网络安全漏洞及其危害,探讨加密技术在保障网络安全中的作用,并强调提高安全意识的必要性。通过本文的学习,读者将了解网络安全的基本概念和应对策略,提升个人和组织的网络安全防护能力。
|
1月前
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将从网络安全漏洞、加密技术和安全意识三个方面进行探讨,旨在提高读者对网络安全的认识和防范能力。通过分析常见的网络安全漏洞,介绍加密技术的基本原理和应用,以及强调安全意识的重要性,帮助读者更好地保护自己的网络信息安全。
49 10
|
1月前
|
安全 Docker 容器
docker的默认网络模式有哪些
Docker 默认网络模式包括:1) bridge:默认模式,各容器分配独立IP,可通过名称或IP通信;2) host:容器与宿主机共享网络命名空间,性能最优但有安全风险;3) none:容器隔离无网络配置,适用于仅需本地通信的场景。
39 6
|
1月前
|
存储 安全 网络安全
网络安全的盾与剑:漏洞防御与加密技术的实战应用
在数字化浪潮中,网络安全成为保护信息资产的重中之重。本文将深入探讨网络安全的两个关键领域——安全漏洞的防御策略和加密技术的应用,通过具体案例分析常见的安全威胁,并提供实用的防护措施。同时,我们将展示如何利用Python编程语言实现简单的加密算法,增强读者的安全意识和技术能力。文章旨在为非专业读者提供一扇了解网络安全复杂世界的窗口,以及为专业人士提供可立即投入使用的技术参考。
|
1月前
|
安全 网络安全 数据安全/隐私保护
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
在数字化时代,网络安全和信息安全已成为我们日常生活中不可或缺的一部分。本文将深入探讨网络安全漏洞、加密技术和安全意识等方面的问题,并提供一些实用的建议和解决方案。我们将通过分析网络攻击的常见形式,揭示网络安全的脆弱性,并介绍如何利用加密技术来保护数据。此外,我们还将强调提高个人和企业的安全意识的重要性,以应对日益复杂的网络威胁。无论你是普通用户还是IT专业人士,这篇文章都将为你提供有价值的见解和指导。
|
1月前
|
安全 网络安全 数据安全/隐私保护
网络安全与信息安全:漏洞、加密与意识的艺术
在数字世界的迷宫中,网络安全和信息安全是守护者之剑。本文将揭示网络漏洞的面纱,探索加密技术的奥秘,并强调安全意识的重要性。通过深入浅出的方式,我们将一起走进这个充满挑战和机遇的领域,了解如何保护我们的数字身份不受威胁,以及如何在这个不断变化的环境中保持警惕和适应。
41 1
|
1月前
|
存储 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
在数字化时代,网络安全和信息安全已经成为了我们生活中不可或缺的一部分。本文将介绍网络安全的基本概念,包括网络安全漏洞、加密技术以及如何提高个人和组织的安全意识。我们将通过一些实际案例来说明这些概念的重要性,并提供一些实用的建议来保护你的信息和数据。无论你是网络管理员还是普通用户,都可以从中获得有用的信息和技能。
26 0
|
1月前
|
安全 网络安全 数据安全/隐私保护
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
在数字化时代,网络安全和信息安全已成为全球关注的焦点。本文将探讨网络安全漏洞、加密技术以及提升安全意识的重要性。通过深入浅出的解释和实际案例分析,我们将揭示网络攻击的常见手段,介绍加密技术如何保护数据安全,并强调个人和企业应如何提高安全防范意识。无论你是IT专业人士还是普通网民,这篇文章都将为你提供宝贵的信息和建议,帮助你在网络世界中更安全地航行。