码农的性能测试

1.如何理解TPS
  性能指标的一个重要因素。TPS(Transaction Per Second,每秒事物数),单位时间内完成的事物的数量。TPS的计算一般是通过的事物除以时间。
  TPS是跟测试脚本中事物(Transaction)相关联的。
  在性能测试工具中,吞吐量也被称之为TPS(Transaction Per Second,每秒事物数)。吞吐量直接体现系统性能的承载能力,是指单位时间内处理的客户请求的数量。其计量单位可以根据需求不同而不同,比如请求数/秒,页面数/秒,业务数/小时(可以说下我们采集项目中吞吐量可以用 解析卡数/秒)。
  对于交互式应用,用户直接的体验就是“响应时间”,通过“并发用户数”和“响应时间”可以确定系统的性能规划;但对于非交互式应用,用“吞吐量”来描述用户对系统的性能期望可能更加合理。
  吞吐量作为性能测试的主要关键指标。吞吐量和并发用户数之前存在着一定的联系。在没有性能瓶颈的时候,吞吐量随着虚拟用户数的增加而增加(计算公式为 吞吐量 = (VU个数 * 每个VU发出请求数) / 单位时间)。如果性能遇到瓶颈,吞吐量与VU数理之间就不再符合这个关系。
  2.如何理解线程调用
  线程(thread)是”进程”中某个单一顺序的控制流。也被称为轻量进程。
  线程的好处:
  1 创建一个新线程花费的时间少。
  2.(JAVA中线程具有新的,可运行,运行,等待/阻塞/休眠,死亡等几种状态。)在未阻塞情况下,两个线程(在同一进程中的)的切换时间少。在阻塞情况下,线程间切换将产生上下文切换。
  3.由于同一个进程内的线程共享内存和文件,所以线程之间互相通信不必调用内核。
  4 线程能独立执行,能充分利用和发挥处理机与外围设备并行工作的能力。
  使用线程可以把占据长时间的程序中的任务放到后台去处理
  ps:JAVA中可以通过jstack或者jprofiler dump出线程所执行的堆栈信息。
  3.如何理解响应时间
  响应时间反映完成某个业务所需要的时间。
  在性能测试中是通过测试工具的事物函数来完成响应时间的统计。事物函数会记录开始事物和结束事物的时间差,使用Transaction Response Time这个词来说明。
  响应时间主要包括网络时间,服务器处理时间,网络延迟
  对于交互式应用,用户直接的体验就是“响应时间”,通过“并发用户数”和“响应时间”可以确定系统的性能规划;
  对于交互式应用,响应时间出现拐点系统就可能出现瓶颈
  4.如何理解性能建模(可分类回答)
  这个不会,之前找到一个资料,分享一下吧 http://www.docin.com/p-452373613.html
  5.如何理解响应时间,TPS曲线和用户之间的关系
  随着用户数量的增加,在未出现瓶颈前响应时间保持稳定,TPS值和并发用户数成线性关系,出现瓶颈后响应时间变长,TPS基本保持不变或开始下降。
  6.在LoadRunner中为何要设置思考时间和pacing?
  1)Think time,思考时间。可以通过设置思考时间,来模拟真实用户在操作过程中的等待时间。从定义上来看,think time是在iteration内部的某个action中各个步骤的间隔时间。
  2)Pacing,步调。可以通过设置两次迭代(iteration)之间的间隔时间,来调整各个action之间的步调(或者称之为节奏)。
  3)pacing和think time都是可以模拟现实世界中的停顿。对于复杂场景,这个停顿要靠pacing来完成。不过,pacing怎么设置才最合适,是需要研究用户行为才能定的。
 操作系统
  1.如何判断CPU、内存、磁盘的瓶颈?
  CPU瓶颈:
  1) 查看CPU利用率。建议CPU指标如下
  a) User Time:65%~70%
  b) System Time:30%~35%
  c) Idle:0%~5%
  如果us,sy高于这个指标可以判断CPU有瓶颈
  使用top查看
  查看运行队列
  每个CPU都会维持一个运行队列,理想情况下,调度器会不断让队列中的进程运行。进程不是处在sleep状态就是run able状态。如果CPU过载,就会出现调度器跟不上系统的要求,导致可运行的进程会填满队列。队列愈大,程序执行时间就愈长。“load”用来表示运行队列,用top 命令我们可以看到CPU一分钟,5分钟和15分钟内的运行队列的大小。这个值越大表明系统负荷越大。超过 1.00,那么说明CPU已经超出负荷,交通严重的拥堵。
  使用top或者uptime查看
  查看上下文切换
  每个CPU(或多核CPU中每个核心)在同一时间只能执行一个线程,Linux采用抢占式调度。即为每个线程分配一定的执行时间,当到达执行时间,线程中有IO阻塞或高优先级线程要执行时,Linux将切换执行的线程,在切换时要存储目前线程的执行状态,并恢复要执行的线程状态,这个过程称之为上下文切换。对于java应用,典型的是在进行文件IO操作,网络IO操作,锁等待或线程sleep时,当前线程会进入阻塞或者休眠状态,从而触发上下文切换,上下文切换过多会造成内核占用过多的CPU使用,使得应用的响应速度下降。
  使用vmstat查看cs
  结论:
  检查system的运行队列,以及确定不要超出每个处理器3个可运行状态线程的限制.
  确定CPU 利用率中user/system比例维持在70/30
  当CPU 开销更多的时间在system mode,那就说明已经超负荷并且应该尝试重新调度优先级
  当I/O 处理得到增长,CPU 范畴的应用处理将受到影响
  ps:对于JAVA应用,CPU瓶颈可以通过jprofiler监控分析
  内存瓶颈:
  1.查看利用率(free)
  used:已使用多大。
  free:可用有多少。
  Shared:多个进程共享的内存总额。
  Buffers/cached:磁盘缓存的大小。
  2.查看页交换,swap交换(po,pi,so,si),磁盘IO(vmstat)
  si: 每秒从交换区写到内存的大小
  so: 每秒写入交换区的内存大小
  page in :分页(Page)从磁盘重新回到内存的过程被称作Page-In
  page out : 分页(Page)写入磁盘的过程被称作Page-Out
  另外在进行页交换的时候,会产生磁盘IO,还需注意bi,bo
  Bo 磁盘块页面从内存到文件或交换设备的总额
  Bi 磁盘块页面从文件或交换设备到内存的总额
  3.page fault(pidstat -r,sar -B )
  minflt/s: 每秒次缺页错误次数(minor page faults),次缺页错误次数意即虚拟内存地址映射成物理内存地址产生的page fault次数
  majflt/s: 每秒主缺页错误次数(major page faults),当虚拟内存地址映射成物理内存地址时,相应的page在swap中,这样的page fault为major page fault,一般在内存使用紧张时产生
  其中sar -B中fault/s表示每秒钟minflt,majflt的和。
  结论:
  监控虚拟内存性能由以下几个部分组成:
  1.当系统中出现较少的页错误,获得最好的响应时间,是因为memory caches(译注:内存高速缓存)比disk caches更快(译注:磁盘高速缓存).
  2.较少的空闲内存,是件好事情,那意味着缓存的使用更有效率.除非在不断的写入swap device和disk.
  3.如果系统不断报告,swap device总是繁忙中,那就意味着内存已经不足,需要升级了.
  zee:
  如果用做缓冲区(buff)和快速缓存(Cache)的物理内存不断地增加,而空闲的物理内存(free)不断地减少,证明系统中运行的进程正在不断地消耗物理内存。
  已经使用的虚拟内存(swpd)不断增加,而且存在着大量的页面交换(si和so),证明物理内存已经不能满足系统需求,系统必须把物理内存的页面交换到磁盘中去。
  由此可以得到这样的结论:该主机上的物理内存已经不能满足系统运行的需要,内存已成为该系统性能的一个瓶颈。
  ps:对于java程序,内存瓶颈可以通过heap dump后使用mat分析
  磁盘瓶颈:
  iostat查看IO信息。如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈。
  另外还需要注意iowait这个值,iowait 值高就意味着磁盘缓慢或负载过大。还有不要信任svctm这个字段。
  监控swap 和系统分区,要确保virtual memory不是文件系统I/O 的瓶颈.
  ps:磁盘瓶颈可以通过pidstat -d 定位程序
  2.如何理解CPU、内存、磁盘的关系?
  这些子系统之间关系是彼此联系,相互彼此依赖的
  1.对于进程来说,数据是存放在内存中的,进程的运行需要使用CPU,进程读写数据需要跟磁盘打交道。
  2.当内存不足时需要跟磁盘进行页(page)交换,swap交换,从而产生磁盘IO。po,so释放物理内存,pi,si增加物理内存使用。交换分页的过程需要占用cpu时间。 (内存占用过高)
  3.当磁盘IO负载过高时,需要监控swap和系统分区,要确保virtual memory不是文件系统I/O 的瓶颈。磁盘的相当慢的,当iowait 增长,表示CPU花费大量的时间在等待磁盘IO,此时CPU Bound的应用处理将受到影响(磁盘IO过高)
  3.如何理解paging in / paging out ?
  在Linux内存管理中,主要是通过“调页Paging”和“交换Swapping”来完成上述的内存调度。调页算法是将内存中最近不常使用的页面换到磁盘上,把活动页面保留在内存中供进程使用。交换技术是将整个进程,而不是部分页面,全部交换到磁盘上。
  分页(Page)写入磁盘的过程被称作Page-Out,分页(Page)从磁盘重新回到内存的过程被称作Page-In。当内核需要一个分页时,但发现此分页不在物理内存中(因为已经被Page-Out了),此时就发生了分页错误(Page Fault)。
  当系统内核发现可运行内存变少时,就会通过Page-Out来释放一部分物理内存。经管Page-Out不是经常发生,但是如果Page-out频繁不断的发生,直到当内核管理分页的时间超过运行程式的时间时,系统效能会急剧下降。这时的系统已经运行非常慢或进入暂停状态,这种状态亦被称作thrashing(颠簸)。
  可以通过vmstat -s 查看 paged in/out 数量
  4.如何监控操作系统的资源?(可用一个操作系统做例子)
  (把简历上部分内容直接贴出来了,懒的整理了)
  CPU监控:top(利用率), uptime(运行队列数), vmstat(上下文切换数), jprofile(方法占用cpu时间百分比)
  内存监控:top, free(利用率), vmstat(page和swap交换), pidstat -r和sar -B(page fault), jmap -heap(堆dump), mat和jprofiler(查看对象)
  磁盘监控:iostat(%util), top(iowait%), pidstat -d
  网络监控:netstat(连接数), nethogs(流量), wireshark和tcpdump(抓包)
  JVM监控:jstat(gc), jmap(堆dump), jstack(线程dump), jprofiler和visualvm(剖析工具)
  nmon(长时间全局收集数据)
  5.如何理解内存管理和线程调度?(可用一个操作系统做例子)
  不会
  6.如何理解上下文切换(context switch)?(可用一个操作系统做例子)
  每个CPU(或多核CPU中每个核心)在同一时间只能执行一个线程,Linux采用抢占式调度。即为每个线程分配一定的执行时间,当到达执行时间,线程中有IO阻塞或高优先级线程要执行时,Linux将切换执行的线程,在切换时要存储目前线程的执行状态,并恢复要执行的线程状态,这个过程称之为上下文切换。对于java应用,典型的是在进行文件IO操作,网络IO操作,锁等待或线程sleep时,当前线程会进入阻塞或者休眠状态,从而触发上下文切换,上下文切换过多会造成内核占用过多的CPU使用,使得应用的响应速度下降。
  vmstat其中cs那一列
  7.如何理解磁盘IO?(可用一个操作系统做例子)
  磁盘IO速度是非常慢的,linux内核就是要尽量降低IO
  内存不足时会进行页交换,产生磁盘IO
  CPU Bound类型应用,当磁盘IO过多,iowait过大时会影响性能。
 操作系统
  1.如何判断CPU、内存、磁盘的瓶颈?
  CPU瓶颈:
  1) 查看CPU利用率。建议CPU指标如下
  a) User Time:65%~70%
  b) System Time:30%~35%
  c) Idle:0%~5%
  如果us,sy高于这个指标可以判断CPU有瓶颈
  使用top查看
  查看运行队列
  每个CPU都会维持一个运行队列,理想情况下,调度器会不断让队列中的进程运行。进程不是处在sleep状态就是run able状态。如果CPU过载,就会出现调度器跟不上系统的要求,导致可运行的进程会填满队列。队列愈大,程序执行时间就愈长。“load”用来表示运行队列,用top 命令我们可以看到CPU一分钟,5分钟和15分钟内的运行队列的大小。这个值越大表明系统负荷越大。超过 1.00,那么说明CPU已经超出负荷,交通严重的拥堵。
  使用top或者uptime查看
  查看上下文切换
  每个CPU(或多核CPU中每个核心)在同一时间只能执行一个线程,Linux采用抢占式调度。即为每个线程分配一定的执行时间,当到达执行时间,线程中有IO阻塞或高优先级线程要执行时,Linux将切换执行的线程,在切换时要存储目前线程的执行状态,并恢复要执行的线程状态,这个过程称之为上下文切换。对于java应用,典型的是在进行文件IO操作,网络IO操作,锁等待或线程sleep时,当前线程会进入阻塞或者休眠状态,从而触发上下文切换,上下文切换过多会造成内核占用过多的CPU使用,使得应用的响应速度下降。
  使用vmstat查看cs
  结论:
  检查system的运行队列,以及确定不要超出每个处理器3个可运行状态线程的限制.
  确定CPU 利用率中user/system比例维持在70/30
  当CPU 开销更多的时间在system mode,那就说明已经超负荷并且应该尝试重新调度优先级
  当I/O 处理得到增长,CPU 范畴的应用处理将受到影响
  ps:对于JAVA应用,CPU瓶颈可以通过jprofiler监控分析
  内存瓶颈:
  1.查看利用率(free)
  used:已使用多大。
  free:可用有多少。
  Shared:多个进程共享的内存总额。
  Buffers/cached:磁盘缓存的大小。
  2.查看页交换,swap交换(po,pi,so,si),磁盘IO(vmstat)
  si: 每秒从交换区写到内存的大小
  so: 每秒写入交换区的内存大小
  page in :分页(Page)从磁盘重新回到内存的过程被称作Page-In
  page out : 分页(Page)写入磁盘的过程被称作Page-Out
  另外在进行页交换的时候,会产生磁盘IO,还需注意bi,bo
  Bo 磁盘块页面从内存到文件或交换设备的总额
  Bi 磁盘块页面从文件或交换设备到内存的总额
  3.page fault(pidstat -r,sar -B )
  minflt/s: 每秒次缺页错误次数(minor page faults),次缺页错误次数意即虚拟内存地址映射成物理内存地址产生的page fault次数
  majflt/s: 每秒主缺页错误次数(major page faults),当虚拟内存地址映射成物理内存地址时,相应的page在swap中,这样的page fault为major page fault,一般在内存使用紧张时产生
  其中sar -B中fault/s表示每秒钟minflt,majflt的和。
  结论:
  监控虚拟内存性能由以下几个部分组成:
  1.当系统中出现较少的页错误,获得最好的响应时间,是因为memory caches(译注:内存高速缓存)比disk caches更快(译注:磁盘高速缓存).
  2.较少的空闲内存,是件好事情,那意味着缓存的使用更有效率.除非在不断的写入swap device和disk.
  3.如果系统不断报告,swap device总是繁忙中,那就意味着内存已经不足,需要升级了.
  zee:
  如果用做缓冲区(buff)和快速缓存(Cache)的物理内存不断地增加,而空闲的物理内存(free)不断地减少,证明系统中运行的进程正在不断地消耗物理内存。
  已经使用的虚拟内存(swpd)不断增加,而且存在着大量的页面交换(si和so),证明物理内存已经不能满足系统需求,系统必须把物理内存的页面交换到磁盘中去。
  由此可以得到这样的结论:该主机上的物理内存已经不能满足系统运行的需要,内存已成为该系统性能的一个瓶颈。
  ps:对于java程序,内存瓶颈可以通过heap dump后使用mat分析
  磁盘瓶颈:
  iostat查看IO信息。如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈。
  另外还需要注意iowait这个值,iowait 值高就意味着磁盘缓慢或负载过大。还有不要信任svctm这个字段。
  监控swap 和系统分区,要确保virtual memory不是文件系统I/O 的瓶颈.
  ps:磁盘瓶颈可以通过pidstat -d 定位程序
  2.如何理解CPU、内存、磁盘的关系?
  这些子系统之间关系是彼此联系,相互彼此依赖的
  1.对于进程来说,数据是存放在内存中的,进程的运行需要使用CPU,进程读写数据需要跟磁盘打交道。
  2.当内存不足时需要跟磁盘进行页(page)交换,swap交换,从而产生磁盘IO。po,so释放物理内存,pi,si增加物理内存使用。交换分页的过程需要占用cpu时间。 (内存占用过高)
  3.当磁盘IO负载过高时,需要监控swap和系统分区,要确保virtual memory不是文件系统I/O 的瓶颈。磁盘的相当慢的,当iowait 增长,表示CPU花费大量的时间在等待磁盘IO,此时CPU Bound的应用处理将受到影响(磁盘IO过高)
  3.如何理解paging in / paging out ?
  在Linux内存管理中,主要是通过“调页Paging”和“交换Swapping”来完成上述的内存调度。调页算法是将内存中最近不常使用的页面换到磁盘上,把活动页面保留在内存中供进程使用。交换技术是将整个进程,而不是部分页面,全部交换到磁盘上。
  分页(Page)写入磁盘的过程被称作Page-Out,分页(Page)从磁盘重新回到内存的过程被称作Page-In。当内核需要一个分页时,但发现此分页不在物理内存中(因为已经被Page-Out了),此时就发生了分页错误(Page Fault)。
  当系统内核发现可运行内存变少时,就会通过Page-Out来释放一部分物理内存。经管Page-Out不是经常发生,但是如果Page-out频繁不断的发生,直到当内核管理分页的时间超过运行程式的时间时,系统效能会急剧下降。这时的系统已经运行非常慢或进入暂停状态,这种状态亦被称作thrashing(颠簸)。
  可以通过vmstat -s 查看 paged in/out 数量
  4.如何监控操作系统的资源?(可用一个操作系统做例子)
  (把简历上部分内容直接贴出来了,懒的整理了)
  CPU监控:top(利用率), uptime(运行队列数), vmstat(上下文切换数), jprofile(方法占用cpu时间百分比)
  内存监控:top, free(利用率), vmstat(page和swap交换), pidstat -r和sar -B(page fault), jmap -heap(堆dump), mat和jprofiler(查看对象)
  磁盘监控:iostat(%util), top(iowait%), pidstat -d
  网络监控:netstat(连接数), nethogs(流量), wireshark和tcpdump(抓包)
  JVM监控:jstat(gc), jmap(堆dump), jstack(线程dump), jprofiler和visualvm(剖析工具)
  nmon(长时间全局收集数据)
  5.如何理解内存管理和线程调度?(可用一个操作系统做例子)
  不会
  6.如何理解上下文切换(context switch)?(可用一个操作系统做例子)
  每个CPU(或多核CPU中每个核心)在同一时间只能执行一个线程,Linux采用抢占式调度。即为每个线程分配一定的执行时间,当到达执行时间,线程中有IO阻塞或高优先级线程要执行时,Linux将切换执行的线程,在切换时要存储目前线程的执行状态,并恢复要执行的线程状态,这个过程称之为上下文切换。对于java应用,典型的是在进行文件IO操作,网络IO操作,锁等待或线程sleep时,当前线程会进入阻塞或者休眠状态,从而触发上下文切换,上下文切换过多会造成内核占用过多的CPU使用,使得应用的响应速度下降。
  vmstat其中cs那一列
  7.如何理解磁盘IO?(可用一个操作系统做例子)
  磁盘IO速度是非常慢的,linux内核就是要尽量降低IO
  内存不足时会进行页交换,产生磁盘IO
  CPU Bound类型应用,当磁盘IO过多,iowait过大时会影响性能。

