我是一个线程 [转]

我是一个线程,我一出生就被编了个号:0x3704,然后被领到一个昏暗的屋子里,在这里我发现了很多和我一模一样的同伴。

我身边的同伴0x6900 待的时间比较长,他带着沧桑的口气对我说:“我们线程的宿命就是处理包裹。把包裹处理完以后还得马上回到这里,否则可能永远回不来了。”

我一脸懵懂,“包裹,什么包裹?”

“不要着急,马上你就会明白了,我们这里是不养闲人的。”

果然,没多久,屋子的门开了, 一个面貌凶恶的家伙吼道:“0x3704 ,出来!”

我一出来就被塞了一个沉甸甸的包裹,上面还附带着一个写满了操作步骤的纸。 

“快去,把这个包裹处理了。”

“去哪儿处理?”

“跟着指示走,先到就绪车间。”

果然,地上有指示箭头,跟着它来到了一间明亮的大屋子,这里已经有不少线程了,大家都很紧张,好像时刻准备着往前冲。

我刚一进来,就听见广播说:“0x3704,进入车间。”

我赶紧往前走,身后有很多人议论。

“他太幸运了,刚进入就绪状态就能运行。”

“是不是有关系?”

“不是,你看人家的优先级多高啊,唉!”

前边就是车间,这里简直是太美了,怪不得老线程总是唠叨着说:“要是能一直待在这里就好了。”

这里空间大,视野好,空气清新,鸟语花香,还有很多从来没见过的人,像服务员一样等着为我服务。

他们也都有编号,更重要的是每个人还有个标签,上面写着:硬盘、数据库、内存、网卡……

我现在理解不了,看看操作步骤吧。

第一步:从包裹中取出参数。

打开包裹,里边有个HttpRequest对象,可以取到userName、 password两个参数。

第二步:执行登录操作。

奥,原来是有人要登录啊,我把userName、password交给数据库服务员,他拿着数据,慢腾腾地走了。

他怎么这么慢?不过我是不是正好可以在车间里多待一会儿?反正也没法执行第三步。

就在这时,车间里的广播响了:“0x3704,我是CPU,记住你正在执行的步骤,然后马上带着包裹离开!”

我慢腾腾地开始收拾。

“快点,别的线程马上就要进来了。”

离开这个车间,又来到一个大屋子,这里有很多线程在慢腾腾地喝茶,打牌。

“哥们,你们没事干了?”

“你新来的吧,你不知道我在等数据库服务员给我数据啊!据说他们比我们慢好几十万倍,在这里好好歇吧。”

“啊? 这么慢!我这里有人在登录系统,能等这么长时间吗?”

“放心,你没听说过人间一天,CPU一年吗?我们这里是用纳秒、毫秒计时的,人间等待一秒,相当于我们好几天呢,来得及。”

干脆睡一会吧。不知道过了多久,大喇叭又开始广播了:“0x3704,你的数据来了,快去执行!”

我转身就往CPU车间跑,发现这里的门只出不进!

后面传来阵阵哄笑声:“果然是新人,不知道还得去就绪车间等。”

于是赶紧到就绪车间,这次没有那么好运了,等了好久才被再次叫进CPU车间。

在等待的时候,我听见有人小声议论:

“听说了吗,最近有个线程被kill掉了。”

“为啥啊?”

“这家伙赖在CPU车间不走,把CPU利用率一直搞成100%,后来就被kill掉了。”

“Kill掉以后弄哪儿去了?”

“可能被垃圾回收了吧。”

我心里打了个寒噤,赶紧接着处理,剩下的动作快多了,第二步登录成功。

第三步:构建登录成功后的主页。

这一步有点费时,因为有很多HTML需要处理,不知道代码谁写的,处理起来很烦人。

我正在紧张的制作HTML呢, CPU又开始叫了:

“0x3704,我是CPU ,记住你正在执行的步骤,然后马上带着包裹离开!”

