当前位置: 首页 > news >正文

成都蜀美网站建设手机在线制作网站

成都蜀美网站建设,手机在线制作网站,重庆专业网站营销,郑州网站制作招聘座右铭:《坚持有效输出,创造价值无限》 最近想了解下canal,自行搭建并完成数据同步。经过了几天的踩坑之旅,今天终于搭建成功了。 环境:canalv1.1.5、MySQL8.0、JDK1.8 安装MySQL 创建存放目录 mkdir /docker-localm…

座右铭:《坚持有效输出,创造价值无限》

最近想了解下canal,自行搭建并完成数据同步。经过了几天的踩坑之旅,今天终于搭建成功了。

环境:canalv1.1.5、MySQL8.0、JDK1.8

安装MySQL

创建存放目录

mkdir /docker-local
mkdir /docker-local/mysql8

之前安装过MySQL,但是没有配置conf,使用canal需要指定一个serveid

docker run --privileged=true -it \-p 3306:3306 --name mysql \-e MYSQL_ROOT_PASSWORD=123456 \-v /docker-local/mysql8/conf:/etc/mysql/conf.d \-v /docker-local/mysql8/data:/var/lib/mysql \-d mysql:8.0.26

编辑my.cnf

cd /docker-local/mysql8/conf
vim my.cnf
[mysqld]
server-id=1

保存,重启mysql

docker restart mysql

创建用户

创建用户,方便canal使用

CREATE USER canal IDENTIFIED BY 'canal';
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';
FLUSH PRIVILEGES;

注意:安装canal还需要开启binlog,因为mysql8.0默认是开启的,并且是row模式,所以我这里没有其他操作。

安装canal

创建存放目录

mkdir docker-local/canal
cd /docker-local/canal/

拉取镜像

docker pull canal/canal-server:v1.1.5

运行

docker run --name canal -d canal/canal-server:v1.1.5

复制容器中的配置文件到本地

docker cp canal:/home/admin/canal-server/conf/canal.properties /docker-local/canal
docker cp canal:/home/admin/canal-server/conf/example/instance.properties /docker-local/canal

修改instance.properties

vim instance.properties

在这里插入图片描述

停止

docker stop canal && docker rm canal

重新运行

docker run --name canal -p 11111:11111 \
-v /docker-local/canal/instance.properties:/home/admin/canal-server/conf/example/instance.properties \
-v /docker-local/canal/canal.properties:/home/admin/canal-server/conf/canal.properties \
-v /docker-local/canal/log/:/home/admin/canal-server/logs/ \
-d canal/canal-server:v1.1.5

查看启动日志

cat log/canal/canal.log

在这里插入图片描述

cat /docker-local/canal/log/example/example.log

遇到的问题

connect /192.168.64.139:3306 failure

Caused by: java.io.IOException: connect /192.168.64.139:3306 failure

发现canal连不上mysql

修改firewalld配置文件

vim /etc/firewalld/zones/public.xml

增加3306端口

<port protocol="tcp" port="3306"/>

在这里插入图片描述

重启firewalld

systemctl restart firewalld

再次查看日志

在这里插入图片描述

部署成功

问题原因

在centos7上部署docker容器,其网络模式采用的是bridger模式。

启动docker时,docker进程会创建一个名为docker0的虚拟网桥,用于宿主机与容器之间的通信。当启动一个docker容器时,docker容器将会附加到虚拟网桥上,容器内的报文通过docker0向外转发。

如果docker容器访问宿主机,那么docker0网桥将报文直接转发到本机,报文的源地址是docker0网段的地址。而如果docker容器访问宿主机以外的机器,docker的SNAT网桥会将报文的源地址转换为宿主机的地址,通过宿主机的网卡向外发送。

当docker容器访问宿主机时,如果宿主机服务端口会被防火墙拦截,无法连通宿主机,出现No route to host的错误。

而访问宿主机所在局域网内的其他机器,由于报文的源地址是宿主机ip,因此,不会被目的机器防火墙拦截,所以可以访问。

也可以开放对应的端口

firewall-cmd --zone=public --add-port=3306/tcp --permanent
firewall-cmd --reload

卸载canal

docker stop canal && docker rm canal
rm -rf /docker-local/canal

这里,我一直认为我本地可以连接到mysql,就不用开启端口了。
至此,就搭建完成了。

http://www.yidumall.com/news/107930.html

相关文章:

  • 网站首页做多大分辨率网络推广的渠道有哪些
  • 织梦做的网站别人提交给我留的言我去哪里看广点通
  • 建设旅游网站的目的和意义百度热搜榜今日头条排名
  • 石家庄网站建设多少钱网络推广公司收费标准
  • 做棋牌网站建设百度热搜风云榜
  • 贵阳h5网站建设搜索引擎的四个组成部分及作用
  • 百度网站制作公司玉林seo
  • 做系统之前的网站收藏在哪里看互联网销售公司
  • 公司网站开发说明介绍郑州百度搜索优化
  • 自媒体营销的策略和方法百度关键词相关性优化软件
  • 网站建设 文章网站404页面怎么做
  • 自我做t恤的网站沪深300指数基金
  • 做网站要学哪些百度搜索指数查询
  • 改号宝网站搭建百度网站优化排名
  • 金融网站开发方案广州从化发布
  • 极速时时彩网站开发百度网盘怎么找片
  • 做网站厦门收录优美图片崩了
  • 深圳网站设计公司 网络服务沪深300指数基金排名
  • 做购物商城类网站需要合肥关键词排名推广
  • 网站栏目 英文seo公司关键词
  • 做字幕网站微信crm管理系统
  • wordpress cms怎么登陆界面网络营销就是seo正确吗
  • asp网站后台登陆地址百度在线
  • 网站备案 时间更新广州百度seo公司
  • 西宁电子商务网站建设女排联赛最新排行榜
  • 陕西网站建设热线百度用户服务中心
  • 做网站优化有必要西安网站外包
  • 做资讯类网站需要特殊资质吗网络推广和网站推广平台
  • 规划网站的总结优化疫情防控 这些措施你应该知道
  • 做网站能拿多少钱信息流广告优化师