我一出生就被编了个号: 0x3704,然后被领到一个昏暗的屋子里, 这里我发现了很多和我一模一样的同伴。
我身边的同伴0x6900待的时间比较长, 他带着沧桑的口气对我说:
“我们线程的宿命就是处理包裹。把包裹处理完以后还得马上回到这里,否则可能永远回不来了。”
“不要着急,马上你就会明白了, 我们这里是不养闲人的。”
果然,没多久,屋子的门开了, 一个面貌凶恶的家伙吼道:
我一出来就被塞了一个沉甸甸的包裹,上面还有附带着一个写满了操作步骤的纸。
果然,地上有指示箭头,跟着它来到了一间明亮的大屋子,这里已经有不少线程了, 大家都很紧张,好像时刻准备着往前冲。
我刚一进来,就听见广播说:“0x3704,进入车间”
前边就是车间, 这里简直是太美了, 怪不得老线程总是唠叨着说:要是能一直待在这里就好了。
这里空间大,视野好,空气清新,鸟语花香,还有很多从来没见过的人,像服务员一样等着为我服务。
他们也都有编号, 更重要的是每个人还有个标签,上面写着:硬盘,数据库,内存,网卡...
打开包裹, 里边有个HttpRequest对象,可以取到userName, password两个参数。
奥,原来是有人要登录啊,我把userName/password 交给数据库服务员,他拿着数据, 慢腾腾的走了。
他怎么这么慢?不过我是不是正好可以在车间里多待一会儿? 反正也没法执行第三步。
“0x3704,我是CPU,记住你正在执行的步骤,马上带包裹离开”
离开这个车间, 又来到一个大屋子,这里很多线程慢腾腾的在喝茶,打牌。
“你新来的吧,你不知道我在等数据库服务员给我数据啊,据说他们比我们慢好几十万倍, 在这里好好歇吧”
“啊? 这么慢? 我这里有人在登录系统, 能等这么长时间吗”
“放心,你没听说过人间一天,CPU一年吗, 我们这里是用纳秒,毫秒计时的,人间等待一秒,相当于我们好几天呢,来的及”
干脆睡一会吧 , 不知道过了多久 ,大喇叭又开始广播了:
于是赶紧到就绪车间,这次没有那么好运了,等了好久才被再次叫进CPU车间。
“这家伙赖在CPU车间不走,把CPU利用率一直搞成100%,后来就被kill掉了”
我心里打了个寒噤 , 赶紧接着处理,收下的动作块多了,第二步登录成功了。
这一步有点费时间, 因为有很多HTML需要处理, 不知道代码谁写的,处理起来很烦人。
“0x3704,我是CPU,记住你正在执行的步骤,马上带包裹离开”
“每个线程只能在CPU上运行一段时间,到了时间就得让别人用了,你去就绪车间待着, 等着叫你吧”
就这样, 我一直在“就绪-运行”这两个状态,不知道轮转了多少次,终于安装步骤清单把工作做完了。
不过相对于有些线程, 我还是幸运的, 他们运行完以后就彻底的销毁了,而我还活着!
“我们的世界规则很复杂,首先你不知道什么时候会被挑中执行;第二,在执行的过程中随时可能被打断,让出CPU车间;第三,一旦出现硬盘,数据库这样耗时的操作也得让出CPU,去等待;第四,就是数据来了,你也不一定马上执行,还得等着CPU挑选”
“我不明白为什么很多线程都执行完就死了, 为什么咱们还活着?”
“你还不知道,长生不老是我们的特权,我们这里有个正式的名称,叫做线程池!”
平淡的日子就这么一天天过去,作为一个线程,我每天的生活都是取包裹,处理包裹,然后回到我们昏暗的家:线程池。
有一天我回来的时候,听到有个兄弟说,今天要好好休息下,明天就是最疯狂的一天。
果然,零点刚过,不知道那些人类怎么了,疯狂的投递包裹,为了应付蜂拥而至的海量包裹,线程池里没有一个人能闲下来,全部出去处理包裹,CPU车间利用率超高,硬盘在嗡嗡转,网卡疯狂的闪,即便如此,还是处理不完,堆积如山。
我们也没有办法,实在是太多太多了,这些包裹中大部分都是浏览页面,下订单,买,买,买。
通过这个事件,我明白了我所处的世界:这是一个电子商务的网站!
我每天的工作就是处理用户的登录,浏览, 购物车,下单,付款。
我问线程池的元老0x6900:“我们要工作到什么时候?”
“怎么可能?系统重启就是我们的死亡时刻, 也就是世界末日,一旦重启,整个线程池全部销毁,时间和空间全部消失,一切从头再来”
其实生活丰富多彩,我最喜欢的包裹是上传图片,由于网络慢,所以能在就绪车间,CPU车间待很长很长时间,可以认识很多好玩的线程。
比如说上次认识了memecached线程,他给我说通过他缓存了很多的用户数据, 还是分布式的! 很多机器上都有!
我说怪不得后来的登录操作快了那么多, 原来是不再从数据库取数据了你那里就有啊,哎,对了,你是分布式的,你去过别的机器没有?
他说怎么可能,我每次也只能通过网络往那个机器发送一个GET, PUT命令才存取数据而已,别的一概不知。
再比如说上次在等待的时候遇到了数据库连接的线程,我才知道它他那里也是一个连接池,和我们线程池几乎一模一样。
他说有些包裹太变态了,竟然查看一年的订单数据,简直把我累死了。
我说拉倒吧你,你那是纯数据,你把数据传给我以后,我还得组装成HTML,工作量不知道比你大多少倍。
他说一定你要和memecached搞好关系,直接从他那儿拿数据,尽量少直接调用数据库,我们JDBC connection也能活的轻松点。
我说好啊好啊,关键是你得提前把数据搞到缓存啊,要不然我先问一遍缓存,没有数据,我这不还得找你吗?
生活就是这样,如果你自己不找点乐子,还有什么意思?
有一天我遇到一个可怕的事情, 差一点死在外边,回不了线程池了......
前几天我处理过一些从http发来的存款和取款的包裹,老线程0x6900特意嘱咐我:
“处理这些包裹的时候要特别小心,你得一定要先获得一把锁,在对账户存款或者取款的时候一定要把账户给锁住,要不然别的线程就会在你等待的时候趁虚而入,搞破坏,我年轻那会儿很毛糙,就捅了篓子”
为了“恐吓”我,好心的0x6900还给了我两个表格:
我看的胆颤心惊, 原来不加锁会带来这么严重的事故。
从此以后看到存款,取款的包裹就倍加小心,还好,没有出过事故。
今天我收到的一个包裹是转账,从某著名演员的账号给某著名导演赚钱,具体是谁我就不透漏了,数额可真是不小。
我按照老线程的吩咐,肯定要加锁啊,先对著名演员账号加锁,在对著名导演账号加锁。
可我万万没想到的是,还有一个线程,对,就是0x7954,竟然同时在从这个导演到往这个演员转账。