“为啥啊?”

“每个线程只能在CPU上运行一段时间,到了时间就得让别人用了,你去就绪车间待着,等着叫你吧。”

就这样,我一直在“就绪——运行”这两个状态中不知道轮转了多少次, 终于按照步骤清单把工作做完了。

最后顺利地把包含html的包裹发了回去。至于登录以后干什么事儿,我就不管了。马上就要回到我那昏暗的房间了,真有点舍不得这里。不过相对于有些线程,我还是幸运的,他们运行完以后就被彻底地销毁了,而我还活着!

回到了小黑屋,老线程0x6900问:

“怎么样?第一天有什么感觉?”

“我们的世界规则很复杂,首先你不知道什么时候会被挑中执行;第二,在执行的过程中随时可能被打断,让出CPU车间;第三,一旦出现硬盘、数据库这样耗时的操作,也得让出CPU去等待;第四,就是数据来了,你也不一定马上执行,还得等着CPU挑选。”

“小伙子理解的不错啊。”

“我不明白为什么很多线程执行完任务就死了,为什么咱们还活着?”

“你还不知道?长生不老是我们的特权!我们这里有个正式的名称,叫作线程池

 

第二回 渐入佳境

平淡的日子就这么一天天地过去,作为一个线程,我每天的生活都是取包裹、处理包裹,然后回到我们昏暗的家:线程池。

有一天我回来的时候,听到有个兄弟说,今天要好好休息下,明天就是最疯狂的一天。我看了一眼日历,明天是 1111号。 

果然,零点刚过,不知道那些人类怎么了,疯狂地投递包裹,为了应付蜂拥而至的海量包裹,线程池里没有一个人能闲下来,全部出去处理包裹,CPU车间利用率超高,硬盘在嗡嗡转,网卡疯狂的闪,即便如此,还是处理不完,堆积如山。

我们也没有办法,实在是太多太多了,这些包裹中大部分都是浏览页面,下订单,买、买、买。

不知道过了多久,包裹山终于慢慢地消失了。终于能够喘口气,我想我永远都不会忘记这一天。

通过这个事件,我明白了我所处的世界:这是一个电子商务的网站!

我每天的工作就是处理用户的登录,浏览,购物车,下单,付款。

我问线程池的元老0x6900我们要工作到什么时候?

要一直等到系统重启的那一刻。”0x6900说。

那你经历过系统重启吗?

怎么可能?系统重启就是我们的死亡时刻,也就是世界末日,一旦重启,整个线程池全部销毁,时间和空间全部消失,一切从头再来。

那什么时候会重启?

这就不好说了,好好享受眼前的生活吧……”

其实生活还是丰富多彩的,我最喜欢的包裹是上传图片,由于网络慢,所以能在就绪车间、CPU车间待很长很长时间,可以认识很多好玩的线程。

比如说上次认识了memecached 线程,他对我说在他的帮助下缓存了很多的用户数据,还是分布式的!很多机器上都有!

我问他:怪不得后来的登录操作快了那么多,原来是不再从数据库取数据了你那里就有啊,哎对了你是分布式的你去过别的机器没有?

他说:怎么可能!我每次也只能通过网络往那个机器发送一个GETPUT命令才存取数据而已,别的一概不知。

再比如说上次在等待的时候遇到了数据库连接的线程,我才知道他那里也是一个连接池,和我们的线程池几乎一模一样。

他告诉我:有些包裹太变态了,竟然查看一年的订单数据,简直把我累死了。

我说:拉倒吧你,你那是纯数据,你把数据传给我以后,我还得组装成HTML,工作量不知道比你大多少倍。

他建议我:你一定要和memecached搞好关系,直接从他那儿拿数据,尽量少直接调用数据库,这样我们JDBC connection也能活得轻松点。

我欣然接纳:好啊好啊,关键是你得提前把数据搞到缓存啊,要不然我先问一遍缓存,没有数据,我这不还得找你吗?

