t_demo_travel_record_child" dataNode="dn1,dn2,dn3" rule="auto-sharding-long" />
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> select user() 192.168.31.187:3307" user="root" password="root123"> writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> select user() 192.168.31.212:3307" user="root" password="root123"> writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> select user() 192.168.31.150:3307" user="root" password="root123">
rule.xml
id rang-long
class="org.opencloudb.route.function.AutoPartitionByLong"> autopartition-long.txt 0
autopartition-long.txt
# range start-end ,data node index # K=1000,M=10000. 0-500M=0 500M-1000M=1 1000M-1500M=2
2.1 模拟在3个数据库上保存了200多万条记录,验证下数据库查询的响应。
物理库上数据情况
VM1 192.168.31.187:3307 保存了74.8万条记录
mysql> SELECT min(id),max(id),count(1) FROM test.t_demo_travel_record;
+---------+---------+----------+
| min(id) | max(id) | count(1) |
+---------+---------+----------+
| 10000 | 5000000 | 748002 |
+---------+---------+----------+
1 row in set (0.16 sec)
VM2 192.168.31.212:3307 保存了74.9万条记录
mysql> SELECT min(id),max(id),count(1) FROM test.t_demo_travel_record;
+---------+----------+----------+
| min(id) | max(id) | count(1) |
+---------+----------+----------+
| 5000001 | 10000000 | 749500 |
+---------+----------+----------+
1 row in set (0.17 sec)
VM3 192.168.31.150: 3307 比VM2少一条记录
mysql> SELECT min(id),max(id),count(1) FROM test.t_demo_travel_record;
+----------+----------+----------+
| min(id) | max(id) | count(1) |
+----------+----------+----------+
| 10000001 | 14991498 | 749499 |
+----------+----------+----------+
1 row in set (0.17 sec)
MYCAT 192.168.31.207: 8806 一共224.7万条记录,最大记录从 VM1 结点获取,最大记录从 VM3 结点获取
mysql> SELECT min(id),max(id),count(1) FROM t_demo_travel_record;
+-------+----------+---------+
| MIN0 | MAX1 | COUNT2 |
+-------+----------+---------+
| 10000 | 14991498 | 2247001 |
+-------+----------+---------+
1 row in set (0.31 sec)
在MYCAT中进行不指定排序的分页查询 ,从第100万条记录开始取100,浩时1.5秒,好久~~
mysql> select * from t_demo_travel_record where id between 4999980 and 14999980 limit 1000000,100;
+----------+------------------+
| id | context |
+----------+------------------+
| 13341025 | context_13341025 |
| 13341026 | context_13341026 |
| 13341027 | context_13341027 |
| 13341028 | context_13341028 |
| 13341029 | context_13341029 |
....
| 8320686 | context_8320686 |
| 8320687 | context_8320687 |
| 8320688 | context_8320688 |
| 8320689 | context_8320689 |
+----------+------------------+
100 rows in set (1.50 sec)
看下日志,MYCAT是把 limit 1000000,100 改为 limit 0 , 1000100 往物理库中发送,速度一个字:不慢才怪。
02/02 23:41:47.958 DEBUG [$_NIOREACTOR-2-RW] (ServerQueryHandler.java:56) -ServerConnection [id=12, schema=TESTDB, host=192.168.31.207, user=test,txIsolation=3, autocommit=true, schema=TESTDB]select * from t_demo_travel_record where id between 4999980 and 14999980 limit 1000000,100
02/02 23:41:47.958 DEBUG [$_NIOREACTOR-2-RW] (EnchachePool.java:70) -SQLRouteCache hit cache ,key:TESTDBselect * from t_demo_travel_record where id between 4999980 and 14999980 limit 1000000,100
02/02 23:41:47.958 DEBUG [$_NIOREACTOR-2-RW] (NonBlockingSession.java:113) -ServerConnection [id=12, schema=TESTDB, host=192.168.31.207, user=test,txIsolation=3, autocommit=true, schema=TESTDB]select * from t_demo_travel_record where id between 4999980 and 14999980 limit 1000000,100, route={
1 -> dn1{SELECT *
FROM t_demo_travel_record
WHERE id BETWEEN 4999980 AND 14999980
LIMIT 0, 1000100}
2 -> dn2{SELECT *
FROM t_demo_travel_record
WHERE id BETWEEN 4999980 AND 14999980
LIMIT 0, 1000100}
3 -> dn3{SELECT *
FROM t_demo_travel_record
WHERE id BETWEEN 4999980 AND 14999980
LIMIT 0, 1000100}
} rrs
02/02 23:41:47.958 DEBUG [$_NIOREACTOR-2-RW] (MultiNodeQueryHandler.java:82) -execute mutinode query select * from t_demo_travel_record where id between 4999980 and 14999980 limit 1000000,100
02/02 23:41:47.958 DEBUG [$_NIOREACTOR-2-RW] (MultiNodeQueryHandler.java:97) -has data merge logic
02/02 23:41:47.961 DEBUG [$_NIOREACTOR-3-RW] (MultiNodeQueryHandler.java:241) -on row end reseponse MySQLConnection [id=19, lastTime=1454427707947, user=root, schema=test, old shema=test, borrowed=true, fromSlaveDB=false, threadId=36, charset=utf8, txIsolation=3, autocommit=true, attachment=dn1{SELECT *
FROM t_demo_travel_record
WHERE id BETWEEN 4999980 AND 14999980
LIMIT 0, 1000100}, respHandler=org.opencloudb.mysql.nio.handler.MultiNodeQueryHandler@24e67429, host=192.168.31.187, port=3307, statusSync=null, writeQueue=0, modifiedSQLExecuted=false]
这里进行数据合并,好在使用了auto-sharding-long模式,如果是sharding-by-mod模式的话,数据是非连续离散在不同数据结点中,那合并起来就更慢了。
在大数据量分片分页查询时,MYCAT 可能会存在效率与内存占用问题。
02/02 23:41:49.392 DEBUG [BusinessExecutor6] (DataMergeService.java:296) -prepare mpp merge result for select * from t_demo_travel_record where id between 4999980 and 14999980 limit 1000000,100
02/02 23:41:49.393 DEBUG [BusinessExecutor6] (MultiNodeQueryHandler.java:324) -last packet id:105
你可能感兴趣的:(MySql,MyCat)
MySQL Buffer Pool、Undo Log、脏页详解
学堂在线
Mysql 数据库 mysql 数据库
文章目录1.BufferPool2.UndoLog3.脏页(DirtyPage)三者的协同工作常见问题总结MySQL中的BufferPool、UndoLog和脏页是InnoDB存储引擎的核心组件,共同保障了事务处理的高效性、一致性与持久性。以下是它们的详细解释及关联:1.BufferPool作用:BufferPool是InnoDB的内存缓存区域,用于缓存数据页和索引页,减少直接访问磁盘的开销,显著
【MYSQL学习】MySQL索引:删除索引的5大绝招你GET到了吗?
墨瑾轩
MySql入门~精通 mysql 学习 数据库
关注墨瑾轩,带你探索编程的奥秘!超萌技术攻略,轻松晋级编程高手技术宝库已备好,就等你来挖掘订阅墨瑾轩,智趣学习不孤单即刻启航,编程之旅更有趣MySQL索引:删除索引的5大绝招你GET到了吗?引言❓在数据库操作中,索引是一个非常重要的概念。合理的索引设计可以显著提高查询性能,而不合理的索引则可能导致性能下降。但你知道如何有效地删除索引吗?今天,我们就来一场深入浅出的探索之旅,带你了解删除索引的5大绝
Mysql-InnoDB索引:普通索引、主键索引、唯一索引、组合索引
豪大大ya
mysql 数据库 java
InnoDB和MyISAM的区别事务方面InnoDB支持事务,MyISAM不支持事务。这是Mysql将默认存储引擎从MyISAM变成InnoDB的重要原因之一外键方面InnoDB支持外键,而MyISAM不支持。对一个包含外键的InnoDB表转为MyISAM会失败索引层面InnoDB是聚集(聚簇)索引,MyISAM是非聚集(非聚簇)索引。MyISAM支持FULLTEXT类型的全文索引。InnoDB不
3-002: MySQL 中使用索引一定有效吗?如何排查索引效果?
盖盖衍上_染染熊_代码集
00-刷题 mysql 数据库
1.索引失效的常见原因虽然索引可以加速查询,但在某些情况下,MySQL可能不会使用索引,甚至使用索引反而更慢。以下是一些常见导致索引失效的原因:①查询条件使用了!=或30时仍能利用索引。2.如何排查索引效果?可以使用EXPLAIN命令分析SQL是否走索引,以及索引的效率。①使用EXPLAIN分析SQL执行计划EXPLAINSELECT*FROMusersWHEREage=30;返回示例:idsel
4-002:如何使用 MySQL 的 EXPLAIN 语句进行查询分析?
盖盖衍上_染染熊_代码集
00-刷题 mysql 数据库
EXPLAIN是MySQL中用于分析查询性能的工具,能够帮助你理解查询的执行计划。通过EXPLAIN,你可以查看MySQL如何执行查询,包括使用的索引、表连接顺序等信息。基本用法在查询前加上EXPLAIN即可:EXPLAINSELECT*FROMyour_tableWHEREyour_column='value';输出字段说明EXPLAIN的输出包含多个字段,以下是主要字段及其含义:id:查询标识
MySQL 的索引数量是否越多越好
Zero_pl
Mysql基础知识 面试题 mysql 数据库
MySQL的索引并不是越多越好,索引数量需要根据查询需求合理设置。虽然索引可以提高查询效率,但过多的索引也会带来额外的开销,影响数据库的性能。✅索引的优点提高查询速度索引类似于书籍的目录,可以快速查找数据,减少查询时间。如SELECT*FROMusersWHEREemail='
[email protected] ';,如果email字段有索引,MySQL可以直接找到匹配数据,否则需要全表扫描。加速排序(
4-001:MySQL 中的索引数量是否越多越好?为什么?
盖盖衍上_染染熊_代码集
00-刷题 mysql 数据库
MySQL中的索引并不是越多越好,索引数量要合理控制!过多索引的影响增加存储开销每个索引都会占用额外的磁盘空间,索引多了,存储成本增加。降低INSERT、UPDATE、DELETE性能任何涉及数据修改的操作,都需要同时更新索引,影响性能。示例:INSERTINTOusers(id,name)VALUES(1,'Tom');,如果users表有多个索引,则插入时每个索引都需要更新,影响插入速度。可能
ES 使用geo point 查询离目标地址最近的数据
DavidSoCool
elasticsearch Mysql elasticsearch 搜索引擎 mysql
需求描述:项目中需要通过经纬度坐标查询目标地所在的行政区。解决思路大致有种,使用es和mysql分别查询。1、使用es进行查询将带有经纬度坐标的省市区数据存入es中,mappings字段使用geopoint类型,索引及查询dsl如下。geopoint文档地址:Geo-distancequery|ElasticsearchGuide[8.6]|ElasticSortsearchresults|Ela
MySQL锁
开发小呆瓜
数据库 数据库 mysql
一、MySQL锁的分类1.按锁的粒度说明适用引擎表锁锁定整个表,并发性低,但开销小。MyISAM、InnoDB(部分场景)行锁仅锁定需要操作的行,并发性高,但开销较大。InnoDB页锁锁定数据页(介于表锁和行锁之间),较少使用。BDB(已废弃)2.按锁的模式说明共享锁(S锁)允许其他事务读取被锁定的行,但禁止修改(读锁)。排他锁(X锁)禁止其他事务读取或修改被锁定的行(写锁)。二、锁的应用场景1.
FLASK,ORM(mysql),12条查询练习语句
毛毛是一只狗
《Python专栏》 flaskORM
ORM查询语句练习,创表数据在flask课件里,在我资源里可以下载查询所有用户数据查询有多少个用户查询第1个用户查询id为4的用户[3种方式]查询名字结尾字符为g的所有数据[开始/包含]查询名字不等于wang的所有数据[2种方式]查询名字和邮箱都以li开头的所有数据[2种方式]查询password是123456或者email以itheima.com结尾的所有数据查询id为[1,3,5,7,9]的用
使用 Golang 操作 MySQL
yinhezhanshen
golang mysql 开发语言
在Go语言中,操作SQL数据库,通常会用到一些第三方库来简化数据库的连接、查询和操作过程。其中原生的database/sql+go-sql-driver/mysql库更符合sql语句使用习惯。安装gogetgithub.com/go-sql-driver/mysql直接上代码来演示基本的创建,插入,更新,删除操作。packagemainimport("database/sql""fmt"_"gi
MySQL 技术浅析(聚簇索引、UndoLog、RedoLog、MVCC)
代码没写完哪有脸睡觉
mysql 数据库
MySQL核心技术深度解析一、聚簇索引与非聚簇索引1.聚簇索引结构存储方式InnoDB中,聚簇索引的叶子节点直接存储完整数据行,数据按主键值物理排序存储。主键索引即数据文件,非叶子节点存储主键范围和子节点指针数据行与主键索引绑定,主键顺序决定磁盘存储顺序示例存储结构B+树结构:根节点→[id20;--索引设计为(name,age)2.事务控制建议控制事务粒度:单个事务执行时间<1秒批量操作分批次提
RabbitMQ实战(二)-消息持久化策略、事务以及Confirm消息确认方式
Java思享汇
RabbitMQ学习 RabbitMQ 消息持久化 事务 confirm ack
「扫码关注我,面试、各种技术(mysql、zookeeper、微服务、redis、jvm)持续更新中~」RabbitMQ学习列表:RabbitMQ实战(一)-消息通信基本概念·在上一篇学习完RabbitMQ通信的基本概念后,我们来继续学习消息的持久化以及代码实现RabbitMQ通信。在正常生产环境运维过程中无法避免RabbitMQ服务器重启,那么,如果RabbitMQ重启之后,那些队列和交换器就会
MySql的MVCC实现原理
zyrr
mysql mysql mvcc java
MySql的MVCC实现原理前言MVCC解决什么问题MVCC的实现3个隐式字段UndoLogReadView读视图大致流程读已提交和可重复隔离级别下的快照读前言什么是MVCC?MVCC(Multi-VersionConcurrencyControl)即多版本并发控制,是乐观锁的一种实现方式,在MySql数据库中主要是为了提高数据库的并发性能,做到读写冲突不加锁,这里的读指的是快照读。快照读与当前读
快速上手:ASP.NET Core MVC 与 EF Core 操作 MySQL 数据库完整实例
殷连靖Harlan
快速上手:ASP.NETCoreMVC与EFCore操作MySQL数据库完整实例【下载地址】ASP.NETCoreMVC使用EF操作MySQL数据库完整实例ASP.NETCoreMVC使用EF操作MySQL数据库完整实例本资源提供了一套完整的示例项目,展示了如何在ASP.NETCoreMVC应用程序中使用EntityFramework(EF)来操作MySQL数据库项目地址:https://gitc
MySQL索引最左原则:从原理到实战的深度解析
MySQL索引最左原则:从原理到实战的深度解析一、什么是索引最左原则?索引最左原则是MySQL复合索引使用的核心规则,简单来说:"当使用复合索引(多列索引)时,查询条件必须从索引的最左列开始,且不能跳过中间的列,否则索引将无法完全生效"为什么会有这个原则?这与B+树索引的存储结构密切相关:复合索引按照定义时的列顺序构建数据先按第一列排序第一列相同的情况下按第二列排序依此类推形成层级结构二、3种典型
【MySQL】MVCC详解与MVCC实现原理(MySQL专栏启动)
2401_89317296
mysql android 数据库
如果此文还不错的话,还请关注、点赞、收藏三连支持一下博主~本文目录本文导读一、什么是MVCC二、MVCC的实现原理1、MVCC多版本实现2、MVCC实现原理3、什么是ReadView3.1、ReadView解析3.2、ReadView含义3.3、ReadView如何判断版本链可用三、当前读,快照读与MVCC1、什么是当前读和快照读
SeaTunnel社区「Demo方舟计划」第2期活动上线—— MySQL同步至MySQL数据合并场景实战
数据库
引言凌晨3点,某金融公司的数据工程师老王盯着屏幕上的报错信息陷入绝望——从32个分库同步的用户交易数据,在合并至中心MySQL表时,因主键冲突导致每天近10万条数据丢失。业务方投诉不断,而他能找到的解决方案,要么是REPLACEINTO性能低下,要么是INSERTIGNORE无法追溯冲突数据。这并非孤例,可能大部分新接触数据同步的工程师都会遇到以下情况:72%在分库分表合并场景中遭遇过主键冲突导致
Linux---sqlite3数据库
磨十三
数据库 linux sqlite
一、数据库分类1.按数据关系分类类型特点代表产品关系型数据库-使用SQL(结构化查询语言)-数据以行列形式存储,支持事务和复杂查询MySQL、Oracle、SQLite非关系型数据库-无固定表结构(如键值对、文档、图)-高扩展性,适合非结构化数据MongoDB、Redis2.按功能规模分类类型特点代表产品大型数据库高并发、高可用性,支持企业级应用Oracle、DB2中型数据库适用于中小型企业,跨平
为什么会出现redis数据库?redis是什么?
Foolforuuu
数据库 redis 缓存
什么是Redis?为什么要用Redis?下面我将从Redis出现的背景、Redis的解决方案个来回答。1、Redis出现的背景互联网的应用越来越多,例如社交网络、电商、实时服务发展的十分迅速,这就导致了传统技术栈(如关系型数据库)面临许多挑战:性能瓶颈:并发、低延迟需求激增(如电商秒杀、社交平台动态刷新)。传统关系型数据库(如MySQL)依赖磁盘IO,无法应对每秒数万次的读写请求,导致响应延迟和扩
【MySQL基础】数据库与表的基本操作:从创建到管理
是阿川啊
零基础学MySQL 数据库 mysql sql
文章目录写在前面:1、数据库的创建和管理1.创建数据库:CREATEDATABASE注意事项:2.查看已有数据库:SHOWDATABASES3.删除数据库:DROPDATABASE防止误删4.总结2、表的创建与管理1.创建数据表:CREATETABLE2.查看表结构:DESCRIBE表名3.删除数据表:DROPTABLE4.修改表结构:ALTERTABLE4.1添加新列4.2删除列4.3修改列的数
Linux系统下如何部署svmspro平台
安防视频中间件/视频资源汇聚平台
linux adb 运维 实时音视频 SVMSPro 信息可视化
上传svmspro服务rz回车后选择svmspro.zip上传如果提示rz命令未找到,请先运行`yuminstall-ylrzsz`安装将svmspro.zip解压出来,并拷贝到/usr/目录下,命令如下:unzipsvmspro.zip//解压程序包cpsvmspro/usr/-r//将svmspro文件夹拷贝到/usr/目录下,方便后续设置成服务安装mysql数据库,SVMSProlinux需
php mysql中几个版本的进化史_PHP 进化史 — 从 v5.6 到 v8.0
插门胡的小背心
php mysql中几个版本的进化史
在此篇文章中,我们将用15分钟对PHPv7.x版本更改进行简要回顾。PHP7.3版本发布后,为了更好地理解这门广泛流行的编程语言的新特性和优化之处,我决定详细地研究下PHP开发:正在开发什么以及其开发方向。在查看了PHP在PHP7.x版本开发过程中实现的一系列特性的简要列表之后,我决定自己整合这个列表作为一个很好的补充,我相信也会有人觉得有用的。我们将从PHP5.6作为基准开始,研究添加或者更改了
生产环境使用k3s避雷指南:避免数据丢失与不可恢复
后端运维数据库
1.存储安全:避免数据丢失的核心1.1必须使用持久化存储问题:k3s默认使用临时存储(如emptyDir),容器重启后数据会丢失。解决方案:生产环境必须使用持久化存储卷(PVC),并绑定到可靠的存储后端(如云厂商的块存储、NFS、Longhorn等)。示例:在MySQL/Redis的Deployment中,替换emptyDir为持久化PVC:volumes:-name:mysql-datapers
基于k3s部署Nginx、MySQL、PHP和Redis的详细教程
先决条件一台Linux服务器(或本地虚拟机),建议Ubuntu/CentOS基础命令行操作能力确保服务器有至少2GB内存和10GB磁盘空间1.安装k3s(极简Kubernetes)1.1一键安装#用root用户或sudo权限执行以下命令curl-sfLhttps://get.k3s.io|sh-解释:k3s是一个轻量级Kubernetes发行版,专为资源有限的环境设计这条命令会自动下载并安装k3s
生产环境使用k3s避雷指南:避免数据丢失与不可恢复
dblens 数据库管理和开发工具
k3s 系统架构 k8s
1.存储安全:避免数据丢失的核心1.1必须使用持久化存储问题:k3s默认使用临时存储(如emptyDir),容器重启后数据会丢失。解决方案:生产环境必须使用持久化存储卷(PVC),并绑定到可靠的存储后端(如云厂商的块存储、NFS、Longhorn等)。示例:在MySQL/Redis的Deployment中,替换emptyDir为持久化PVC:volumes:-name:mysql-datapers
【MySQL】表的约束
熙曦Sakura
MySQL mysql android oracle
5.表的约束真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。表的约束很多,这里主要介绍如下几个:null/notnull,default,comment,zerofill,primarykey,auto_increment,uniquekey。5.1空属性两个值:null(默认
SpringBoot整合Hutool实现文件上传下载
晚上睡不着!
# SpringBoot 笔记
前言我相信我们在日常开发中,难免会遇到对各种媒体文件的操作,由于业务需求的不同对文件操作的代码实现也大不相同数据库设计/*NavicatPremiumDataTransferSourceServer:MySQL5.5SourceServerType:MySQLSourceServerVersion:50554(5.5.54)SourceHost:localhost:3306SourceSchema
mysql主从切换 日志_mysql笔记之主从切换
新德里的雨
mysql主从切换 日志
一、正常切换1)从服务器检查SHOWPROCESSLIST语句的输出,直到你看到HasreadallrelaylogwaitingfortheslaveI/Othreadtoupdateit2)确保从服务器已经处理了日志中的所有语句。mysql>STOPSLAVEIO_THREAD当从服务器都执行完这些,它们可以被重新配置为一个新的设置。3)在被提升为主服务器的从服务器上,发出STOPSLAVE和
如何使用logrotete定时切割mysql的慢日志
从不删库的DBA
Mysql mysql 数据库
背景:在Linux系统中,logrotate是常用的日志文件管理工具,可以配置它来对MySQL的慢查询日志进行轮转,例如按照每天或者每周进行轮转,将旧的日志文件备份压缩并重新生成新的日志文件来继续记录!创建配置文件创建一个专门用于配置MySQL慢查询日志切割规则的文件,通常放在/etc/logrotate.d/目录下。假设你的MySQL慢查询日志文件名为/var/lib/mysql/[主机名]-s
二分查找排序算法
周凡杨
java 二分查找 排序 算法 折半
一:概念 二分查找又称
折半查找(
折半搜索/
二分搜索),优点是比较次数少,查找速度快,平均性能好;其缺点是要求待查表为有序表,且插入删除困难。因此,折半查找方法适用于不经常变动而 查找频繁的有序列表。首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表 分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步
java中的BigDecimal
bijian1013
java BigDecimal
在项目开发过程中出现精度丢失问题,查资料用BigDecimal解决,并发现如下这篇BigDecimal的解决问题的思路和方法很值得学习,特转载。
原文地址:http://blog.csdn.net/ugg/article/de
Shell echo命令详解
daizj
echo shell
Shell echo命令
Shell 的 echo 指令与 PHP 的 echo 指令类似,都是用于字符串的输出。命令格式:
echo string
您可以使用echo实现更复杂的输出格式控制。 1.显示普通字符串:
echo "It is a test"
这里的双引号完全可以省略,以下命令与上面实例效果一致:
echo Itis a test 2.显示转义
Oracle DBA 简单操作
周凡杨
oracle dba sql
--执行次数多的SQL
select sql_text,executions from (
select sql_text,executions from v$sqlarea order by executions desc
) where rownum<81;
&nb
画图重绘
朱辉辉33
游戏
我第一次接触重绘是编写五子棋小游戏的时候,因为游戏里的棋盘是用线绘制的,而这些东西并不在系统自带的重绘里,所以在移动窗体时,棋盘并不会重绘出来。所以我们要重写系统的重绘方法。
在重写系统重绘方法时,我们要注意一定要调用父类的重绘方法,即加上super.paint(g),因为如果不调用父类的重绘方式,重写后会把父类的重绘覆盖掉,而父类的重绘方法是绘制画布,这样就导致我们
线程之初体验
西蜀石兰
线程
一直觉得多线程是学Java的一个分水岭,懂多线程才算入门。
之前看《编程思想》的多线程章节,看的云里雾里,知道线程类有哪几个方法,却依旧不知道线程到底是什么?书上都写线程是进程的模块,共享线程的资源,可是这跟多线程编程有毛线的关系,呜呜。。。
线程其实也是用户自定义的任务,不要过多的强调线程的属性,而忽略了线程最基本的属性。
你可以在线程类的run()方法中定义自己的任务,就跟正常的Ja
linux集群互相免登陆配置
林鹤霄
linux
配置ssh免登陆
1、生成秘钥和公钥 ssh-keygen -t rsa
2、提示让你输入,什么都不输,三次回车之后会在~下面的.ssh文件夹中多出两个文件id_rsa 和 id_rsa.pub
其中id_rsa为秘钥,id_rsa.pub为公钥,使用公钥加密的数据只有私钥才能对这些数据解密 c
mysql : Lock wait timeout exceeded; try restarting transaction
aigo
mysql
原文:http://www.cnblogs.com/freeliver54/archive/2010/09/30/1839042.html
原因是你使用的InnoDB 表类型的时候,
默认参数:innodb_lock_wait_timeout设置锁等待的时间是50s,
因为有的锁等待超过了这个时间,所以抱错.
你可以把这个时间加长,或者优化存储
Socket编程 基本的聊天实现。
alleni123
socket
public class Server
{
//用来存储所有连接上来的客户
private List<ServerThread> clients;
public static void main(String[] args)
{
Server s = new Server();
s.startServer(9988);
}
publi
多线程监听器事件模式(一个简单的例子)
百合不是茶
线程 监听模式
多线程的事件监听器模式
监听器时间模式经常与多线程使用,在多线程中如何知道我的线程正在执行那什么内容,可以通过时间监听器模式得到
创建多线程的事件监听器模式 思路:
1, 创建线程并启动,在创建线程的位置设置一个标记
2,创建队
spring InitializingBean接口
bijian1013
java spring
spring的事务的TransactionTemplate,其源码如下:
public class TransactionTemplate extends DefaultTransactionDefinition implements TransactionOperations, InitializingBean{
...
}
TransactionTemplate继承了DefaultT
Oracle中询表的权限被授予给了哪些用户
bijian1013
oracle 数据库 权限
Oracle查询表将权限赋给了哪些用户的SQL,以备查用。
select t.table_name as "表名",
t.grantee as "被授权的属组",
t.owner as "对象所在的属组"
【Struts2五】Struts2 参数传值
bit1129
struts2
Struts2中参数传值的3种情况
1.请求参数绑定到Action的实例字段上
2.Action将值传递到转发的视图上
3.Action将值传递到重定向的视图上
一、请求参数绑定到Action的实例字段上以及Action将值传递到转发的视图上
Struts可以自动将请求URL中的请求参数或者表单提交的参数绑定到Action定义的实例字段上,绑定的规则使用ognl表达式语言
【Kafka十四】关于auto.offset.reset[Q/A]
bit1129
kafka
I got serveral questions about auto.offset.reset. This configuration parameter governs how consumer read the message from Kafka when there is no initial offset in ZooKeeper or
nginx gzip压缩配置
ronin47
nginx gzip 压缩范例
nginx gzip压缩配置 更多
0
nginx
gzip
配置
随着nginx的发展,越来越多的网站使用nginx,因此nginx的优化变得越来越重要,今天我们来看看nginx的gzip压缩到底是怎么压缩的呢?
gzip(GNU-ZIP)是一种压缩技术。经过gzip压缩后页面大小可以变为原来的30%甚至更小,这样,用
java-13.输入一个单向链表,输出该链表中倒数第 k 个节点
bylijinnan
java
two cursors.
Make the first cursor go K steps first.
/*
* 第 13 题:题目:输入一个单向链表,输出该链表中倒数第 k 个节点
*/
public void displayKthItemsBackWard(ListNode head,int k){
ListNode p1=head,p2=head;
Spring源码学习-JdbcTemplate queryForObject
bylijinnan
java spring
JdbcTemplate中有两个可能会混淆的queryForObject方法:
1.
Object queryForObject(String sql, Object[] args, Class requiredType)
2.
Object queryForObject(String sql, Object[] args, RowMapper rowMapper)
第1个方法是只查
[冰川时代]在冰川时代,我们需要什么样的技术?
comsci
技术
看美国那边的气候情况....我有个感觉...是不是要进入小冰期了?
那么在小冰期里面...我们的户外活动肯定会出现很多问题...在室内呆着的情况会非常多...怎么在室内呆着而不发闷...怎么用最低的电力保证室内的温度.....这都需要技术手段...
&nb
js 获取浏览器型号
cuityang
js 浏览器
根据浏览器获取iphone和apk的下载地址
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" content="text/html"/>
<meta name=
C# socks5详解 转
dalan_123
socket C#
http://www.cnblogs.com/zhujiechang/archive/2008/10/21/1316308.html 这里主要讲的是用.NET实现基于Socket5下面的代理协议进行客户端的通讯,Socket4的实现是类似的,注意的事,这里不是讲用C#实现一个代理服务器,因为实现一个代理服务器需要实现很多协议,头大,而且现在市面上有很多现成的代理服务器用,性能又好,
运维 Centos问题汇总
dcj3sjt126com
云主机
一、sh 脚本不执行的原因
sh脚本不执行的原因 只有2个
1.权限不够
2.sh脚本里路径没写完整。
二、解决You have new mail in /var/spool/mail/root
修改/usr/share/logwatch/default.conf/logwatch.conf配置文件
MailTo =
MailFrom
三、查询连接数
Yii防注入攻击笔记
dcj3sjt126com
sql WEB安全 yii
网站表单有注入漏洞须对所有用户输入的内容进行个过滤和检查,可以使用正则表达式或者直接输入字符判断,大部分是只允许输入字母和数字的,其它字符度不允许;对于内容复杂表单的内容,应该对html和script的符号进行转义替换:尤其是<,>,',"",&这几个符号 这里有个转义对照表:
http://blog.csdn.net/xinzhu1990/articl
MongoDB简介[一]
eksliang
mongodb MongoDB简介
MongoDB简介
转载请出自出处:http://eksliang.iteye.com/blog/2173288 1.1易于使用
MongoDB是一个面向文档的数据库,而不是关系型数据库。与关系型数据库相比,面向文档的数据库不再有行的概念,取而代之的是更为灵活的“文档”模型。
另外,不
zookeeper windows 入门安装和测试
greemranqq
zookeeper 安装 分布式
一、序言
以下是我对zookeeper 的一些理解: zookeeper 作为一个服务注册信息存储的管理工具,好吧,这样说得很抽象,我们举个“栗子”。
栗子1号:
假设我是一家KTV的老板,我同时拥有5家KTV,我肯定得时刻监视
Spring之使用事务缘由(2-注解实现)
ihuning
spring
Spring事务注解实现
1. 依赖包:
1.1 spring包:
spring-beans-4.0.0.RELEASE.jar
spring-context-4.0.0.
iOS App Launch Option
啸笑天
option
iOS 程序启动时总会调用application:didFinishLaunchingWithOptions:,其中第二个参数launchOptions为NSDictionary类型的对象,里面存储有此程序启动的原因。
launchOptions中的可能键值见UIApplication Class Reference的Launch Options Keys节 。
1、若用户直接
jdk与jre的区别(_)
macroli
java jvm jdk
简单的说JDK是面向开发人员使用的SDK,它提供了Java的开发环境和运行环境。SDK是Software Development Kit 一般指软件开发包,可以包括函数库、编译程序等。
JDK就是Java Development Kit JRE是Java Runtime Enviroment是指Java的运行环境,是面向Java程序的使用者,而不是开发者。 如果安装了JDK,会发同你
Updates were rejected because the tip of your current branch is behind
qiaolevip
学习永无止境 每天进步一点点 众观千象 git
$ git push joe prod-2295-1
To
[email protected] :joe.le/dr-frontend.git
! [rejected] prod-2295-1 -> prod-2295-1 (non-fast-forward)
error: failed to push some refs to '
[email protected]
[一起学Hive]之十四-Hive的元数据表结构详解
superlxw1234
hive hive元数据结构
关键字:Hive元数据、Hive元数据表结构
之前在 “[一起学Hive]之一–Hive概述,Hive是什么”中介绍过,Hive自己维护了一套元数据,用户通过HQL查询时候,Hive首先需要结合元数据,将HQL翻译成MapReduce去执行。
本文介绍一下Hive元数据中重要的一些表结构及用途,以Hive0.13为例。
文章最后面,会以一个示例来全面了解一下,
Spring 3.2.14,4.1.7,4.2.RC2发布
wiselyman
Spring 3
Spring 3.2.14、4.1.7及4.2.RC2于6月30日发布。
其中Spring 3.2.1是一个维护版本(维护周期到2016-12-31截止),后续会继续根据需求和bug发布维护版本。此时,Spring官方强烈建议升级Spring框架至4.1.7 或者将要发布的4.2 。
其中Spring 4.1.7主要包含这些更新内容。