A privacy-first, self-hosted, fully open source personal knowledge management software, written in typescript and golang. https://b3log.org/siyuan
Find a file
颖逸 08b333501b
🎨 Widgets search supports symlink subdirectory
* 🎨 bazaar resource directories support symlink

* 🎨 bazaar resource directories support symlink

* Squashed commit of the following:

commit a335101d49
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 12:53:33 2023 +0800

    🔖 Release v2.8.8

commit 6a6dec05f3
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 11:30:33 2023 +0800

    📝 Update changelogs

commit a819656c0a
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 11:15:53 2023 +0800

    📝 Update changelogs

commit 56a2c368d9
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 11:11:54 2023 +0800

    🐛 Remove inconsistent scroll IAL

commit 8b6abec8e9
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 10:39:48 2023 +0800

    🎨 Bazaar resource directories support symlink https://github.com/siyuan-note/siyuan/pull/8263

commit 9455086820
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 10:35:46 2023 +0800

    📝 Update changelogs

commit fdbfe6b848
Author: 颖逸 <49649786+Zuoqiu-Yingyi@users.noreply.github.com>
Date:   Tue May 16 10:34:38 2023 +0800

    Bazaar resource directories support symlink (#8263)

    * 🎨 bazaar resource directories support symlink

    * 🎨 bazaar resource directories support symlink

commit 85496345ef
Author: Vanessa <lly219@gmail.com>
Date:   Tue May 16 10:31:01 2023 +0800

     enable plugin

commit f3d1acd166
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 09:39:01 2023 +0800

    📝 Update changelogs

commit bf4b88a007
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 09:38:50 2023 +0800

    🎨 Plugin hot load

commit 516276db49
Author: Liang Ding <d@b3log.org>
Date:   Tue May 16 09:09:31 2023 +0800

    🎨 Data sync connectivity check supports redirection Fix https://github.com/siyuan-note/siyuan/issues/8264

commit d24f5ae3cf
Author: Vanessa <lly219@gmail.com>
Date:   Tue May 16 00:05:18 2023 +0800

    🚨

commit 1ac623ebb1
Author: Vanessa <lly219@gmail.com>
Date:   Tue May 16 00:04:25 2023 +0800

    🎨 fix https://github.com/siyuan-note/siyuan/issues/8258

commit fdf9f0d9e4
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 22:33:36 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/5066 removeData

commit 7c7f3db0b8
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 22:26:11 2023 +0800

    🐛 fix https://github.com/siyuan-note/siyuan/issues/8259

commit ba4e5e8eed
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 19:59:13 2023 +0800

    💄 fix https://github.com/siyuan-note/siyuan/issues/8260

commit 4f099bd990
Merge: b892fadd 856c7e09
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 19:35:33 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit b892fadd19
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 19:35:19 2023 +0800

    💄

commit 856c7e0973
Author: Liang Ding <d@b3log.org>
Date:   Mon May 15 18:48:33 2023 +0800

    📝 Improve initialization data sync interaction https://github.com/siyuan-note/siyuan/issues/8220

commit ab6cb335e4
Author: Liang Ding <d@b3log.org>
Date:   Mon May 15 18:41:51 2023 +0800

    📝 Improve initialization data sync interaction https://github.com/siyuan-note/siyuan/issues/8220

commit a759936208
Author: Liang Ding <d@b3log.org>
Date:   Mon May 15 16:02:58 2023 +0800

    📝 Improve initialization data sync interaction https://github.com/siyuan-note/siyuan/issues/8220

commit 2513cbc31d
Author: Liang Ding <d@b3log.org>
Date:   Mon May 15 15:53:46 2023 +0800

    📝 Improve initialization data sync interaction https://github.com/siyuan-note/siyuan/issues/8220

commit 9a03f1e736
Author: Liang Ding <d@b3log.org>
Date:   Mon May 15 15:52:00 2023 +0800

    📝 Update changelogs

commit 4cb952361e
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 15:51:31 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/8220

commit 7d58ab0607
Merge: 6ca68174 0a102851
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 15:43:33 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit 6ca6817465
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 15:43:16 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/8220

commit 0a10285167
Author: Liang Ding <d@b3log.org>
Date:   Mon May 15 14:56:12 2023 +0800

    🎨 Escape the notification message https://github.com/siyuan-note/siyuan/issues/7811

commit 7dbfa43de4
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 13:59:50 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/8220

commit 15141dde1f
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 13:54:30 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/8220

commit dc1941da3c
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 12:11:45 2023 +0800

    🎨 catch plugin load

commit e7288185be
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 12:04:22 2023 +0800

    🎨 catch plugin load

commit 6690084caa
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 11:46:51 2023 +0800

    🎨 fix https://github.com/siyuan-note/siyuan/issues/8256

commit 53a95ffbf7
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 00:27:27 2023 +0800

    💄 account

commit 4c7fe248e4
Merge: 3674e834 2cf8a819
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 00:11:08 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit 3674e83428
Author: Vanessa <lly219@gmail.com>
Date:   Mon May 15 00:10:46 2023 +0800

    💄 account

commit 2cf8a8191a
Author: Liang Ding <d@b3log.org>
Date:   Sun May 14 23:21:32 2023 +0800

    🎨 Improve images render in the marketplace package https://github.com/siyuan-note/bazaar/issues/1119

commit 7572db4012
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 12:10:47 2023 +0800

    🎨 fix https://github.com/siyuan-note/siyuan/issues/8216

commit 18071638cf
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 12:09:52 2023 +0800

    🎨 fix https://github.com/siyuan-note/siyuan/issues/8216

commit 300a60aa45
Merge: 0b001595 a6ecb981
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 11:50:55 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit 0b00159511
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 11:50:41 2023 +0800

    🐛 open new window

commit a6ecb981b2
Author: Liang Ding <d@b3log.org>
Date:   Sun May 14 11:43:54 2023 +0800

    🎨 Sponsorship through the Open Collective is no longer supported

commit 6c3c8d44ad
Author: Liang Ding <d@b3log.org>
Date:   Sun May 14 10:44:39 2023 +0800

    🎨 When multiple windows exist, each window should be isolated using the `Optimize Typesetting` https://github.com/siyuan-note/siyuan/issues/8216

commit 3edd8230d3
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 10:34:48 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/8216

commit f8412a49c4
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 10:27:16 2023 +0800

    🐛 fix https://github.com/siyuan-note/siyuan/issues/8187

commit a74ee348f7
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 10:17:43 2023 +0800

    🎨 fix https://github.com/siyuan-note/siyuan/issues/8242

commit 518ce94912
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 10:09:11 2023 +0800

    💄 bazaar

commit e6923bdebc
Author: Vanessa <lly219@gmail.com>
Date:   Sun May 14 09:55:50 2023 +0800

    🎨 https://github.com/siyuan-note/siyuan/issues/8245?utm_source=ld246.com

* 🎨 widgets search support symlink directory

* 🎨 templates directory support symlink

* Update template.go
2023-05-17 15:27:32 +08:00
.github 🔖 Release v2.8.8 2023-05-16 12:53:33 +08:00
app 🐛 fix https://github.com/siyuan-note/siyuan/issues/8285 2023-05-17 12:38:31 +08:00
kernel 🎨 Widgets search supports symlink subdirectory 2023-05-17 15:27:32 +08:00
screenshots 📸 Update snapshots 2022-10-19 21:41:50 +08:00
scripts ✏️ Fix typos 2023-05-02 23:02:14 +08:00
.gitattributes :octocat: Organize GitHub language statistics 2023-03-29 10:17:26 +08:00
.gitignore :octocat: Update comments 2023-03-29 10:19:32 +08:00
API.md 📝 Update doc of kernel API insertBlock Fix https://github.com/siyuan-note/siyuan/issues/8270 2023-05-17 09:38:12 +08:00
API_zh_CN.md 📝 Update doc of kernel API insertBlock Fix https://github.com/siyuan-note/siyuan/issues/8270 2023-05-17 09:38:12 +08:00
CHANGELOG.md 🎨 Show "What's News" after upgrading https://github.com/siyuan-note/siyuan/issues/7902 2023-04-06 21:56:52 +08:00
Dockerfile 🎨 Show "What's News" after upgrading https://github.com/siyuan-note/siyuan/issues/7902 2023-04-06 21:56:52 +08:00
LICENSE ❤️ Complete open source interface and kernel #5013 2023-04-19 19:27:40 +08:00
README.md 📝 Update README 2023-05-17 11:30:22 +08:00
README_zh_CN.md 📝 Update README 2023-05-17 11:30:22 +08:00

SiYuan
Build Your Eternal Digital Garden

中文

💡 Introduction

SiYuan is a privacy-first personal knowledge management system, support fine-grained block-level reference and Markdown WYSIWYG.

feature0.png

🔮 Features

Free

All local features are free, even for commercial use.

  • Content block
    • Block-level reference and two-way links
    • Custom attributes
    • SQL query embed
    • Protocol siyuan://
  • Editor
    • Block-style
    • Markdown WYSIWYG
    • List outline
    • Block zoom-in
    • Block horizontal layout
    • Million-word large document editing
    • Mathematical formulas, charts, flowcharts, Gantt charts, timing charts, staffs, etc.
    • Web clipping
    • PDF Annotation link
  • Export
    • Block ref and embed
    • Standard Markdown with assets
    • PDF, Word and HTML
    • Copy to WeChat MP, Zhihu and Yuque
  • End-to-end encrypted data sync and backup via the third-party cloud storage services
    • S3
    • WebDAV
  • Spaced repetition
  • Multi-tab, drag and drop to split screen
  • Template snippet
  • JavaScript/CSS snippet
  • Android/iOS APP
  • Docker deployment
  • API
  • Community bazaar

Paid subscription

Cloud services require a paid subscription.

  • VIP identity
  • End-to-end encrypted data sync and backup
  • Cloud assets serving
  • WeChat notification
  • Cloud inbox

🌟 Star History

Star History Chart

🗺️ Roadmap

🚀 Download Setup

It is recommended to give priority to installing through the application market on the desktop and mobile, so that you can upgrade the version with one click in the future.

App Market

Docker Hosting

Docker Deployment

Overview

The easiest way to serve SiYuan on a server is to deploy it through Docker.

File structure

The overall program is located under /opt/siyuan/, which is basically the structure under the resources folder of the Electron installation package:

  • appearance: icon, theme, languages
  • guide: user guide document
  • stage: interface and static resources
  • kernel: kernel program

Entrypoint

The entry point is set when building the Docker image: ENTRYPOINT ["/opt/siyuan/kernel" ], use docker run b3log/siyuan with parameters to start:

  • --workspace specifies the workspace folder path, mounted to the container via -v on the host

More parameters can refer to --help. The following is an example of a startup command: docker run -v workspace_dir_host:workspace_dir_container -p 6806:6806 b3log/siyuan --workspace=workspace_dir_container

  • workspace_dir_host: the workspace folder path on the host
  • workspace_dir_container: The path of the workspace folder in the container, which is the same as specified in --workspace

To simplify, it is recommended to configure the workspace folder path to be consistent on the host and container, such as: workspace_dir_host and workspace_dir_container are configured as /siyuan/workspace, the corresponding startup commands is: docker run -v /siyuan/workspace:/siyuan/workspace -p 6806:6806 -u 1000:1000 b3log/siyuan --workspace=/siyuan/workspace/.

User permissions

In the image, the normal user siyuan (uid 1000/gid 1000) created by default is used to start the kernel process. Therefore, when the host creates a workspace folder, please pay attention to setting the user group of the folder: chown -R 1000:1000 /siyuan/workspace. The parameter -u 1000:1000 is required when starting the container.

Hidden port

Use NGINX reverse proxy to hide port 6806, please note:

  • Configure WebSocket reverse proxy /ws

Note

  • Be sure to confirm the correctness of the mounted volume, otherwise the data will be lost after the container is deleted
  • Do not use URL rewriting for redirection, otherwise there may be problems with authentication, it is recommended to configure a reverse proxy

Limitations

  • Does not support desktop and mobile application connections, only supports use on browsers
  • Export to PDF, HTML and Word formats is not supported
  • Import Markdown file is not supported

Installation Package

Insider Preview

We release insider preview before major updates, please visit https://github.com/siyuan-note/insider.

🏘️ Community

  • Issues Official support channels
  • Discord A community built by enthusiastic users
  • Awesome SiYuan Resources organized by enthusiastic users

🛠️ Development Guide

See Development Guide.

FAQ

Is SiYuan right for me? Or how should I choose note-taking software?

This question varies from person to person and is difficult to answer uniformly. If you're not sure if SiYuan is right for you, here are some suggestions:

How does SiYuan store data?

The data is saved in the workspace folder, in the workspace data folder:

  • assets is used to save all inserted assets
  • emojis is used to save emoji images
  • snippets is used to save code snippets
  • storage is used to save query conditions, layouts and flashcards, etc.
  • templates is used to save template snippets
  • widgets is used to save widgets
  • plugins is used to save plugins
  • The rest of the folders are the notebook folders created by the user, files with the suffix of .sy in the notebook folder are used to save the document data, and the data format is JSON

Does it support data synchronization through a third-party sync disk?

Data synchronization through third-party synchronization disks is not supported, otherwise data may be corrupted.

Although it does not support third-party sync disks, it supports third-party cloud storage services, which can be configured in Settings - Cloud - Cloud Storage Provider, currently supported:

Synchronizing data through third-party cloud storage services is also end-to-end encrypted, and third-party cloud storage service providers cannot obtain our plaintext data.

In addition, you can also consider manually exporting and importing data to achieve data synchronization:

  • Desktop: Settings - Export - Export Data / Import Data
  • Mobile: Right column - About - Export Data / Import Data

Is SiYuan open source?

SiYuan is completely open source, and contributions are welcome:

For more details, please refer to Development Guide.

How to upgrade to a new version?

  • If installed via app store, please update via app store
  • If it is installed through the installation package on the desktop, you can open the option of Settings - About - Automatically download update installation package, so that SiYuan will automatically download The latest version of the installation package and prompts to install
  • If it is installed by manual installation package, please download the installation package again to install

You can Check update in Settings - About - Current Version, or by following GitHub Releases or SiYuan Announcement to get the new version.

Note: Do not place the workspace in the installation directory, because the updated version will clear all files in the installation directory

Is there any note for deleting docs?

After deletion, the doc will not appear in the operating system's recycle bin, but will be deleted directly. When deleted, SiYuan will generate data history.

How can I just wrap and not start a new paragraph?

Please use Shift+Enter.

What if some blocks (such as paragraph blocks in list items) cannot find the block icon?

The first sub-block under the list item is the block icon omitted. You can move the cursor into this block and trigger its block menu with Ctrl+/ .

How to share notes?

  • Share document to Liandi
  • Export and import .sy.zip package
  • Via network hosting
  • Export and import Markdown
  • Export Preview to copy to third-party online services

What should I do if the data repo key is lost?

  • If the data repo key is correctly initialized on multiple devices before, the key is the same on all devices and can be set in Settings - About - Data repo key - Copy key string retrieve

  • If it has not been configured correctly before (for example, the keys on multiple devices are inconsistent) or all devices are unavailable and the key string cannot be obtained, you can reset the key by following the steps below:

    1. Manually back up the data, you can use Export Data or directly copy the workspace/data/ folder on the file system
    2. Settings - About - Data rep key - Reset data repo
    3. Reinitialize the data repo key. After initializing the key on one device, other devices import the key
    4. The cloud uses the new synchronization directory, the old synchronization directory is no longer available and can be deleted
    5. The existing cloud snapshots are no longer available and can be deleted

Do I need to pay for it?

All local features are free, even for commercial use.

Cloud Service requires an annual subscription. At present, only users in mainland China are supported to subscribe, and users outside of mainland China are not allowed to subscribe.

🙏 Acknowledgement

Contributors

Welcome to join us and contribute code to SiYuan together.

Open source project dependencies

SiYuan is made possible by the following open source projects.