最新内容请见作者的GitHub页:http://qaseven.github.io/

时间: 2024-12-31 03:03:17

码农的性能测试的相关文章

快乐Node码农的十个习惯

从问世到现在将近20年,JavaScript一直缺乏其它有吸引力的编程语言,比如Python和Ruby,的很多优点:命令行界面,REPL,包管理器,以及组织良好的开源社区.感谢Node.js和npm,现如今的JavaScript鸟枪换炮了.Web开发者有了强大的新工具,接下来就看他们的想象力了. 下面这个提示和技巧清单,能让你和你的node程序保持快乐. 1. 用npm init开始新项目 npm有个init命令,可以引导你完成创建package.json文件的过程.即便你非常熟悉package

码农的2014年,年终总结

问题描述 码农的2014年,年终总结 公司无法写博客,改天回家改下,对不住大家了 HI,2015: 我个人是个工作狂,也是研究技术狂,不太喜欢过旧的生活,本来前两天应该总结, 回老家啦--媳妇生小孩啦,我升级了--呵呵-- 公司工作: 2014年初,主要负责xx公司里的应用版本平台服务接口开发,为解决业务问题, 详细了解mybatis和mysql之间sql底层数据交付,完成文件批量上传,优化数据库,借鉴老应用版本的业务, 设计数据库,核心业务逻辑编写和引导新同学. 微信公众平台:功能有,微信用户

