Live Demo • Install • Help • Development • Design Doc
Bytebase is a web-based, zero-config, dependency-free database schema change and version control management tool for the DevOps team.
Regardless of working as an IC in a team or managing your own side project, developers using Bytebase will have a holistic view of all the related database info, the ongoing database schema change tasks and the past database migration history.
A collaborative web-console to allow DBAs to manage database tasks and handle developer tickets much more efficiently than traditonal tools.
Teams using Bytebase will naturally adopt industry best practice for managing database schema changes. Tech leads will see an improved development velocity and reduced outages caused by database changes.
✅ MySQL ✅ PostgreSQL ✅ TiDB ✅ ClickHouse ✅ Snowflake
Database-as-Code, login with VCS account, project membership sync.
✅ GitLab CE/EE ✅ GitHub.com
- Web-based database change and management workspace for teams
- SQL Review
- UI based change workflow
- Version control based change workflow (Database-as-Code)
- SQL Review Rules
- Built-in SQL Editor
- Detailed migration history
- Multi-tenancy (rollout change to homogeneous databases belonged to different tenants)
- Backup and restore
- Point-in-time recovery (PITR)
- Anomaly center
- Environment policy
- Approval policy
- Backup schedule enforcement
- Schema drift detection
- Backward compatibility schema change check
- Role-based access control (RBAC)
- Webhook integration for Slack, Discord, MS Teams, DingTalk(钉钉), Feishu(飞书), WeCom(企业微信)
In particular, get familar with various product concept such as data model, roles and permissions and etc.
https://github.com/bytebase/bytebase/tree/main/docs/design
https://github.com/bytebase/bytebase/tree/main/docs/version-management.md
-
Checkout issues tagged with good first issue.
-
We are maintaining an online database glossary list, you can add/improve content there.
Note: We are quite disciplined on tech stack. If you consider bringing a new programming language, framework and any non-trivial external dependency, please open a discussion first.
Bytebase is built with a curated tech stack. It is optimized for developer experience and is very easy to start working on the code:
- It has no external dependency.
- It requires zero config.
- 1 command to start backend and 1 command to start frontend, both with live reload support.
-
Tech Stack
-
Data Model
-
Install Air v1.30.0. Use 1.30.0 because the newer version changes the behavior and won't shutdown the previous service properly.
go install github.com/cosmtrek/[email protected]
-
Pull source.
git clone https://github.com/bytebase/bytebase
-
Start backend using air (with live reload).
air -c scripts/.air.toml
Change the open file limit if you encounter "error: too many open files".
ulimit -n 10240
If you need additional runtime parameters such as --backup-bucket, please add them like this:
air -c scripts/.air.toml -- --backup-region us-east-1 --backup-bucket s3:\\/\\/example-bucket --backup-credential ~/.aws/credentials
-
Start frontend (with live reload).
cd frontend && pnpm i && pnpm dev
Bytebase should now be running at http://localhost:3000 and change either frontend or backend code would trigger live reload.
-
(Optional) Install pre-commit.
cd bytebase pre-commit install pre-commit install --hook-type commit-msg
Check out our jobs page for openings.