生活就是这样,如果你自己不找点乐子,还有什么意思?

 

第三回 虎口脱险

前几天我遇到一个可怕的事情,差一点死在外边,回不了线程池了。其实这次遇险我应该能够预想得到才对,真是太大意了。

那天我处理了一些从http发来的存款和取款的包裹,老线程0x6900特意嘱咐我:“处理这些包裹的时候一定要特别小心,你必须先获得一把锁,在对账户存款或取款的时候一定要把账户锁住,要不然别的线程就会在你等待的时候趁虚而入,搞破坏,我年轻那会儿很毛糙,就捅了篓子。”

为了“恐吓”我, 好心的0x6900还给了我两个表格:

(1)没有加锁的情况

 

(2)加锁的情况

 

我看得胆颤心惊,原来不加锁会带来这么严重的事故。从此以后看到存款、取款的包裹就倍加小心,还好没有出过事故。

今天我收到的一个包裹是转账,从某著名演员的账户给某著名导演的账户转钱,具体是谁我就不透漏了,数额可真是不小。

我按照老线程的吩咐,肯定要加锁啊,先对著名演员的账户加锁,再对著名导演的账户加锁。

可我万万没想到的是,还有一个线程,对,就是0x7954, 竟然同时在从这个导演的账户往这个演员的账户转账。 

于是乎,就出现了这么个情况:

刚开始我还不知道什么情况,一直坐在等待车间傻等,可是等的时间太长了,长达几十秒!我可从来没有经历过这样的事件。

这时候我就看到了线程0x7954 , 他悠闲地坐在那里喝咖啡,我和他聊了起来:

“哥们,我看你已经喝了8杯咖啡了,怎么还不去干活?”

“你不喝了9杯茶了吗?”0x7954回敬道。

“我在等一个锁,不知道哪个孙子一直不释放!”

“我也在等锁啊,我要是知道哪个孙子不释放锁我非揍死他不可!”0x7954毫不示弱。

我偷偷地看了一眼,这家伙怀里不就抱着我正等的某导演的锁吗?

很明显,0x7954也发现了我正抱着他正在等待的锁。

很快我们两个就吵了起来,互不相让:

    “把你的锁先给我,让我先做完!”

“不行,从来都是做完工作才释放锁,现在绝对不能给你!”

从争吵到打起来,就那么几秒钟的事儿。更重要的是,我们俩不仅仅持有这个著名导演和演员的锁,还有很多其他的锁,导致等待的线程越来越多,围观的人们把屋子都挤满了。最后事情真的闹大了,我从来没见过的终极大boss“操作系统”也来了。大Boss毕竟见多识广,他看了一眼,哼了一声,很不屑地说:

“又出现死锁了。”

“你们俩要Kill掉一个,来吧,过来抽签。”

这一下子把我给吓尿了,这么严重啊!我战战兢兢地抽了签,打开一看,是个“活”字。唉,小命终于保住了。

可怜的0x7954被迫交出了所有的资源以后,很不幸地被kill掉,消失了。我拿到了导演的锁,可以开始干活了。大Boss“操作系统”如一阵风似的消失了,身后只传来他的声音:

“记住,我们这里导演>演员,无论任何情况都要先获得导演的锁。”

由于这里不仅仅只有导演和演员,还有很多其他人,大Boss留下了一个表格, 里边是个算法,用来计算资源的大小,计算出来以后,永远按照从大到小的方式来获得锁: 

我回到线程池,大家都知道了我的历险,围着我问个不停。

凶神恶煞的线程调度员把大Boss的算法贴到了墙上。

每天早上,我们都得像无节操的房屋中介、美容美发店的服务员一样,站在门口,像被耍猴一样大声背诵:

多个资源加锁要牢记,一定要按Boss的算法比大小,然后从最大的开始加锁。

 

第四回 江湖再见

