# Bifrost
**Repository Path**: getjava/Bifrost
## Basic Information
- **Project Name**: Bifrost
- **Description**: Bifrost ---- 面向生产环境的 MySQL 同步到Redis,ClickHouse,MongoDB等服务的异构中间件
- **Primary Language**: Go
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: http://www.xbifrost.com/
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 97
- **Created**: 2020-12-14
- **Last Updated**: 2020-12-19
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
## Bifrost ---- 面向生产环境的 MySQL 同步到Redis,ClickHouse等服务的异构中间件
[](https://travis-ci.org/brokercap/Bifrost)
[](https://opensource.org/licenses/apache2.0)
[English](https://github.com/brokercap/Bifrost/blob/v1.6.x/README.EN.MD)
##### 漫威里的彩虹桥可以将 雷神 送到 阿斯加德 和 地球
#### 而这个 Bifrost 可以将 你 MySQL 里的数据 全量 , 实时的同步到 :
* Redis
* MongoDB
* ClickHouse
* MySQL
* Memcahe
* RabbitMQ
* ActiveMQ
* Kafka
* [Http 自定义服务](https://github.com/brokercap/Bifrost/blob/v1.6.x/plugin/http/example/http_server/http_server.go)
* [Hprose RPC 自定义服务](https://github.com/brokercap/Bifrost/blob/v1.6.x/hprose_server/tcp_server.go)
---
#### **WIKI** : [https://wiki.xbifrost.com](https://wiki.xbifrost.com)
----
#### Bifrost 特点
* 支持 MySQL 所有存储类型
* **界面化**动态灵活配置不同的数据表及目标库
* 多数据源,**多种目标库**支持
* 同时支持 **增量** 及 **全量** 数据同步
* 一个Binlog解析线程,多个目标库**并行同步**
* 宕机后重启自动恢复配置,位点精确控制
* 支持 Email 及 微信企业号等**监控报警**功能
* 提供第三方监控平台访问接口(Http Basic验证)
#### 源码下载
[Github](https://github.com/brokercap/Bifrost/) , [Gitee](https://gitee.com/jc3wish/Bifrost)
你的点击 star 就是对 Bifrost 最大的支持!!!
#### Bifrost在线界面体验
https://www.xbifrost.com/demo/goto.html
用户名: Bifrost
密码 : Bifrost123

#### *Bifrsot* Diagram

#### MySQL 版本(经过测试)
* 5.1.73
* 5.5.42
* 5.6.36
* 5.7.18
* 8.0.21 (用户密码验证需要采用 mysql_native_password 方式)
#### 安装
##### 编译
```sh
git clone https://github.com/brokercap/Bifrost.git
make install prefix=./target
```
##### 二进制文件安装
`````sh
wget https://github.com/brokercap/Bifrost/releases/download/v1.6.0-release/bifrost_v1.6.0-release_Linux-amd64-bin.tar.gz
tar -zxvf bifrost_v1.6.0-release_Linux-amd64-bin.tar.gz
cd bifrost_v1.6.0-beta.04_Linux-amd64-bin/bin && chmod a+x ./Bifrost*
`````
##### 启动
`````shell
./Bifrost-server start
`````
##### 停止
`````shell
./Bifrost-server stop
`````
##### 界面管理
https://127.0.0.1:21036
用户名和密码是在 etc/Bifrost.ini 配置文件中配置的
默认用户名和密码
用户名:Bifrost
密码:Bifrost123
##### Docker启动
`````shell
docker pull jc3wish/bifrost
mkdir -p /data/BifrostData
docker run -d -p21036:21036 -v /etc/localtime:/etc/localtime -v /data/BifrostData:/linux/data jc3wish/bifrost
`````
##### 配置
`````sh
vim Bifrost.ini
[user]
#登入用户名和密码
#用户名在前,= 号后面是密码
Bifrost=Bifrost123
BifrostMonitor=Bifrost123
[groups]
#administrator 管理人员可以添加删除等操作
#monitor 只能查看数据
Bifrost=administrator
BifrostMonitor=monitor
[Bifrostd]
#log写到入的文件夹,默认为启动文件所在文件夹下的logs目录
#log_dir=/data/log/
#监听端口,默认 0.0.0.0:21036
listen=0.0.0.0:21036
#通过界面配置的信息保存文件夹,默认为启动文件所在文件夹下的data目录
data_dir=./
#设置同步给第三方服务的队列大小,默认5000
toserver_queue_size=10000
#通道队列的大小,默认1000
channel_queue_size=1000
#是否支持动态加plugin so 插件,默认为false
#这个参数只在 linux 下有效,其他平台全部为false
dynamic_plugin=false
#是否支持https
tls=true
#server.key 及 server.crt 相对于 Bifrost 的路径,也可以填绝对路径
tls_key_file=./etc/server.key
tls_crt_file=./etc/server.crt
#是否开启文件队列功能 true|false
file_queue_usable=true
#统计是否启文件队列的时间,单位毫秒
file_queue_usable_count_time_diff=5000
#file_queue_usable_count_time_diff 时间内内存队列被挤满的次数
file_queue_usable_count=10
#采用什么方式存储,默认文件方式
meta_storage_type=redis
#存储介质的连接地址
meta_storage_path=127.0.0.1:6379
#用于区别实例的名字
cluster_name=bifrostTestClusterName
#是否开启文件队列功能 true|false
file_queue_usable=true
#统计是否启文件队列的时间,单位毫秒
file_queue_usable_count_time_diff=5000
#file_queue_usable_count_time_diff 时间内内存队列被挤满的次数
file_queue_usable_count=10
#在没有数据的情况下,间隔多久提交一次插件,单位 秒
plugin_commit_timeout=5
#在同步出错的情况下,每2次重试之后 间隔多久再重试 ,单位 秒
plugin_sync_retry_time=5
`````
##### 生成https证书
[参考证书生成](https://wiki.xbifrost.com/install/https_certificate/)
### 感谢相关依赖包提供者
- github.com/gmallard/stompngo
- github.com/hprose/hprose-golang
- github.com/Shopify/sarama
- github.com/bradfitz/gomemcache/memcache
- gopkg.in/mgo.v2
- github.com/streadway/amqp
- github.com/go-redis/redis
- github.com/syndtr/goleveldb/leveldb
- github.com/ClickHouse/clickhouse-go
### QQ群号: 70331601
### 捐赠
![]() |
![]() |