- MIT6.824 课程-MapReduce
余为民同志
6.824mapreduce分布式6.824
MapReduce:在大型集群上简化数据处理概要MapReduce是一种编程模型,它是一种用于处理和生成大型数据集的实现。用户通过指定一个用来处理键值对(Key/Value)的map函数来生成一个中间键值对集合。然后,再指定一个reduce函数,它用来合并所有的具有相同中间key的中间value。现实生活中有许多任务可以通过该模型进行表达,具体案例会在论文中展现出来。以这种函数式风格编写的程序能够
- CMU15-440-P0:Implementing a key-value messaging system
sdj222555
分布式
准备继续更新blog。最近工作上一直在写业务,看些课程换换脑子。15-440是CMU的一个分布式课程http://www.cs.cmu.edu/~15-440/syllabus.html,其实之前在学校的时候就上过分布式的课程,当时用的MIT6.824的课件,可惜当时很多paper没有仔细去看,只是把作业做了下,除了lab1都没有写blog记录,导致后来有时间写blog的时候很多细节都不记得了。这
- redis持久化
背帆
redisredis数据库
持久化:可以理解为mit6.824教的主从备份机制,状态转移对应RDB,复制状态机对应AOF,RDB是全部数据的二进制快照文件,AOF是文本追加的日志。RDB拷贝全部数据慢,是分钟级别的恢复机制但恢复更快,AOF通常设置1秒保存一次。官方推荐默认使用RDB,但AOF与RDB同时开启仅使用AOFRDB触发:1、主动执行save(阻塞)或bgsave(非阻塞)。2、达到阙值。3、关闭redis。RDB
- 6.824-Lab 1: MapReduce
向来痴_
mapreduce大数据
lab1链接:6.824Lab1:MapReduce(mit.edu)介绍在这个实验中,你将构建一个MapReduce系统。你将实现一个工作进程(workerprocess),调用应用程序的Map和Reduce函数,并处理文件的读写,以及一个主进程(masterprocess),分配任务给工作进程并处理失败的工作进程。你将构建的系统与MapReduce论文中描述的相似。合作政策你必须自己编写你提交
- MIT 6.5830 概述
一颗小小的石头.
MIT6.5830数据库开发mit课程
简介同MIT6.824系列类似,6.4830是关于DatabaseSystem的一门课程,官方主页链接。从课程信息可知,理论课分为21个课时,3个问题集,4个实验,1个项目。课程的ppt可以下载,对应的课堂回放可以直接在YouTube上观看。课程要求对数据库有基础理解,如下:SQL。会基本的crud操作,包括join、groupby等实操经验。执行/存储引擎聚簇索引查询优化分析内容21节课程比较啰
- MapReduce 论文阅读笔记 MapReduce 简介
RzBu11d023r
分布式系统摘要性笔记mapreducebigdata大数据
论文:MapReduce:SimplifiedDataProcessingonLargeClustersJeffreyDeanandSanjayGhemawatGooglehttps://pdos.csail.mit.edu/6.824/papers/mapreduce.pdfMapReduce是一种分布式系统中处理大数据方法。他提出是在2004,jeffdean和SanjayGhemawat的作
- 分布式一致性算法---Raft初探
小帅吖
分布式系统分布式共识算法raft分布式系统
读Raft论文也有一段时间了,但是自己总是以目前并没有完全掌握为由拖着这篇博客。今天先以目前的理解程度(做了6.824的lab2A和lab2B)对这篇论文做一个初步总结,之后有了更深入的理解之后再进行迭代,关于本文有任何疑问欢迎评论交流。另外需要说明的是本篇博客并没有对Raft算法的背景和基础知识进行全面介绍,所以需要有一定的基础之后进行阅读。基本概念三种状态及相互转换关系Raft算法中每个服务器
- MIT 6.824 分布式系统 lab1 MapReduce 遇到死锁问题
花里胡哨的菜只因
mapreduce大数据
记录学习6.824的lab1遇到的坑(死锁了)代码逻辑借鉴:https://blog.csdn.net/weixin_45938441/article/details/124018485问题描述目前处于编写worker与coordinate进行RPC通信的环节,worker中的Map和Reduce方法还都没有开动只有一个打印逻辑,只是想先测一下,worker和coordinate之间能否正常通信。
- 【分布式-6.824】MIT分布式系统概述
我要精通C++
分布式分布式
1.引入论文地址:http://nil.csail.mit.edu/6.824/2020/schedule.html参考lab:https://github.com/aQuaYi/MIT-6.824-Distributed-Systems推荐书目:DDIA数据密集型应用系统设计https://book.douban.com/subject/30329536/--推荐书《DesigningData-
- 6.824 Lab3 KVRAFT总结
Countingstarss
1引言实验结果对于3A部分,可以稳定通过测试,结果如下:Test:oneclient(3A)......Passed--15.352021212Test:manyclients(3A)......Passed--16.453230466Test:unreliablenet,manyclients(3A)......Passed--17.152616311Test:concurrentappendt
- CMU 15445 Project 2A 实现并发B+树的数据库索引(查询和插入)
西部小笼包
项目文档在这里,这个PROJECT我大概看了下描述。还是比较有挑战的,所以我会写的详细一点。但和MIT6.824那样一步步手把手指导,还是会不同。这边我重点挑我认为不是无脑就可以实现的部分写。https://15445.courses.cs.cmu.edu/fall2018/project2/按照CHECKPOINTA的描述,大概我们会改动image.png在此之前,我建议你做一下HOMEWORK
- MIT 6.824 练习1
Daniel_187
Gogo分布式网络爬虫爬虫
Hi,there!这是一份根据MIT6.824(2021)课程的第2课的课堂示例代码改编的2个go语言编程练习。像其他的编程作业一样,我去除了核心部分,保留了代码框架,并编写了每一步的提示练习代码在本文的最后面爬虫在第一部分,你需要实现3个版本的网络爬虫。1单线程爬虫首先,请为fakeFetcher类型实现Fetcher接口中的Fetch()方法。然后实现串行爬虫Serial()函数(递归),并在
- 【MIT 6.824 分布式系统】Lecture2中的 crawler.go 代码及解析
背书包的小新
爬虫golang开发语言
packagemainimport("fmt""sync")////SeveralsolutionstothecrawlerexercisefromtheGotutorial//https://tour.golang.org/concurrency/10//////Serialcrawler////看Mit这节课的时候,感觉mit的学生真的很不一样,一直在提问题,而且直接打断老师并说出自己的想法。
- Redis集群:分布式的less is more
SakamataZ
redis分布式数据库
Redis完全就是《数据密集型应用系统设计》的简单实现,主打一个**大道至简**。推荐配合这本书(或者15-445+6.824)一起看[1]。本文就从分布式视角来介绍下Redis集群模式,顺便看看一些经典的分布式问题在redis下如何解决。**这篇文章主要提供一个highlevel的视角,也就是聚焦于所有分布式系统都会有的一些问题,而不仅限于Redis,阅读时可以多带入自己熟悉的系统的视角。**比
- 6.824 Lab2 RAFT总结
Countingstarss
1引言大约用了20多天的时间完成了6.824的lab2,期间穿插了毕业预答辩,改论文,准备外审等等事情,最终磕磕绊绊的完成了Lab2,感觉算是自己写的程序中比较具有挑战性的了,因为在实验过程中需要认真的考虑并发、加锁、死锁等问题,并且实际RAFT论文中省去了很多细节,而且为了尽量通过测试与优化性能,本人也对与RAFT论文中很多细节进行更改,因此该Lab的完成具有一定挑战。实验结果开门见山,先放结果
- MIT 6.824 -- MapReduce Lab
Binary Oracle
#MIT6.824mapreduce大数据
MIT6.824--MapReduceLab环境准备实验背景实验要求测试说明流程说明实验实现GoLand配置代码实现对象介绍协调器启动工作线程启动Map阶段分配任务执行任务Reduce阶段分配任务执行任务终止阶段崩溃恢复注意事项并发安全文件转换golang知识点测试环境准备从官方git仓库拉取分支gitclonegit://g.csail.mit.edu/6.824-golabs-20206.82
- MIT6.824-lab2A-2022篇(万字推导思路及代码构建)
幸平xp
分布式后端分布式golang
目录前言一、学习背景二、实验引入三、结构体实现3.1State的定义3.2AppendEntriesRPC的定义3.3RequestVoteRPC的定义四、领导选举4.1初始化raft节点4.2Ticker(建立主体的心跳)4.3投票RPC实现五、日志增量/心跳建立5.1心跳/日志增量RPC实现5.2Test情况六、DeBug杂谈总结前言趁着五一没啥事情,花两天把lab2A写一下…还是老样子,希望
- MIT6.824-lab2B-2022篇(万字推导思路及代码构建)
幸平xp
分布式开发语言go分布式
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、整体流程思路二、初始化,发送ticker2.1、初始化2.2、发送ticker三、进行日志增量的RPC3.1、进行reply构造3.2、处理reply四、Debug五、总结前言忙里偷闲总算是把lab2b肝完了…不得不说五月真是最近最忙的一个月。对于lab2b,难度其实确实比lab2a大,甚至是比整个Lab1大的。2b其
- Mit6.824-lab2d-2022
eternalex
Mit6.824分布式
Mit6.824-lab2d-2022写在前面如果你听从了我在2a里的建议,计算下标时已经考虑到了snapshot并且有好好做过2a和2b实验的设计与debug,那2d实验和2c差不多一样简单,只完成snapshot和installSnapshot这两个功能,并在适时的位置调用即可。如果你是和我一样什么也没有准备,就一个实验一个实验接着往下做,那想要2d做到完善,就需要大量的填补漏洞与漫长的deb
- Mit6.824-lab3a-2022
eternalex
Mit6.824分布式go算法
Mit6.824-lab3a-2022写在前面个人感觉lab3相比于lab2要简单不少,唯一的难点应该就是没有lab2那样明确的paper指导。对我来说花费时间最多的反而是对lab2的修补,用了一个大佬的lab2代码,两天就把lab3的代码全部通过测试,回过头来debug自己lab2的代码反反复复花了一个多星期。而且和lab2直接对raft进行debug不同,lab3要结合自己的逻辑然后和lab2
- Mit6.824-lab3b-2022
eternalex
Mit6.824golang分布式算法
Mit6.824-lab3b-2022写在前面个人感觉3b需要做的工作比3a还要简单,只是添加了个server的snapshot,但是由于加入了snapshot所以3a的测试对raft的代码要求又高了一个档次,我基本上所有的精力也都花到对raft部分的debug上了,由于进行apply的chan不能上锁,这里会出现各种乱序的bug,只能说这个地方的设计确实是有点难受了。而且每次十几万行的log信息
- Mit6.824-lab2a-2022
eternalex
Mit6.824服务器javascript前端
Mit6.824-lab2a-2022实验介绍实验建议1.熟悉整个实验2.提前做好后两个实验的准备3.写好功能函数4.做足够的测试2a实验内容具体实现测试错误信息实验介绍lab2总体是要复现一个简易的Raft系统,这个实验被分为了四个部分2a,Leader的选举与保持;2b,log的添加;2c,数据持久化与服务器恢复2d,snapshot实现实验的重点是2a和2b,如果这两个部分没有打好基础,后面
- MIT 6.824-lab2 Raft
东东儿
6.824goraft算法分布式mit分布式一致性协议
这个lab2属实麻烦,花了两天时间写代码,最后花了四天时间来debug才通过,debug的手段也很有限,基本只能通过看日志来发现代码中的逻辑问题,最终回顾写出来的代码还乱得不行,先做个简单的记录,以后如果还有时间来重构一下代码。1.Raftraft算法是一种分布式共识算法,相对于paxos算法而言更加简单容易理解(看起来简单,实现起来也挺不容易的)。raft的论文很多,也有很多中文版的,看一看很容
- mit6.824 2022 lab2
最佳损友1020
国外课程实验raftmit6.824lab2
MIT6.8242022RaftRaftleaderelectionlogpersistencelogcompaction整体测试后面发现的问题参考代码汇总博客:MIT6.8242022Raftleaderelection不论是访问还是修改Raft可变类成员,都需要加锁rf.mu.Lock()ifrf.state!=Leader{rf.mu.Unlock()return}args:=AppendE
- MIT 6.824分布式 LAB3:kvraft
Wedge_Ss
分布式数据库gogolang
Lab3要求实现数据库和raft算法的结合。分别需要设计客户端和服务端,Lab3的代码的复杂性远不如Lab2,因此代码量不是很多,尽量也避免修改raft的源码,不然出了bug改起来也头疼。客户端和服务端进行连接,服务端处运行着数据库服务,服务端同样还需要运行raft算法进行共识。客户端能够向服务端发起的请求有put,append,get。当客户端需要进行指定的功能时,给服务端的发送消息,然后会将操
- MIT 6.824分布式 LAB2D:Raft
Wedge_Ss
分布式rpcgolang
Lab2D是lab2的最后阶段了,这一阶段就是加了一个快照机制,但是这种实验中这个快照是何时以及如何进行的,建议大家事前先去看一看,不然就会碰到各种问题。例如,我在测试过程中莫名其妙发现leader死锁了,以及测试显示lastapplied的index值和commandIndex值不匹配等问题。这个实验的代码修改范围挺大,因为涉及到了rf.log的索引值的修改,以及logreplication的运
- MIT 6.824分布式 LAB2A:Raft
Wedge_Ss
分布式golang
Lab2A被官方指定为中等难度,对于我这种之前很少写多线程的菜鸡而言,真的花费了大量时间,同时对于论文的理解不够深刻,导致我在写这个lab的过程中多次推倒重写其中的逻辑,以及锁使用的不熟练,让程序在执行过程中经常发生有raft节点死锁。后续记录一下,我写这个lab2A过程中的踩的坑。介绍Lab2A就是让你实现leader的选举,因此对于选举这块的逻辑务必要理清,否则写的过程中就会不知如何处理Las
- MIT 6.824分布式 LAB2B:Raft
Wedge_Ss
分布式javarpc
Lab2B难度为hard,但是有了之前2A的经历,于我而言,2B的难度倒是远低于2A的难度。2B需要实现的功能就只是logreplication。在写2B的过程中,我还找到了之前2A写的一些bug,说实话,多线程的程序,有些bug真的很难发现,你会发现突然某次运行就有一个raft节点发生了死锁,没有任何响应了,大概率是因为锁设置的太多了,导致某处出现了死锁,同时此写这个lab对于我debug能力的
- MIT6.824-Raft笔记:Raft初探、副本间log时序
Skyego
分布式共识算法raftMIT6.824笔记分布式存储
从宏观角度说明raft在程序中的作用,和客户端的关系,以及多个副本之间的关系;从微观角度说明多个副本之间raft对日志处理的流程。1.Raft初探宏观角度说明raft在程序中的作用,和客户端的关系,以及多个副本之间的关系。Raft会以库(Library)的形式存在于服务中。如果你有一个基于Raft的多副本服务,那么每个服务的副本将会由两部分组成:应用程序代码和Raft库,应用程序代码接收RPC或者
- MIT6.824-Raft笔记:脑裂、Majority Vote(过半投票/过半选举)
Skyego
分布式共识算法raftMIT6.824共识算法
本部分主要是问题引入,以及给出一个解决方案1脑裂(SplitBrain)replicationsystem的共同点:单点前面几个容错特性(fault-tolerant)的系统,有一个共同的特点。MapReduce复制了计算,但是复制这个动作,或者说整个MapReduce被一个单主节点控制。GFS以主备(primary-backup)的方式复制数据,会实际的复制文件内容,但它也依赖一个单主节点,来确
- mongodb3.03开启认证
21jhf
mongodb
下载了最新mongodb3.03版本,当使用--auth 参数命令行开启mongodb用户认证时遇到很多问题,现总结如下:
(百度上搜到的基本都是老版本的,看到db.addUser的就是,请忽略)
Windows下我做了一个bat文件,用来启动mongodb,命令行如下:
mongod --dbpath db\data --port 27017 --directoryperdb --logp
- 【Spark103】Task not serializable
bit1129
Serializable
Task not serializable是Spark开发过程最令人头疼的问题之一,这里记录下出现这个问题的两个实例,一个是自己遇到的,另一个是stackoverflow上看到。等有时间了再仔细探究出现Task not serialiazable的各种原因以及出现问题后如何快速定位问题的所在,至少目前阶段碰到此类问题,没有什么章法
1.
package spark.exampl
- 你所熟知的 LRU(最近最少使用)
dalan_123
java
关于LRU这个名词在很多地方或听说,或使用,接下来看下lru缓存回收的实现
1、大体的想法
a、查询出最近最晚使用的项
b、给最近的使用的项做标记
通过使用链表就可以完成这两个操作,关于最近最少使用的项只需要返回链表的尾部;标记最近使用的项,只需要将该项移除并放置到头部,那么难点就出现 你如何能够快速在链表定位对应的该项?
这时候多
- Javascript 跨域
周凡杨
JavaScriptjsonp跨域cross-domain
 
