2022-01-17 08:42:36 +08:00
< h1 align = "center" > ✍️ Memos< / h1 >
2022-05-20 06:24:47 +08:00
< p align = "center" > An open source, self-hosted knowledge base that works with a SQLite db file.< / p >
2022-05-15 10:54:00 +08:00
2022-01-16 13:33:25 +08:00
< p align = "center" >
2022-05-21 12:33:18 +08:00
< img alt = "GitHub stars" src = "https://img.shields.io/github/stars/usememos/memos" / >
2022-07-09 14:09:40 +08:00
< a href = "https://hub.docker.com/r/neosmemo/memos" > < img alt = "Docker pull" src = "https://img.shields.io/docker/pulls/neosmemo/memos.svg" / > < / a >
2022-05-21 12:33:18 +08:00
< img alt = "Go report" src = "https://goreportcard.com/badge/github.com/usememos/memos" / >
2022-01-16 13:33:25 +08:00
< / p >
2022-01-17 08:42:36 +08:00
2022-01-16 13:33:25 +08:00
< p align = "center" >
2022-05-15 10:54:00 +08:00
< a href = "https://memos.onrender.com/" > Live Demo< / a > •
2022-07-15 22:49:22 +08:00
< a href = "https://t.me/+-_tNF1k70UU4ZTc9" > Discuss in Telegram< / a >
2022-01-16 13:33:25 +08:00
< / p >
2021-12-08 23:43:14 +08:00
2022-07-09 21:04:53 +08:00
![demo ](https://raw.githubusercontent.com/usememos/memos/main/resources/demo.webp )
2022-05-02 11:09:29 +08:00
2022-02-04 22:00:13 +08:00
## 🎯 Intentions
2022-01-16 13:33:25 +08:00
2022-05-15 10:54:00 +08:00
- ✍️ Write down the light-card memos very easily;
- 🏗️ Build the fragmented knowledge management tool for yourself;
- 📒 For noting your 📅 daily/weekly plans, 💡 fantastic ideas, 📕 reading thoughts...
2022-01-17 08:42:36 +08:00
2022-02-04 22:00:13 +08:00
## ✨ Features
2022-01-16 13:33:25 +08:00
2022-03-06 12:07:58 +08:00
- 🦄 Fully open source;
2022-05-29 11:04:58 +08:00
- 👍 Write in the plain textarea without any burden;
2022-05-15 10:54:00 +08:00
- 🤠 Great UI and never miss any detail;
- 🚀 Super quick self-hosted with `Docker` and `SQLite` ;
2022-01-16 13:33:25 +08:00
2022-05-01 11:06:29 +08:00
## ⚓️ Deploy with Docker
2022-04-03 21:54:54 +08:00
2022-05-01 11:06:29 +08:00
```docker
2022-07-09 14:09:40 +08:00
docker run \
--name memos \
--publish 5230:5230 \
--volume ~/.memos/:/var/opt/memos \
neosmemo/memos:latest \
--mode prod \
--port 5230
2022-05-01 11:06:29 +08:00
```
2022-04-03 21:54:54 +08:00
2022-05-20 06:24:47 +08:00
Memos should now be running at [http://localhost:5230 ](http://localhost:5230 ). If the `~/.memos/` does not have a `memos_prod.db` file, then `memos` will auto generate it.
2022-04-03 21:54:54 +08:00
2022-07-09 14:09:40 +08:00
⚠️ Please DO NOT use `dev` of docker image if you have no experience.
2022-05-15 10:54:00 +08:00
## 🏗 Development
Memos is built with a curated tech stack. It is optimized for developer experience and is very easy to start working on the code:
1. It has no external dependency.
2. It requires zero config.
3. 1 command to start backend and 1 command to start frontend, both with live reload support.
### Tech Stack
2022-05-21 12:33:18 +08:00
< img alt = "tech stack" src = "https://raw.githubusercontent.com/usememos/memos/main/resources/tech-stack.png" width = "360" / >
2022-05-15 10:54:00 +08:00
### Prerequisites
- [Go ](https://golang.org/doc/install ) (1.16 or later)
- [Air ](https://github.com/cosmtrek/air#installation ) for backend live reload
- [yarn ](https://yarnpkg.com/getting-started/install )
### Steps
1. pull source code
```bash
2022-05-21 12:33:18 +08:00
git clone https://github.com/usememos/memos
2022-05-15 10:54:00 +08:00
```
2. start backend using air(with live reload)
```bash
air -c scripts/.air.toml
```
3. start frontend dev server
```bash
2022-05-15 15:56:14 +08:00
cd web & & yarn & & yarn dev
2022-05-15 10:54:00 +08:00
```
2022-05-20 06:24:47 +08:00
Memos should now be running at [http://localhost:3000 ](http://localhost:3000 ) and change either frontend or backend code would trigger live reload.
2022-05-15 10:54:00 +08:00
2022-04-03 22:14:43 +08:00
## 🌟 Star history
2022-05-21 12:33:18 +08:00
[![Star History Chart ](https://api.star-history.com/svg?repos=usememos/memos&type=Date )](https://star-history.com/#usememos/memos& Date)
2022-04-03 22:14:43 +08:00
2022-02-04 22:00:13 +08:00
---
Just enjoy it.