码农从菜鸟到大牛的必须文章

几年前我也是一个码农菜鸟,我也常常幻想着成为技术大牛. 如何减小与"大牛"的差距是我常常不得不面对的话题.今天从我走过来的路来总结一下成为大牛的技术之路. 先来看一张程序员的时间管理图. 除了时间管理,技术学习也是少不了的.下面推荐一下比较好的技术文章. 使用瀑布流插件 Masonry 进行瀑布流布局 业余草微信公众号上线了! 使用HTML5 Canvas实现火焰风暴动画 HTML5 实现3D翻转立方体 使用 HTML5 制作像素太空战机游戏 常用的Linux关机命令大全 5个常用的L

也谈“为什么中国的程序员总被称为码农?”

        我经常在CSDN上浏览新闻,同时也喜欢阅读博客.最近,我看到有不少文章在谈"为什么中国的程序员总被称为码农"这个话题.大家虽然各抒己见,但都在表明一个事实:在中国做程序员真的很累,与种地的农民没有什么区别.        作为一个刚工作不久的程序员新手,我想就自己的经历谈一下对这个话题的认识.        在学校的时候,我们对那些"IT界的英雄"很是敬佩,包括:盖茨.乔布斯.扎克伯格,以及大家都很熟悉的李开复老师.想到他们用自己的智慧改变了人类的生