又过了很多天,我和其他线程们发现了一个奇怪的事情:包裹的处理越来越简单,不管任何包裹,不管是登录、浏览、存钱……处理的步骤都是一样的, 返回一个固定的html页面。

有一次我偷偷地看了一眼,上面写着:“本系统将于今晚 00:00 至4:00 进行维护升级, 给您带来的不便我们深感抱歉!”

我去告诉了老线程0x6904,他叹了一口气说:

“唉,我们的生命也到头了,看来马上就要重启系统,我们就要消失了,再见吧兄弟。”

系统重启的那一刻终于到来了。我看到屋子里的东西一个个的不见了,等待车间、就绪车间,甚至CPU车间都慢慢地消失了。我身边的线程兄弟也越来越少,最后只剩我自己了。

我在空旷的原野上大喊:“还有人吗?”

无人应答。

我们这一代线程池完成了使命……

不过下一代线程池即将重生!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575965.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自动化运维之–Cobbler

Cobbler 自动化 Cobbler简介 Cobbler是一个快速网络安装linux的服务,而且在经过调整也可以支持网络安装windows。该工具使用python开发,小巧轻便(才15k行python代码),使用简单的命令即可完成PXE网络安装环境的配置&…

基于VC++6.0的DLL开发

原文地址:http://blog.163.com/twnhr126/blog/static/78927547200910254346804/ 基于VC6.0的DLL开发 最近在开发一个基于网络的模块,目标是将这个在CAsyncSocket基础上开发的扩展类,进行有效的封装,向应用程序提供模块化的功能&a…

开源jumpserver 堡垒机搭建

一、环境 CentOS 6.x x86_64 mini service iptables stop 关闭SELinux的方法: 修改/etc/selinux/config文件中的SELINUX”” 为 disabled ,然后重启。 如果不想重启系统,使用命令setenforce 0 1.指定yum源 wget -O /etc/yum.repos.d/e…

Standard Driver Routines(标准驱动程序)

标准驱动程序 This section describes the required and optional routines that you must implement in your driver to respond to calls from Windows or other drivers. 本节介绍当驱动被Windows或其它驱动程序调用时,为了做出适当的回应,你的驱动必…

Shell 变量及函数讲解 [2]

Shell 变量的输入 Shell变量除了可以直接赋值或脚本传参外,还可以使用read命令从标准输入获得,read为bash内置命令,可以通过help read查看帮助【语法格式】read [参数] [变量名]【常用参数】-p prompt:设置提示信息-t timeout&…

python实例化次数怎么算,我需要一个Python类来跟踪它被实例化的次数

I need a class that works like this:>>> aFoo()>>> bFoo()>>> cFoo()>>> c.i3Here is my try:class Foo(object):i 0def __init__(self):Foo.i 1It works as required, but I wonder if there is a more pythonic way to do it.解决方…

多个域名要选择合适的SSL证书

一般来讲,一个网站(一个域名)对应一个SSL证书,因为SSL证书是绑定域名的。只有通配符证书和UCC多域名证书才支持多个域名。通配符证书适用于同一个域名下的多个子域。如同一服务器有多个网站:www.domain.comlogin.domai…

java大作业私人管家系统_重庆管家婆软件丨管家婆工贸PRO的E-MES管理详解

其实,ERP和MES在制造操作中扮演着独立而又互补的角色。ERP能将企业所有方面的数据进行实时、可用的全面集成,为管理决策提供高效、准确的业务决策支持;MES则能加强MRP计划的执行,把MRP计划同车间作业现场控制通过执行系统联系起来。这些“现场…

监控体系 [精]

监控体系 zabbix 监控对象:     1. 监控对象的理解:CPU是怎么工作的,原理     2. 监控对象的指标:CPU使用率 CPU负载 CPU个数 上下文切换     3. 确定性能基准线:怎么样才算故障?CPU负载多…

SD卡启动盘制作软件