- linux下安装apache服务器
g21121
apache
安装apache
下载windows版本apache,下载地址:http://httpd.apache.org/download.cgi
1.windows下安装apache
Windows下安装apache比较简单,注意选择路径和端口即可,这里就不再赘述了。 2.linux下安装apache:
下载之后上传到linux的相关目录,这里指定为/home/apach
- FineReport的JS编辑框和URL地址栏语法简介
老A不折腾
finereportweb报表报表软件语法总结
JS编辑框:
1.FineReport的js。
作为一款BS产品,browser端的JavaScript是必不可少的。
FineReport中的js是已经调用了finereport.js的。
大家知道,预览报表时,报表servlet会将cpt模板转为html,在这个html的head头部中会引入FineReport的js,这个finereport.js中包含了许多内置的fun
- 根据STATUS信息对MySQL进行优化
墙头上一根草
status
mysql 查看当前正在执行的操作,即正在执行的sql语句的方法为:
show processlist 命令
mysql> show global status;可以列出MySQL服务器运行各种状态值,我个人较喜欢的用法是show status like '查询值%';一、慢查询mysql> show variab
- 我的spring学习笔记7-Spring的Bean配置文件给Bean定义别名
aijuans
Spring 3
本文介绍如何给Spring的Bean配置文件的Bean定义别名?
原始的
<bean id="business" class="onlyfun.caterpillar.device.Business">
<property name="writer">
<ref b
- 高性能mysql 之 性能剖析
annan211
性能mysqlmysql 性能剖析剖析
1 定义性能优化
mysql服务器性能,此处定义为 响应时间。
在解释性能优化之前,先来消除一个误解,很多人认为,性能优化就是降低cpu的利用率或者减少对资源的使用。
这是一个陷阱。
资源时用来消耗并用来工作的,所以有时候消耗更多的资源能够加快查询速度,保持cpu忙绿,这是必要的。很多时候发现
编译进了新版本的InnoDB之后,cpu利用率上升的很厉害,这并不
- 主外键和索引唯一性约束
百合不是茶
索引唯一性约束主外键约束联机删除
目标;第一步;创建两张表 用户表和文章表
第二步;发表文章
1,建表;
---用户表 BlogUsers
--userID唯一的
--userName
--pwd
--sex
create
- 线程的调度
bijian1013
java多线程thread线程的调度java多线程
1. Java提供一个线程调度程序来监控程序中启动后进入可运行状态的所有线程。线程调度程序按照线程的优先级决定应调度哪些线程来执行。
2. 多数线程的调度是抢占式的(即我想中断程序运行就中断,不需要和将被中断的程序协商)
a) 
- 查看日志常用命令
bijian1013
linux命令unix
一.日志查找方法,可以用通配符查某台主机上的所有服务器grep "关键字" /wls/applogs/custom-*/error.log
二.查看日志常用命令1.grep '关键字' error.log:在error.log中搜索'关键字'2.grep -C10 '关键字' error.log:显示关键字前后10行记录3.grep '关键字' error.l
- 【持久化框架MyBatis3一】MyBatis版HelloWorld
bit1129
helloworld
MyBatis这个系列的文章,主要参考《Java Persistence with MyBatis 3》。
样例数据
本文以MySQL数据库为例,建立一个STUDENTS表,插入两条数据,然后进行单表的增删改查
CREATE TABLE STUDENTS
(
stud_id int(11) NOT NULL AUTO_INCREMENT,
- 【Hadoop十五】Hadoop Counter
bit1129
hadoop
1. 只有Map任务的Map Reduce Job
File System Counters
FILE: Number of bytes read=3629530
FILE: Number of bytes written=98312
FILE: Number of read operations=0
FILE: Number of lar
- 解决Tomcat数据连接池无法释放
ronin47
tomcat 连接池 优化
近段时间,公司的检测中心报表系统(SMC)的开发人员时不时找到我,说用户老是出现无法登录的情况。前些日子因为手头上 有Jboss集群的测试工作,发现用户不能登录时,都是在Tomcat中将这个项目Reload一下就好了,不过只是治标而已,因为大概几个小时之后又会 再次出现无法登录的情况。
今天上午,开发人员小毛又找到我,要我协助将这个问题根治一下,拖太久用户难保不投诉。
简单分析了一
- java-75-二叉树两结点的最低共同父结点
bylijinnan
java
import java.util.LinkedList;
import java.util.List;
import ljn.help.*;
public class BTreeLowestParentOfTwoNodes {
public static void main(String[] args) {
/*
* node data is stored in
- 行业垂直搜索引擎网页抓取项目
carlwu
LuceneNutchHeritrixSolr
公司有一个搜索引擎项目,希望各路高人有空来帮忙指导,谢谢!
这是详细需求:
(1) 通过提供的网站地址(大概100-200个网站),网页抓取程序能不断抓取网页和其它类型的文件(如Excel、PDF、Word、ppt及zip类型),并且程序能够根据事先提供的规则,过滤掉不相干的下载内容。
(2) 程序能够搜索这些抓取的内容,并能对这些抓取文件按照油田名进行分类,然后放到服务器不同的目录中。
- [通讯与服务]在总带宽资源没有大幅增加之前,不适宜大幅度降低资费
comsci
资源
降低通讯服务资费,就意味着有更多的用户进入,就意味着通讯服务提供商要接待和服务更多的用户,在总体运维成本没有由于技术升级而大幅下降的情况下,这种降低资费的行为将导致每个用户的平均带宽不断下降,而享受到的服务质量也在下降,这对用户和服务商都是不利的。。。。。。。。
&nbs
- Java时区转换及时间格式
Cwind
java
本文介绍Java API 中 Date, Calendar, TimeZone和DateFormat的使用,以及不同时区时间相互转化的方法和原理。
问题描述:
向处于不同时区的服务器发请求时需要考虑时区转换的问题。譬如,服务器位于东八区(北京时间,GMT+8:00),而身处东四区的用户想要查询当天的销售记录。则需把东四区的“今天”这个时间范围转换为服务器所在时区的时间范围。
- readonly,只读,不可用
dashuaifu
jsjspdisablereadOnlyreadOnly
readOnly 和 readonly 不同,在做js开发时一定要注意函数大小写和jsp黄线的警告!!!我就经历过这么一件事:
使用readOnly在某些浏览器或同一浏览器不同版本有的可以实现“只读”功能,有的就不行,而且函数readOnly有黄线警告!!!就这样被折磨了不短时间!!!(期间使用过disable函数,但是发现disable函数之后后台接收不到前台的的数据!!!)
- LABjs、RequireJS、SeaJS 介绍
dcj3sjt126com
jsWeb
LABjs 的核心是 LAB(Loading and Blocking):Loading 指异步并行加载,Blocking 是指同步等待执行。LABjs 通过优雅的语法(script 和 wait)实现了这两大特性,核心价值是性能优化。LABjs 是一个文件加载器。RequireJS 和 SeaJS 则是模块加载器,倡导的是一种模块化开发理念,核心价值是让 JavaScript 的模块化开发变得更
- [应用结构]入口脚本
dcj3sjt126com
PHPyii2
入口脚本
入口脚本是应用启动流程中的第一环,一个应用(不管是网页应用还是控制台应用)只有一个入口脚本。终端用户的请求通过入口脚本实例化应用并将将请求转发到应用。
Web 应用的入口脚本必须放在终端用户能够访问的目录下,通常命名为 index.php,也可以使用 Web 服务器能定位到的其他名称。
控制台应用的入口脚本一般在应用根目录下命名为 yii(后缀为.php),该文
- haoop shell命令
eksliang
hadoophadoop shell
cat
chgrp
chmod
chown
copyFromLocal
copyToLocal
cp
du
dus
expunge
get
getmerge
ls
lsr
mkdir
movefromLocal
mv
put
rm
rmr
setrep
stat
tail
test
text
- MultiStateView不同的状态下显示不同的界面
gundumw100
android
只要将指定的view放在该控件里面,可以该view在不同的状态下显示不同的界面,这对ListView很有用,比如加载界面,空白界面,错误界面。而且这些见面由你指定布局,非常灵活。
PS:ListView虽然可以设置一个EmptyView,但使用起来不方便,不灵活,有点累赘。
<com.kennyc.view.MultiStateView xmlns:android=&qu
- jQuery实现页面内锚点平滑跳转
ini
JavaScripthtmljqueryhtml5css
平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且 url 链接最后会有“小尾巴”,就像#keleyi,今天我就介绍一款 jquery 做的滚动的特效,既可以设置滚动速度,又可以在 url 链接上没有“小尾巴”。
效果体验:http://keleyi.com/keleyi/phtml/jqtexiao/37.htmHTML文件代码:
&
- kafka offset迁移
kane_xie
kafka
在早前的kafka版本中(0.8.0),offset是被存储在zookeeper中的。
到当前版本(0.8.2)为止,kafka同时支持offset存储在zookeeper和offset manager(broker)中。
从官方的说明来看,未来offset的zookeeper存储将会被弃用。因此现有的基于kafka的项目如果今后计划保持更新的话,可以考虑在合适
- android > 搭建 cordova 环境
mft8899
android
1 , 安装 node.js
http://nodejs.org
node -v 查看版本
2, 安装 npm
可以先从 https://github.com/isaacs/npm/tags 下载 源码 解压到
- java封装的比较器,比较是否全相同,获取不同字段名字
qifeifei
非常实用的java比较器,贴上代码:
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.JsonConfig;
i
- 记录一些函数用法
.Aky.
位运算PHP数据库函数IP
高手们照旧忽略。
想弄个全天朝IP段数据库,找了个今天最新更新的国内所有运营商IP段,copy到文件,用文件函数,字符串函数把玩下。分割出startIp和endIp这样格式写入.txt文件,直接用phpmyadmin导入.csv文件的形式导入。(生命在于折腾,也许你们觉得我傻X,直接下载人家弄好的导入不就可以,做自己的菜鸟,让别人去说吧)
当然用到了ip2long()函数把字符串转为整型数
- sublime text 3 rust
wudixiaotie
Sublime Text
1.sublime text 3 => install package => Rust
2.cd ~/.config/sublime-text-3/Packages
3.mkdir rust
4.git clone https://github.com/sp0/rust-style
5.cd rust-style
6.cargo build --release
7.ctrl