阿里巴巴六年码农自白

各位亲爱的网友朋友大家好,又到了回顾上周新闻的时候了.上一周热闹的事情比较多,我们把他们拆开来看一下. 首先看一下开发者感兴趣的话题.一提到开发,大家可能都会想到一个形容词,那就是"辛苦".的确,开发人员的工作量非常的大,所以很多开发人员被冠以了"码农"的称号.上周点击量第一的文章,标题就叫"一个阿里巴巴码农的六年回眸"这篇文章讲述了一个码农的六年心路历程,中心思想总结起来就是:"技术耐得住寂寞,低谷积累高峰冲刺,主动改变一切.&quo

ThinkPHP3.2.1版本正式发布了,马年码农们的福音

在这个特别的日子里, ThinkPHP3.2.1版本http://www.aliyun.com/zixun/aggregation/18782.html">正式发布了,祝马年码农们元宵节情人节快乐啊^_^ 在继此前发布的3.2.0版本对ThinkPHP的架构作出重大调整之后,ThinkPHP3.2.1版本在修正一些BUG后,着重优化了性能,并提高了 易用性,同时也增加了不少的扩展功能,是一个比3.2.0版本更加 稳定.安全.高效以及易用的版本.强烈推荐升级. [ 更新 ] 相对于3.2.0

