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.
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/entrypoint.sh"]. This script allows changing the PUID and PGID of the user that will run inside the container. This is especially relevant to solve permission issues when mounting directories from the host. The PUID (User ID) and PGID (Group ID) can be passed as environment variables, making it easier to ensure correct permissions when accessing host-mounted directories.
Use the following parameters when running the container with docker run b3log/siyuan:
--workspace: Specifies the workspace folder path, mounted to the container via -v on the host
--accessAuthCode: Specifies the access authorization code
More parameters can be found using --help. Here’s an example of a startup command with the new environment variables:
PUID: Custom user ID (optional, defaults to 1000 if not provided)
PGID: Custom group ID (optional, defaults to 1000 if not provided)
workspace_dir_host: The workspace folder path on the host
workspace_dir_container: The path of the workspace folder in the container, as specified in --workspace
In alternative, it’s possible to set the path via the SIYUAN_WORKSPACE_PATH env variable. The commandline will always have the priority, if both are set
accessAuthCode: Access authorization code (please be sure to modify, otherwise anyone can access your data)
In alternative, it’s possible to set the auth code via the SIYUAN_ACCESS_AUTH_CODE env variable. The commandline will always have the priority, if both are set
To disable the Access authorization code set the env variable SIYUAN_ACCESS_AUTH_CODE_BYPASS=true
To simplify things, it is recommended to configure the workspace folder path to be consistent on the host and container, such as having both workspace_dir_host and workspace_dir_container configured as /siyuan/workspace. The corresponding startup command would be:
For users running Siyuan with Docker Compose, the environment variables PUID and PGID can be passed to customize the user and group IDs. Here’s an example of a Docker Compose configuration:
version: "3.9"
services:
main:
image: b3log/siyuan
command: ['--workspace=/siyuan/workspace/', '--accessAuthCode=${AuthCode}']
ports:
- 6806:6806
volumes:
- /siyuan/workspace:/siyuan/workspace
restart: unless-stopped
environment:
# A list of time zone identifiers can be found at https://en.wikipedia.org/wiki/List_of_tz_database_time_zones
- TZ=${YOUR_TIME_ZONE}
- PUID=${YOUR_USER_PUID} # Customize user ID
- PGID=${YOUR_USER_PGID} # Customize group ID
In this setup:
PUID and PGID are set dynamically and passed to the container
If these variables are not provided, the default 1000 will be used
By specifying PUID and PGID in the environment, you avoid the need to explicitly set the user directive (user: '1000:1000') in the compose file. The container will dynamically adjust the user and group based on these environment variables at startup.
User Permissions
In the image, the entrypoint.sh script ensures the creation of the siyuan user and group with the specified PUID and PGID. Therefore, when the host creates a workspace folder, pay attention to setting the user and group ownership of the folder to match the PUID and PGID you plan to use. For example:
chown -R 1001:1002 /siyuan/workspace
If you use custom PUID and PGID values, the entrypoint script will ensure that the correct user and group are created inside the container, and ownership of mounted volumes will be adjusted accordingly. There’s no need to manually pass -u in docker run or docker-compose as the environment variables will handle the customization.
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
If you encounter permission issues, verify that the PUID and PGID environment variables match the ownership of the mounted directories on your host system
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
Unraid Hosting
Unraid Deployment
Note: First run chown -R 1000:1000 /mnt/user/appdata/siyuan in the terminal
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
public is used to save public data
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 connect with third-party cloud storage (Member’s privileges).
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:
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 pay attention to Official Download or GitHub Releases to get the new version.
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+/ .
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:
Manually back up the data, you can use Export Data or directly copy the workspace/data/ folder on the file system
Settings - About - Data rep key - Reset data repo
Reinitialize the data repo key. After initializing the key on one device, other devices import the key
The cloud uses the new synchronization directory, the old synchronization directory is no longer available and can be deleted
The existing cloud snapshots are no longer available and can be deleted
Do I need to pay for it?
Most features are free, even for commercial use.
Member’s privileges can only be used after payment, please refer to Pricing.
🙏 Acknowledgement
The birth of SiYuan is inseparable from many open source projects and contributors, please refer to the project source code kernel/go.mod, app/package.json and project homepage.
The growth of SiYuan is inseparable from user feedback and promotion, thank you for everyone’s help to SiYuan ❤️
Contributors
Welcome to join us and contribute code to SiYuan together.
Refactor your thinking
中文 | 日本語 | Türkçe
Table of Contents
💡 Introduction
SiYuan is a privacy-first personal knowledge management system, support fine-grained block-level reference and Markdown WYSIWYG.
Welcome to SiYuan English Discussion Forum to learn more.
🔮 Features
Most features are free, even for commercial use.
siyuan://Some features are only available to paid members, for more details please refer to Pricing.
🏗️ Architecture and Ecosystem
🌟 Star History
🗺️ 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
Mobile:
Desktop:
Installation Package
Package Manager
siyuansiyuan-noteDocker Hosting
Docker Deployment
Overview
The easiest way to serve SiYuan on a server is to deploy it through Docker.
b3log/siyuanFile structure
The overall program is located under
/opt/siyuan/, which is basically the structure under the resources folder of the Electron installation package:Entrypoint
The entry point is set when building the Docker image:
ENTRYPOINT ["/opt/siyuan/entrypoint.sh"]. This script allows changing thePUIDandPGIDof the user that will run inside the container. This is especially relevant to solve permission issues when mounting directories from the host. ThePUID(User ID) andPGID(Group ID) can be passed as environment variables, making it easier to ensure correct permissions when accessing host-mounted directories.Use the following parameters when running the container with
docker run b3log/siyuan:--workspace: Specifies the workspace folder path, mounted to the container via-von the host--accessAuthCode: Specifies the access authorization codeMore parameters can be found using
--help. Here’s an example of a startup command with the new environment variables:PUID: Custom user ID (optional, defaults to1000if not provided)PGID: Custom group ID (optional, defaults to1000if not provided)workspace_dir_host: The workspace folder path on the hostworkspace_dir_container: The path of the workspace folder in the container, as specified in--workspaceSIYUAN_WORKSPACE_PATHenv variable. The commandline will always have the priority, if both are setaccessAuthCode: Access authorization code (please be sure to modify, otherwise anyone can access your data)SIYUAN_ACCESS_AUTH_CODEenv variable. The commandline will always have the priority, if both are setSIYUAN_ACCESS_AUTH_CODE_BYPASS=trueTo simplify things, it is recommended to configure the workspace folder path to be consistent on the host and container, such as having both
workspace_dir_hostandworkspace_dir_containerconfigured as/siyuan/workspace. The corresponding startup command would be:Docker Compose
For users running Siyuan with Docker Compose, the environment variables
PUIDandPGIDcan be passed to customize the user and group IDs. Here’s an example of a Docker Compose configuration:In this setup:
PUIDandPGIDare set dynamically and passed to the container1000will be usedBy specifying
PUIDandPGIDin the environment, you avoid the need to explicitly set theuserdirective (user: '1000:1000') in the compose file. The container will dynamically adjust the user and group based on these environment variables at startup.User Permissions
In the image, the
entrypoint.shscript ensures the creation of thesiyuanuser and group with the specifiedPUIDandPGID. Therefore, when the host creates a workspace folder, pay attention to setting the user and group ownership of the folder to match thePUIDandPGIDyou plan to use. For example:If you use custom
PUIDandPGIDvalues, the entrypoint script will ensure that the correct user and group are created inside the container, and ownership of mounted volumes will be adjusted accordingly. There’s no need to manually pass-uindocker runordocker-composeas the environment variables will handle the customization.Hidden port
Use NGINX reverse proxy to hide port 6806, please note:
/wsNote
PUIDandPGIDenvironment variables match the ownership of the mounted directories on your host systemLimitations
Unraid Hosting
Unraid Deployment
Note: First run
chown -R 1000:1000 /mnt/user/appdata/siyuanin the terminalTemplate reference:
TrueNAS Hosting
TrueNAS Deployment
Note: First run below commands in the TrueNAS Shell. please update `Pool_1/Apps_Data/siyuan to match your dataset for Apps.
Navigate to Apps - DiscoverApps - More Options(on top right, besies Custom App) - Install via YAML
Template reference:
Insider Preview
We release insider preview before major updates, please visit https://github.com/siyuan-note/insider.
🏘️ Community
🛠️ Development Guide
See Development Guide.
❓ FAQ
How does SiYuan store data?
The data is saved in the workspace folder, in the workspace data folder:
assetsis used to save all inserted assetsemojisis used to save emoji imagessnippetsis used to save code snippetsstorageis used to save query conditions, layouts and flashcards, etc.templatesis used to save template snippetswidgetsis used to save widgetspluginsis used to save pluginspublicis used to save public data.syin the notebook folder are used to save the document data, and the data format is JSONDoes 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 connect with third-party cloud storage (Member’s privileges).
In addition, you can also consider manually exporting and importing data to achieve data synchronization:
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?
You can Check update in Settings - About - Current Version, or pay attention to Official Download or GitHub Releases to get the new version.
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+/ .
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:
Do I need to pay for it?
Most features are free, even for commercial use.
Member’s privileges can only be used after payment, please refer to Pricing.
🙏 Acknowledgement
The birth of SiYuan is inseparable from many open source projects and contributors, please refer to the project source code kernel/go.mod, app/package.json and project homepage.
The growth of SiYuan is inseparable from user feedback and promotion, thank you for everyone’s help to SiYuan ❤️
Contributors
Welcome to join us and contribute code to SiYuan together.