Arganzheng's Blog

stay hungry, stay foolish

进程VS线程

2010-05-06 星期四 晴朗 引入进程与线程这两个抽象,主要是资源的问题。硬件资源是有限的(如CPU,内存,各个寄存器等),而要支持多用户“同时”操作。以烹饪比喻,硬件资源就好像厨房以及厨房中的各种厨具。进程就好像各个厨师,操作系统调度程序决定什么时候应该将哪个厨师经来做饭,并且给了他们一定的时间限制,如果到时间没有做完,那么会为其保存现场,切换成下个厨师上次的现场,然后请下一个厨师...

Java IO概述

Input and Output - Source and Destination Java IO解决的问题是从一个source读取数据,和写数据到一个destination。在Java中常见的source和destination有下面几种: Files Pipes Network Connections System.in, System.out, System.er...

Java中如何把InputStream转化为String

法一:使用InputStreamReader(with charset)作为source,StringWriter或者StringBuilder作为destination。 import java.io.BufferedReader; import java.io.FileInputStream; import java.io.IOException; import java.io.Inp...

从暴风影音事件反思DNS频率攻击漏洞

蝴蝶效应 令人意想不到的是,这次断网的起因竟然是所谓两个网游私服外挂互掐,一个游戏“私服”的网站打算对它的竞争对手发动攻击,黑客在没法黑掉竞争对手网站的情况下,干脆从域名下手,利用肉鸡攻击对方的免费DNS服务商DNSpod的服务器,大流量的DDoS攻击导致了DNSpod的服务器流量剧增,于是被机房停止了服务,导致DNSpod的DNS服务暂停。而非常不巧的是DNSpod正好是暴风影音的域名解...

使用Servlet和JSP模拟最小化的SpringMVC框架

web服务器或应用服务器都是容器,容器只知道与Listener或Servlet打交道,因此所谓的Web MVC框架其实就是预定义了一些Servlet帮我们做了本应该是我们做的事情。 关键:如何用Servlet和JSP实现Web MVC框架 一个Web MVC简单的实现如下:在Servlet中实现web控制逻辑,在它们结束之后,再导向到适当的JSP视图。相应的模型对象将通过Servlet ...

Groovy元编程——使用invokeMethod和闭包构建DSL和Builder

Since 1.0, Groovy supports the ability to intercept all method and property access via the invokeMethod and get/setProperty hooks. If you only want to intercept failed method/property access take a...

BDB中的共享区域

2009-5-23 星期六 雨天 1. 数据结构 环境数据结构 DB_ENV{} struct __db_env { int db_lorder; /* Byte order. */ /* Error message callback. */ void (*db_errcall) __P((const ch...

BDB中的共享区域──MPOOL

2009-5-23 星期六 大雨 1. 数据结构 首先是DB_ENV{}和REGLAYOUT{}对于所有贡献区域都是一样的,在前面已经介绍过了,这里就不赘述了。 我们直接来看MPOOL共享区域数据结构MPOOL{}定义: /* * MPOOL -- * Shared memory pool region. One of these is allocated in shared ...

BDB1.6中的初始化过程──MPOOL初始化

我们前面的讨论都是基于BDB2.7.7版本的,那时候的BDB已经是一个支持事务处理的相当复杂的模块了。现在让我们回过头来看一下BDB1.6版本的初始化过程,那时候的共享区域就只有MPOOL。 首先其入口函数是dbopen(…)函数: DB * dbopen(fname, flags, mode, type, openinfo) const char *fname; int...

BDB事务共享区域

最后我们来看一下事务共享区域。 首先仍然是每个进程都有的一个数据结构__db_txnmgr{}: /* * The transaction manager encapsulates the transaction system. It contains * references to the log and lock managers as well as the state that...