程序员 软件工程师-研究生毕业28.5岁了,还可以当码农吗?会有单位要吗?

问题描述 研究生毕业28.5岁了,还可以当码农吗?会有单位要吗? 研究生毕业28.5岁了,还可以当码农吗?会有单位要吗? 研究生毕业28.5岁了,还可以当码农吗?会有单位要吗? 电子信息工程专业 解决方案 肯定有!但是起薪可能不高,发展不可限量的 解决方案二: 可以的,关键看自身的水平了.姐姐考考你,请问能用C++写一个Basic解释器么? 解决方案三: 这么年轻啊,找对方向,没问题 解决方案四: 现在码农这么缺的时代,当然可以 解决方案五: 研究生阶段都学了啥呢?只要你不介意,有基础当然可以当

码农们每天到底在干嘛?

摘要: 腾讯科技讯 (王冠)对于绝大多数网友来说,产品开发都是一件很神秘的事情.那些天书般的代码经过程序猿.工程狮们的双手敲击,就能产生各种奇妙的画面和有趣功能. 从用户的 腾讯科技讯(王冠)对于绝大多数网友来说,产品开发都是一件很神秘的事情.那些天书般的代码经过程序猿.工程狮们的双手敲击,就能产生各种奇妙的画面和有趣功能. 从用户的角度看,产品一直都是稳定而简洁的.那些码农们每天都在敲啊敲的,他们到底在干嘛?有人说,我知道,有个家伙用了一个星期写了个游戏,然后他让一亿人一起打飞机-- 多么壮观

2016版码农跳槽指南:云架构师成香饽饽

本文讲的是2016版码农跳槽指南:云架构师成香饽饽[IT168 云计算]2016云栖大会上海峰会召开前夕,阿里云透露将在本次大会上首次推出开放实验室workshop,为技术爱好者搭建实验平台,帮助他们迅速了解阿里云的产品特性,并快速上手. 阿里巴巴开源小组总监沈金堤表示,workshop是业界流行的线下技术交流形式,不仅有助于开发者理解掌握云计算相关的知识和技能,更可以和阿里云的专家一起探索云产品的最佳实践. 沈金堤介绍,阿里云开放实验室workshop设计了的丰富的产品应用场景供开发者动手实验