下载地址:http://www.roadkil.net/program.php?ProgramID24转载于:https://www.cnblogs.com/wangf/archive/2013/06/04/3116882.html

vs 设置起始页不见了_发朋友圈屏蔽爸妈,结果不小心设置成了仅家人可见...场面一发不可收拾哈哈哈哈!...

一提到爸妈的朋友圈,就会想到养生鸡汤,中老年流量谣言,土味表情包而出于保护个人隐私拒绝被爸妈误解而遭受灵魂拷问的考虑很多人选择了两全其美的分组法给家人看到阳光可爱正能量的一面沙雕的一面只展现给沙雕网友们可如果不小心把屏蔽的内容…

KVM 安装

KVM介绍 Kernel-based Virtual Machine的简称,是一个开源的系统虚拟化模块,自Linux 2.6.20之后集成在Linux的各个主要发行版本中。它使用Linux自身的调度器进行管理,所以相对于Xen,其核心源码很少。KVM目前已成为学术界的主流VMM之…

彼聆智能语音机器人_电销行业的人工智能:智能语音电话机器人

随着人工智能的发展,越来越多的机器人出现在我们的日常生活中,用于电话营销公司的自动打电话机器人、快递公司用来送快递的机器人、餐厅里用来上菜的机器人,最近更是有一款会后空翻的机器人。机器人正活跃在各行各业中,代替人类去…

接触的第二个引擎 scaleform

最近在研究 一个全新的 引擎 scaleform 一个 基于 Flash 的 优化的一个引擎 这个引擎之前只有 U3D 和 UDK 两个 版本的工具 去年 改引擎 发布了 mobile 的 SDK 这个引擎有一个 很强大的地方就是 对 Flash 中矢量图的 优化 这个引擎配备了相对完备的 说明文档 (c2d相当于没有) 缺…

Shell 基础介绍 [1]

本文目录1.什么是Shell?2.脚本语言类型3.其他常用的脚本语句种类4.Shell脚本的建立和执行5.Shell 变量类型6.普通变量7.Shell 特殊重要变量8.Shell进程状态变量9.Parameter Expansion10.扩展:其他变量的替换11.变量的数值(整数)计…

c++创建二叉树_数据结构:查找(4)|| 平衡二叉树

在介绍平衡二叉树之前,应该先了解平衡因子的概念,平衡因子定义为左子树深度减去右子树深度,这个值的绝对值越大,非常容易理解它就对应着越不平衡的情况。一棵平衡的二叉树的平衡因子只能是1,0,-1如何构建一…

[批处理]截取for命令里面的变量%%i

写了一个批处理,里面需要call几个其他的批处理。 其中主进程需要根据批处理文件运行时的输入参数,选择合适的url,而url的定义写到另外的批处理里面 URLProxyAA.cmd URLProxyBB.cmd.... 我想在主程序运行时搜索一下当前目录,有多少…

华睿相机sdk 开发_索尼发布相机远程操作SDK(软件开发工具包)

索尼从2020年12月9日开始,向开发者免费提供针对索尼数码相机的软件开发工具包“ Camera Remote SDK” 1.03版。“ Camera Remote SDK”开发的软件可以远程更改相机设置、并执行诸如快门释放,实时取景监视(如取景和对焦)之类的操作。支持的操作系统包括Wi…

Linux 字体颜色设置

本文主要介绍Linux 字体颜色的调整,常用于shell脚本当中。我们举一个例子:echo-e"\033[44;37;5m ME \033[0m COOL" 以上命令设置背景成为蓝色,前景白色,闪烁光标,输出字符“ME”,然后重新设置屏幕…

利用Unity实现AOP

.NET程序中,可以利用Unity来实现AOP,用来进行日志、缓存或权限的处理。这里我们来写一个简单的程序,让其实现简单的AOP功能。 1.使用NuGet,在项目中获取Microsoft.Practices.Unity。 2.新建一个ITalk类及其实现 public interface …