首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

一行代码实现Okhttp,Retrofit,Glide下载上传进度监听

原文地址: http://www.jianshu.com/p/5832c776621f qq群:301733278 前言 发表上篇文章 我一行代码都不写实现Toolbar!...主要是通过 Okhttp 实现,如同吃了定心丸,瞬间舒坦 需求 2 (减小体积) 这个需求 Google 了下,也非常简单,用 provided 依赖框架,打包时依赖的框架就不会包含进去 需求 3 (一行代码实现...的 Api 来设计,用户只用一行代码,传入一个 标记 和一个 事件 即可实现上传和下载进度监听,没错 标记 就是 Url , 事件 就是用于获取进度信息的 监听器,这样也就满足了 需求 3 的一行代码实现的需求...Like this ProgressManager.post(标记,事件); 用户调用这一行代码后,我会将 Url 作为 Key,监听器 作为 value 放入一个全局唯一的 Map 中 等等?...代替之前的 Map 容器,这个 WeakHashMap 会在 Java虚拟机 回收内存时,找到没被使用的 Key,将此条目整个移除,所以不需要手动 remove() 加锁 在上面提到用户只需要一行代码

73520

1 监听mysql表内容变化,mysql开启binlog

可以看到,只要有了这个binlog,我们就拥有了mysql的完整备份了。 我们时常会碰到这样的需求,就是要监听某个表的变化,然后来做一些操作。...如果该表数据只增加、不删除修改的话,要监听比较简单,可以定时去查询最新的id即可。但要有删除、修改操作的话,免不了就得全表扫描,效率极低。倘若该表发生变化时,能触发个事件之类的可供监听,那最好不过。...监听binlog的变化即可,这样每次执行了什么语句都会提现在binlog里,我们就能监听到了。 binlog默认是关闭的,我们要开启它,就需要来修改mysql的配置文件。...然后通过brew restart mysql重启mysql。...只有了binlog,那还是不够的,我们还需要一个监听binlog的工具。

3.2K10

1 监听mysql表内容变化,mysql开启binlog

可以看到,只要有了这个binlog,我们就拥有了mysql的完整备份了。 我们时常会碰到这样的需求,就是要监听某个表的变化,然后来做一些操作。...如果该表数据只增加、不删除修改的话,要监听比较简单,可以定时去查询最新的id即可。但要有删除、修改操作的话,免不了就得全表扫描,效率极低。倘若该表发生变化时,能触发个事件之类的可供监听,那最好不过。...监听binlog的变化即可,这样每次执行了什么语句都会提现在binlog里,我们就能监听到了。 binlog默认是关闭的,我们要开启它,就需要来修改mysql的配置文件。...然后通过brew restart mysql重启mysql。再通过mysql -uroot -p命令进入mysql控制台,执行 show variables like '%log_bin%' ; ?...只有了binlog,那还是不够的,我们还需要一个监听binlog的工具。下一篇来看canal

3.4K60

MySQL监听端口的一个场景

这两天配合解决一个GreatDB端口的问题,碰巧看到爱可生开源社区的这篇文章《故障分析 | MySQL监听端口故障排查》,同样介绍了一个MySQL数据库端口的问题,问题不是很复杂,但这个场景,确实很少碰到...02:43:20  /mysqldata/mysql/base/8.0.24/bin/mysqld --defaults- file=/mysqldata/mysql/etc/3308/my.cnf -...-daemonize --pid- file=/mysqldata/mysql/data/3308/mysqld.pid --user=mysql -- socket=/mysqldata/mysql/...=3308 (2) 排查端口绑定情况,居然没有绑定端口, [root@wx ~]# lsof -i:3308 [root@wx ~]# ss -nltp|grep 3308 (3) 查看启动日志发现,监听端口等于...Version: '8.0.24' socket: '/mysqldata/mysql/data/3306/mysqld.sock' port: 0 MySQL Community Server - GPL

68710

SpringBoot系列之集成阿里canal监听MySQL Binlog

引用官网的图片,canal的工作原理主要是模拟 MySQL slave 的交互协议,伪装自己为 MySQL slave,向master发送dump 协议,获取到数据后,解析 binary log 对象数据...使用canal需要确保数据库开启了binlog: show variables like'log_%'; 如果没开启,在mysql my.ini配置文件添加配置,注意文件内存为的时候,注意编码格式必须为...ANSI,不然会编译报错 [mysqld] # 开启 binlog log-bin=mysql-bin # 选择 ROW 模式 binlog-format=ROW # 配置 MySQL replaction...需要定义,不要和 canal 的 slaveId 重复 server_id=1 配置文件修改是否正确,使用命令,查看日志 mysqld --console 重启MySQL实例 net stop mysql...net start mysql binlog开启后,创建一个canal用户并授权,官网配置是@%,表示所有服务器,因为本地测试的,所以改为localhost就可以 CREATE USER canal

1.3K20

mysql一行记录是怎么存储的?

mysql一行记录,最终肯定是存储在磁盘上,也就是肉眼可见的文件上,今天我们的目标很简单,就是看看它到底是怎么存的。...猜测下这部分就是每一行的记录信息吧。 我们插入了七条数据,我发现这些二进制串有一段可以分割成七对,我把他单独拿出来,并且按行分割。 ? 我们将第一行记录拆解,第一行记录的表数据是这样的。...我找到了源码,还是很清晰的,注释上就写明了每一行记录的磁盘数据格式,太好了,不用看代码了。 ? 再贴上刚刚的第一行记录。...行记录格式整体结构 总结下,整个一行记录的格式,叫做 mysql 的行记录格式,ROW_FORMAT。...就是 mysql 规定了一种将一行记录存储在磁盘中的格式,以便于 mysql 自己的程序可以根据这个结构认识这一行记录。

1.7K30
领券