- InnoDB内部结构
小园子的小菜
mysqljavamysql后端
在mysql数据库中,InnoDB存储引擎是最为常用和强大的存储引擎之一。了解InnoDB的内存结构对于优化数据库的性能,提高系统的稳定性和扩展性至关重要。本文将深入探讨InnoDB的内存结构。1.BufferPoolBufferPool:缓冲池,其作用是用来缓存表数据和索引数据,可以看作是数据库的高速缓存,可以减少磁盘的I/O操作,提高数据库的访问性能。BufferPool由缓存数据页(Page
- InnoDB 的 Buffer Pool
wayyyy
对于使用InnoDB存储引擎来说,无论是存储用户数据的索引,还是各种系统数据,最终都是以文件的形式存放于磁盘中,InnoDB存储引擎在处理客户端的请求时,如果需要访问某个页的数据,就会把完整的页中的全部数据加载在内存中,而且在读写访问之后,并不着急把该页的内存释放掉,而是将其缓存起来,这样将来有请求访问该页时,就可以省下磁盘IO的开销。BufferPool为了缓存磁盘中的页,MySQL启动时就会向
- mysql之写缓冲(change buffer)
tracy_668
[TOC]先简单回顾一下InnoDB缓冲池的工作原理。:image.png(1)MySQL数据存储包含内存与磁盘两个部分;(2)内存缓冲池(bufferpool)以页为单位,缓存最热的数据页(datapage)与索引页(indexpage);(3)InnoDB以变种LRU算法管理缓冲池,并能够解决“预读失效”与“缓冲池污染”的问题;毫无疑问,对于读请求,缓冲池能够减少磁盘IO,提升性能。问题来了,
- InnoDB架构
乐神来了
名词解释架构oracle数据库
InnoDB是MySQL数据库的一种存储引擎,它是MySQL默认的存储引擎。InnoDB使用了多版本并发控制(MVCC)来实现高并发性和事务性。InnoDB架构包括以下几个组件:缓冲池(BufferPool):用于存放数据页的内存缓存区,可以减少磁盘IO次数,提高查询性能。重做日志(RedoLog):用于记录数据库的修改操作,包括插入、更新和删除操作。重做日志可以保证事务的持久性。Undo日志(U
- MySQL篇之undo log和redo log
学java的冲鸭
mysqljava数据库面试
一、持久化时服务器宕机缓冲池(bufferpool):主内存中的一个区域,里面可以缓存磁盘上经常操作的真实数据,在执行增删改查操作时,先操作缓冲池中的数据(若缓冲池没有数据,则从磁盘加载并缓存),以一定频率刷新到磁盘,从而减少磁盘IO,加快处理速度。数据页(page):是InnoDB存储引擎磁盘管理的最小单元,每个页的大小默认为16KB。页中存储的是行数据。当服务器宕机了,数据同步失败了,可能内存
- mysql双写缓冲_MYSQL-写缓冲(change buffer)
saintbeta
mysql双写缓冲
(1)MySQL数据存储包含内存与磁盘两个部分;(2)内存缓冲池(bufferpool)以页为单位,缓存最热的数据页(datapage)与索引页(indexpage);(3)InnoDB以变种LRU算法管理缓冲池,并能够解决“预读失效”与“缓冲池污染”的问题;毫无疑问,对于读请求,缓冲池能够减少磁盘IO,提升性能。问题来了,那写请求呢?情况一假如要修改页号为4的索引页,而这个页正好在缓冲池内。如上
- 一文详解InnoDB最核心组件Buffer Pool(一)
南山的架构笔记
前文笔者通过一条语句的执行,从整体上讲解了InnoDB存储引擎的架构,让大家对一条SQL语句的执行过程中,都有哪些操作有了完备的了解。InnoDB存储引擎处理一条数据,无论是查询还是修改,都需要先从磁盘加载到内存中,然后在内存中对这条数据进行相关的操作,这块内存就是BufferPool。可以说BufferPool是整个InnoDB最重要的组件了。这篇文章笔者就顺着前文的思路,深入剖析下Buffer
- MySQL-MVCC多版本并发控制机制
廷达罗斯猎犬
MySqlmysqlb树数据库
MySQL-MVCC多版本并发控制机制MVCC多版本并发控制机制undo日志版本链与readview机制详解Innodb引擎SQL执行的BufferPool缓存机制引用自图灵,用于学习。MVCC多版本并发控制机制Mysql在可重复读隔离级别下如何保证事务较高的隔离性,同样的sql查询语句在一个事务里多次执行查询结果相同,就算其它事务对数据有修改也不会影响当前事务sql语句的查询结果。这个隔离性就是
- Mysql快速学习——InnoDB的内存缓冲池Change Buffer
火箭蛋头
2.ChangeBuffer写请求的处理流程(1)如果索引页不在bufferpool中,则先把索引页,从磁盘加载到缓冲池,一次磁盘随机读操作;(2)修改缓冲池中的页,一次内存操作;(3)写入redolog,一次磁盘顺序写操作;写请求处理是否会出现一致性问题呢?不会,因为:(1)读取,会命中缓冲池的页;(2)缓冲池LRU数据淘汰,会将“脏页”刷回磁盘;(3)数据库异常奔溃,能够从redolog中恢复
- undo log 和 redo log的区别
mhz2977170
数据库
undolog和redolog的区别缓冲池(BufferPool)是MySQL用于存储数据页的内存区域,它用于减少对磁盘的读写操作,提高数据库的访问速度。在MySQL中,数据被分为多个固定大小的数据页(通常为16KB),缓冲池通过将这些数据页加载到内存中,使得读取和写入操作可以直接在内存中进行,从而避免了频繁的磁盘I/O操作。缓冲池还可以用于缓存索引页,加快索引的检索速度。数据页(DataPage
- 【golang】23、gorilla websocket 源码:examples、数据结构、流程
呆呆的猫
#golang计算机网络golangwebsocket开发语言
文章目录一、examples1.1echo1.1.1server.go1.1.2client.go1.2command1.2.1功能和启动方式1.2.2home.html1.2.3main.go1.3filewatch1.3.1html1.3.2serveHome渲染模板1.3.3serveWs1.3.4writer()1.4bufferpool1.4.1server1.4.2client1.5c
- MySQL学习笔记(一)InnoDB内存数据结构浅析
小知_知数堂
以下文章来源于腾讯云数据库,作者陈俊熹Innodb存储引擎是目前MySQL最主流的存储引擎,学习Innodb,可以先从其最基础的数据结构开始。Innodb的数据结构主要包括内存数据结构(In-MemoryStructures),如bufferpool,changebuffer,logbuffer等,磁盘数据结构(On-DiskStructures),如索引Index,表空间及日志结构等。Buffe
- mysql临时表简述
好大的月亮
Mysqlmysql数据库
概述业务中经常会对一些表进行聚合组装信息,然后筛选,有些表比较数据量大的时候,会对拖慢查询;常用的mybatis的分页查询,在查询时会先count一下所有数据,然后再limit分页,即使分页也会有深度分页问题;在分页的时候一些大表的子查询都是重复的,而且每次的count和查询对大表实际进行了2次查询,可能mysql的bufferpool中会有缓存,但是非常影响查询速度;在不使用其他中间件的情况下,
- 我的创作纪念日+【MySQL】- 08 优化服务器设置
yinying293
SQL面试题Javamysqladb数据库
我的创作纪念日+【MySQL】-08优化服务器设置写在前面我的创作纪念日mysql优化服务器设置1.创建MySQL配置文件2.InnoDB缓冲池(BufferPool)3.线程缓存4.表缓存5.InnoDBI/O配置(事务日志)6.InnoDB并发配置7.优化排序(Filesorts)8.其他配置项写在前面近期比较忙,一些工作上的事情和个人提升方面的事情忙的天昏地暗,再打开C站发现居然已经接近两个
- Mysql的BufferPool
Artisan_w
#Mysqlmysql数据库
Mysql的BufferPoolMysql是一个存储数据到磁盘的进程,但是磁盘的速度难以与CPU相比,所以InnoDB存储引擎在处理客户端的请求时,当需要访问某个页的数据时,就会把完整的页的数据全部加载到内存中。将整个页加载到内存中后就可以进行读写访问了,在进行完读写访问之后并不着急把该页对应的内存空间释放掉,而是将其缓存起来,这样将来有请求再次访问该页面时,就可以省去磁盘IO的开销了。设计Inn
- mysql innodb 之 buffer pool
一刀道人
Mysqlmysqlbufferpoolinnodb
1bufferpool是什么bufferpool为内存中的一个数据块,主要由三部分组成:1)缓存中的数据页–存储业务数据,大小和磁盘中的数据页大小一样,均为16K。注:缓冲池和磁盘之间进行数据交换的单位是-数据页2)数据描述区域,也称为控制块,记录缓存数据页的元数据信息:包括数据页所属表空间、数据页编号、数据页在bufferpool中的地址、锁信息、LSN信息等。控制块大小800K左右,为缓存页大
- mysql-索引与引擎
名字忒不好取
笔记数据库mysqlb树数据库
文章目录数据库引擎using和on关键字myisam数据存储innodb(默认)INNODB三大特性BufferPool自适应Hash索引双写缓冲区索引本质数据结构创建、删除索引聚集索引辅助索引索引覆盖回表最左匹配索引下推explain优化查询索引列不要使用表达式(计算、函数等)前缀索引索引扫描排序unionall、or、in索引使用范围查询强制类型转化索引失效limit使用不要使用select*
- 面试题汇总
我但行好事莫问前程
java
1MySQL事务如何实现MySQL数据库中事务的实现主要依赖于支持事务的存储引擎,如InnoDB。InnoDB通过日志系统和锁机制来确保事务处理过程满足ACID(原子性、一致性、隔离性和持久性)特性:原子性(Atomicity):RedoLog(重做日志):当事务对数据进行修改时,首先记录在重做日志中,然后更新内存中的缓冲池(BufferPool)。事务提交前,会将重做日志刷到磁盘上的重做日志文件
- MIT6.830-2022-lab1实验思路详细讲解
幸平xp
Databasejava数据库后端
系列目录lab1地址:lab1lab2地址:lab2lab3地址:lab3lab4地址:lab4lab5地址:lab5lab6地址:lab6文章目录系列目录前言一、6.830/Lab1Start二、Exercise2.1、Exercise1:FieldsandTuples2.2、Exercise2:Catalog2.3、Exercise3:BufferPool2.4、Exercise4:HeapF
- MIT6.5830 实验2
一颗小小的石头.
MIT6.5830数据库开发mit课程
前置回顾在实验一中,我们完成了基本的数据存储层功能,以及实现了最核心的几个数据结构,Tuple、HeapFile、HeapPage、BufferPool等,对他们的增删查改已经支持,但没有和上层的逻辑sql关联起来。实验二需要对Tuple数据结构有深刻的理解,这里附上实验一的核心内容。HeapFile:物理上对应一个操作系统的文件,即实验中的.dat文件。逻辑上对应一张表。HeapPage:物理概
- [mysql]binlog和redolog有什么区别?
pmdream
sqlmysql面试
前言可能会考的面试题,我都把redolog原理看一遍了。那么,这个问题怎么回答呢?回答1.redolog是innodb独有的,binlog是server层实现的,所有引擎都能使用;2.redolog大小固定(可以设置),bufferpool的记录落盘后,日志就可以被覆盖了,无法保证用于数据回滚;3.redolog更多是为了保证,异常宕机了,之后我们可以根据redolog把没有刷到磁盘中的数据恢复。
- Mysql性能优化之BufferPool介绍
Memory_2020
mysql数据库
之前在一条SQL在MySQL中是如何执行的-CSDN博客这篇文章中讲了sql语句在Mysql里是如何执行的,今天就给大家介绍下Mysql的BufferPool,BufferPool是MySQL中一个关键的组件,它负责管理数据库引擎的内存缓存,提高数据库的读取性能。本文将深入讨论MySQL中BufferPool的概念、作用以及通过场景示例说明其在实际应用中的重要性。下面用张图再来总结下SQL的执行过
- Mysql 学习(十 三)InnoDB的BufferPool
程序胖
mysql学习java
为什么要有缓存?我们知道每次获取数据我们都需要从磁盘获取,磁盘的运行速度又慢的不行,对于这一个问题我们要怎么解决呢?我们把查询结果存储起来不就行了,因为当需要访问某个页的数据时,就会把完整的页的数据全部加载到内存中,也就是说即使我们只需要访问一个页的一条记录,那也需要先把整个页的数据加载到内存中。所以在进行完这些页对应的操作之后,不释放,而是将他们存储起来,下次再访问这个页的时候,就可以直接从缓存
- 三.逻辑架构
草莓田田圈~
MySQL--进阶Mysql数据库
逻辑架构1.逻辑架构剖析1.1服务器处理客户端请求1.2Connectors1.3第一层:连接层1.4第二层:服务层1.5第三层:引擎层1.6存储层1.7小结2.SQL执行流程2.1MySQL中的SQL执行流程2.2MySQL8中SQL执行原理2.3MySQL5.7中SQL执行原理2.4SQL语法顺序2.5Oracle中的SQL执行流程(了解)3.数据库缓冲池(bufferpool)3.1缓冲池v
- 【MySQL进阶】InnoDB引擎存储结构和架构
小小Yi学编程
mysqlmysql架构数据库
文章目录逻辑存储结构架构内存结构BufferPool&AdaptiveHashIndexChangeBufferLogBuffer磁盘结构逻辑存储结构表空间(Tablespaces):InnoDB使用表空间来管理存储表和索引的数据文件。每个表空间包含一个或多个数据文件,这些文件实际上存储数据表和索引。段(Segments):InnoDB将每个表空间划分为多个段,用于存储不同类型的数据。主要的段类型
- 07深入理解MVCC与BufferPool缓存机制
~Wil~
MySQLmysql
深入理解MVCC与BufferPool缓存机制MVCC多版本并发控制机制同样的SQL查询语句在一个事务里多次执行查询结果相同,就算其它事务对数据有修改也不会影响当前事务sql语句的查询结果这个隔离性就是靠MVCC保证的,对一行数据的读和写两个操作默认是不会通过加锁互斥来保证隔离性,避免了频繁加锁互斥,而在串行化隔离级别为了保证较高的隔离性是通过将所有操作加锁互斥来实现的。MySQL在读已提交和可重
- bufferpool oracle,Oracle调优之buffer pool有关
Maggie姐说
bufferpooloracle
Oracle调优之bufferpool相关一个oracleblock与databuffer中的一个buffer对应。用户进程(serverprocess)负责读取磁盘上的block到databuffercache中,DEWn进程负责将脏块写到磁盘上。一个buffer在databuffer中有4种状态pined:多个进程想写这个块,但只有1个进程能获得锁。claen:buffer中的数据和磁盘上的数
- Buffer Pool详解
清云青云
mysqlBufferpoolFree链表Flush链表LRU链表Chunk
文章目录一、简介二、缓存页三、Free链表四、Flush链表五、LRU链表六、脏页刷新七、多个Bufferpool八、Chunk单位一、简介mysql的数据都是存放在磁盘下的,为了加快cpu从磁盘i/o读取数据的效率,Innodb存储引擎在cpu和磁盘中间添加了一个缓冲区bufferpool。当一个请求进来,会先从bufferpool中去看需要的查询结果数据是否已经存在,存在则直接返回,不存在,则
- Buffer Pool
CRUD_coder
java学习mysql
BufferPool概念free链表flush链表LRU链表chunk概念MySQL在启动时向操作系统申请的一片连续的内存,默认128M。然后将这块内存分为一个一个缓冲页(16KB,因为页就是16KB的)。再为每个缓冲页创建对应的控制块用于管理。比如第一次查询数据之后,数据库中对应的数据页就加载到缓冲页,第二次查询就不用去数据库了,直接内存查到返回。free链表由空闲的缓冲页的控制块组成的链表,新
- buffer pool和查询缓存的区别
zyjzyjjyzjyz
缓存
在学习bufferpool的时候我产生了疑问,bufferpool和查询缓存是一个东西吗?结论:不是一回事。bufferpoolbufferpool我之前介绍过,它的出现是为了提高查找效率,缓存磁盘上的数据页。bufferpool虽说是内存中的一段连续空间,但是它实际上是介于存储引擎和数据层之间。可以把这个连续的空间看成是磁盘,先去这个“磁盘空间”去找,如果找不到再去实际的磁盘寻找,找到后存到bu
- 深入浅出Java Annotation(元注解和自定义注解)
Josh_Persistence
Java Annotation元注解自定义注解
一、基本概述
Annontation是Java5开始引入的新特征。中文名称一般叫注解。它提供了一种安全的类似注释的机制,用来将任何的信息或元数据(metadata)与程序元素(类、方法、成员变量等)进行关联。
更通俗的意思是为程序的元素(类、方法、成员变量)加上更直观更明了的说明,这些说明信息是与程序的业务逻辑无关,并且是供指定的工具或
- mysql优化特定类型的查询
annan211
java工作mysql
本节所介绍的查询优化的技巧都是和特定版本相关的,所以对于未来mysql的版本未必适用。
1 优化count查询
对于count这个函数的网上的大部分资料都是错误的或者是理解的都是一知半解的。在做优化之前我们先来看看
真正的count()函数的作用到底是什么。
count()是一个特殊的函数,有两种非常不同的作用,他可以统计某个列值的数量,也可以统计行数。
在统
- MAC下安装多版本JDK和切换几种方式
棋子chessman
jdk
环境:
MAC AIR,OS X 10.10,64位
历史:
过去 Mac 上的 Java 都是由 Apple 自己提供,只支持到 Java 6,并且OS X 10.7 开始系统并不自带(而是可选安装)(原自带的是1.6)。
后来 Apple 加入 OpenJDK 继续支持 Java 6,而 Java 7 将由 Oracle 负责提供。
在终端中输入jav
- javaScript (1)
Array_06
JavaScriptjava浏览器
JavaScript
1、运算符
运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=)、算术运算符(+,-,*,/,++,--,%)、比较运算符(>,<,<=,>=,==,===,!=,!==)、逻辑运算符(||,&&,!)、条件运算(?:)、位
- 国内顶级代码分享网站
袁潇含
javajdkoracle.netPHP
现在国内很多开源网站感觉都是为了利益而做的
当然利益是肯定的,否则谁也不会免费的去做网站
&
- Elasticsearch、MongoDB和Hadoop比较
随意而生
mongodbhadoop搜索引擎
IT界在过去几年中出现了一个有趣的现象。很多新的技术出现并立即拥抱了“大数据”。稍微老一点的技术也会将大数据添进自己的特性,避免落大部队太远,我们看到了不同技术之间的边际的模糊化。假如你有诸如Elasticsearch或者Solr这样的搜索引擎,它们存储着JSON文档,MongoDB存着JSON文档,或者一堆JSON文档存放在一个Hadoop集群的HDFS中。你可以使用这三种配
- mac os 系统科研软件总结
张亚雄
mac os
1.1 Microsoft Office for Mac 2011
大客户版,自行搜索。
1.2 Latex (MacTex):
系统环境:https://tug.org/mactex/
&nb
- Maven实战(四)生命周期
AdyZhang
maven
1. 三套生命周期 Maven拥有三套相互独立的生命周期,它们分别为clean,default和site。 每个生命周期包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖于前面的阶段,用户和Maven最直接的交互方式就是调用这些生命周期阶段。 以clean生命周期为例,它包含的阶段有pre-clean, clean 和 post
- Linux下Jenkins迁移
aijuans
Jenkins
1. 将Jenkins程序目录copy过去 源程序在/export/data/tomcatRoot/ofctest-jenkins.jd.com下面 tar -cvzf jenkins.tar.gz ofctest-jenkins.jd.com &
- request.getInputStream()只能获取一次的问题
ayaoxinchao
requestInputstream
问题:在使用HTTP协议实现应用间接口通信时,服务端读取客户端请求过来的数据,会用到request.getInputStream(),第一次读取的时候可以读取到数据,但是接下来的读取操作都读取不到数据
原因: 1. 一个InputStream对象在被读取完成后,将无法被再次读取,始终返回-1; 2. InputStream并没有实现reset方法(可以重
- 数据库SQL优化大总结之 百万级数据库优化方案
BigBird2012
SQL优化
网上关于SQL优化的教程很多,但是比较杂乱。近日有空整理了一下,写出来跟大家分享一下,其中有错误和不足的地方,还请大家纠正补充。
这篇文章我花费了大量的时间查找资料、修改、排版,希望大家阅读之后,感觉好的话推荐给更多的人,让更多的人看到、纠正以及补充。
1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。
2.应尽量避免在 where
- jsonObject的使用
bijian1013
javajson
在项目中难免会用java处理json格式的数据,因此封装了一个JSONUtil工具类。
JSONUtil.java
package com.bijian.json.study;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
- [Zookeeper学习笔记之六]Zookeeper源代码分析之Zookeeper.WatchRegistration
bit1129
zookeeper
Zookeeper类是Zookeeper提供给用户访问Zookeeper service的主要API,它包含了如下几个内部类
首先分析它的内部类,从WatchRegistration开始,为指定的znode path注册一个Watcher,
/**
* Register a watcher for a particular p
- 【Scala十三】Scala核心七:部分应用函数
bit1129
scala
何为部分应用函数?
Partially applied function: A function that’s used in an expression and that misses some of its arguments.For instance, if function f has type Int => Int => Int, then f and f(1) are p
- Tomcat Error listenerStart 终极大法
ronin47
tomcat
Tomcat报的错太含糊了,什么错都没报出来,只提示了Error listenerStart。为了调试,我们要获得更详细的日志。可以在WEB-INF/classes目录下新建一个文件叫logging.properties,内容如下
Java代码
handlers = org.apache.juli.FileHandler, java.util.logging.ConsoleHa
- 不用加减符号实现加减法
BrokenDreams
实现
今天有群友发了一个问题,要求不用加减符号(包括负号)来实现加减法。
分析一下,先看最简单的情况,假设1+1,按二进制算的话结果是10,可以看到从右往左的第一位变为0,第二位由于进位变为1。
 
- 读《研磨设计模式》-代码笔记-状态模式-State
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
/*
当一个对象的内在状态改变时允许改变其行为,这个对象看起来像是改变了其类
状态模式主要解决的是当控制一个对象状态的条件表达式过于复杂时的情况
把状态的判断逻辑转移到表示不同状态的一系列类中,可以把复杂的判断逻辑简化
如果在
- CUDA程序block和thread超出硬件允许值时的异常
cherishLC
CUDA
调用CUDA的核函数时指定block 和 thread大小,该大小可以是dim3类型的(三维数组),只用一维时可以是usigned int型的。
以下程序验证了当block或thread大小超出硬件允许值时会产生异常!!!GPU根本不会执行运算!!!
所以验证结果的正确性很重要!!!
在VS中创建CUDA项目会有一个模板,里面有更详细的状态验证。
以下程序在K5000GPU上跑的。
- 诡异的超长时间GC问题定位
chenchao051
jvmcmsGChbaseswap
HBase的GC策略采用PawNew+CMS, 这是大众化的配置,ParNew经常会出现停顿时间特别长的情况,有时候甚至长到令人发指的地步,例如请看如下日志:
2012-10-17T05:54:54.293+0800: 739594.224: [GC 739606.508: [ParNew: 996800K->110720K(996800K), 178.8826900 secs] 3700
- maven环境快速搭建
daizj
安装mavne环境配置
一 下载maven
安装maven之前,要先安装jdk及配置JAVA_HOME环境变量。这个安装和配置java环境不用多说。
maven下载地址:http://maven.apache.org/download.html,目前最新的是这个apache-maven-3.2.5-bin.zip,然后解压在任意位置,最好地址中不要带中文字符,这个做java 的都知道,地址中出现中文会出现很多
- PHP网站安全,避免PHP网站受到攻击的方法
dcj3sjt126com
PHP
对于PHP网站安全主要存在这样几种攻击方式:1、命令注入(Command Injection)2、eval注入(Eval Injection)3、客户端脚本攻击(Script Insertion)4、跨网站脚本攻击(Cross Site Scripting, XSS)5、SQL注入攻击(SQL injection)6、跨网站请求伪造攻击(Cross Site Request Forgerie
- yii中给CGridView设置默认的排序根据时间倒序的方法
dcj3sjt126com
GridView
public function searchWithRelated() {
$criteria = new CDbCriteria;
$criteria->together = true; //without th
- Java集合对象和数组对象的转换
dyy_gusi
java集合
在开发中,我们经常需要将集合对象(List,Set)转换为数组对象,或者将数组对象转换为集合对象。Java提供了相互转换的工具,但是我们使用的时候需要注意,不能乱用滥用。
1、数组对象转换为集合对象
最暴力的方式是new一个集合对象,然后遍历数组,依次将数组中的元素放入到新的集合中,但是这样做显然过
- nginx同一主机部署多个应用
geeksun
nginx
近日有一需求,需要在一台主机上用nginx部署2个php应用,分别是wordpress和wiki,探索了半天,终于部署好了,下面把过程记录下来。
1. 在nginx下创建vhosts目录,用以放置vhost文件。
mkdir vhosts
2. 修改nginx.conf的配置, 在http节点增加下面内容设置,用来包含vhosts里的配置文件
#
- ubuntu添加admin权限的用户账号
hongtoushizi
ubuntuuseradd
ubuntu创建账号的方式通常用到两种:useradd 和adduser . 本人尝试了useradd方法,步骤如下:
1:useradd
使用useradd时,如果后面不加任何参数的话,如:sudo useradd sysadm 创建出来的用户将是默认的三无用户:无home directory ,无密码,无系统shell。
顾应该如下操作:
- 第五章 常用Lua开发库2-JSON库、编码转换、字符串处理
jinnianshilongnian
nginxlua
JSON库
在进行数据传输时JSON格式目前应用广泛,因此从Lua对象与JSON字符串之间相互转换是一个非常常见的功能;目前Lua也有几个JSON库,本人用过cjson、dkjson。其中cjson的语法严格(比如unicode \u0020\u7eaf),要求符合规范否则会解析失败(如\u002),而dkjson相对宽松,当然也可以通过修改cjson的源码来完成
- Spring定时器配置的两种实现方式OpenSymphony Quartz和java Timer详解
yaerfeng1989
timerquartz定时器
原创整理不易,转载请注明出处:Spring定时器配置的两种实现方式OpenSymphony Quartz和java Timer详解
代码下载地址:http://www.zuidaima.com/share/1772648445103104.htm
有两种流行Spring定时器配置:Java的Timer类和OpenSymphony的Quartz。
1.Java Timer定时
首先继承jav
- Linux下df与du两个命令的差别?
pda158
linux
一、df显示文件系统的使用情况,与du比較,就是更全盘化。 最经常使用的就是 df -T,显示文件系统的使用情况并显示文件系统的类型。 举比例如以下: [root@localhost ~]# df -T Filesystem Type &n
- [转]SQLite的工具类 ---- 通过反射把Cursor封装到VO对象
ctfzh
VOandroidsqlite反射Cursor
在写DAO层时,觉得从Cursor里一个一个的取出字段值再装到VO(值对象)里太麻烦了,就写了一个工具类,用到了反射,可以把查询记录的值装到对应的VO里,也可以生成该VO的List。
使用时需要注意:
考虑到Android的性能问题,VO没有使用Setter和Getter,而是直接用public的属性。
表中的字段名需要和VO的属性名一样,要是不一样就得在查询的SQL中
- 该学习笔记用到的Employee表
vipbooks
oraclesql工作
这是我在学习Oracle是用到的Employee表,在该笔记中用到的就是这张表,大家可以用它来学习和练习。
drop table Employee;
-- 员工信息表
create table Employee(
-- 员工编号
EmpNo number(3) primary key,
-- 姓