1.1 cpu 性能查看
1, 查看物理 cpu 个数:
cat /proc/cpuinfo |grep "physical id"|sort|uniq|wc -l
2, 查看每个物理 cpu 中的 core 个数:
cat /proc/cpuinfo |grep "cpu cores"|wc -l
3, 逻辑 cpu 的个数:
cat /proc/cpuinfo |grep "processor"|wc -l
物理 cpu 个数 * 核数 = 逻辑 cpu 个数(不支持超线程技术的情况下)
1.2 内存查看
1, 查看内存使用情况:
#free -m total used free shared buffers cachedMem: 3949 2519 1430 0 189 1619-/+ buffers/cache: 710 3239Swap: 3576 0 3576total: 内存总数 used: 已经使用的内存数 free: 空闲内存数 shared: 多个进程共享的内存总额 - buffers/cache:(已用)的内存数, 即 used-buffers-cached+ buffers/cache:(可用)的内存数, 即 free+buffers+cachedBuffer Cache 用于针对磁盘块的读写; Page Cache 用于针对文件 inode 的读写, 这些 Cache 能有效地缩短 I/O 系统调用的时间. 对操作系统来说 free/used 是系统可用 / 占用的内存; 对应用程序来说 -/+ buffers/cache 是可用 / 占用内存, 因为 buffers/cache 很快就会被使用.
我们工作时候应该从应用角度来看.
1.3 硬盘查看
1, 查看硬盘及分区信息:
fdisk -l
2, 查看文件系统的磁盘空间占用情况:
df -h
3, 查看硬盘的 I/O 性能(每隔一秒显示一次, 显示 5 次):
iostat -x 1 5
iostat 是含在套装 systat 中的, 可以用 yum -y install systat 来安装.
常关注的参数:
如 %util 接近 100%, 说明产生的 I/O 请求太多, I/O 系统已经满负荷, 该磁盘可能存在瓶颈. 如 idle 小于 70%,I/O 的压力就比较大了, 说明读取进程中有较多的 wait.
4, 查看 linux 系统中某目录的大小:
du -sh /root
如发现某个分区空间接近用完, 可以进入该分区的挂载点, 用以下命令找出占用空间最多的文件或目录, 然后按照从大到小的顺序, 找出系统中占用最多空间的前 10 个文件或目录:
du -cksh *|sort -rn|head -n 10
1.4 查看平均负载
有时候系统响应很慢, 但又找不到原因, 这时就要查看平均负载了, 看它是否有大量的进程在排队等待.
最简单的命令:
uptime-- 查看过去的 1 分钟, 5 分钟和 15 分钟内进程队列中的平均进程数量.
还有动态命令 top 我们只关心以下部分:
top - 21:33:09 up 1:00, 1 user, load average: 0.00, 0.01, 0.05 如果每个逻辑 cpu 当前的活动进程不大于 3, 则系统性能良好; 如果每个逻辑 cpu 当前的活动进程不大于 4, 表示可以接受; 如果每个逻辑 cpu 当前的活动进程大于 5, 则系统性能问题严重.
一般计算方法: 负载值 / 逻辑 cpu 个数
还可以结合 vmstat 命令来判断系统是否繁忙, 其中:
procsr: 等待运行的进程数. b: 处在非中断睡眠状态的进程数. w: 被交换出去的可运行的进程数. memeoryswpd: 虚拟内存使用情况, 单位为 KB.free: 空闲的内存, 单位为 KB.buff: 被用来作为缓存的内存数, 单位为 KB.swapsi: 从磁盘交换到内存的交换页数量, 单位为 KB.so: 从内存交换到磁盘的交换页数量, 单位为 KB.iobi: 发送到块设备的块数, 单位为 KB.bo: 从块设备接受的块数, 单位为 KB.systemin: 每秒的中断数, 包括时钟中断. cs: 每秒的环境切换次数. cpu 按 cpu 的总使用百分比来显示. us:cpu 使用时间. sy:cpu 系统使用时间. id: 闲置时间.
1.5 其他参数
查看内核版本号: uname -a 简化命令: uname -r 查看系统是 32 位还是 64 位的: file /sbin/init 查看发行版: cat /etc/issue 或 lsb_release -a 查看系统已载入的相关模块: lsmod 查看 pci 设置: lspci
二 Linux 服务器性能评估
2.1.1 影响 Linux 服务器性能的因素
1. 操作系统级
CPU 内存磁盘 I/O 带宽网络 I/O 带宽
2. 程序应用级
2.1.2 系统性能评估标准
影响性能因素 | 好 | 坏 | 糟糕 |
---|---|---|---|
CPU | user% + sys%< 70% | user% + sys%= 85% | user% + sys% >=90% |
内存 | Swap In(si)=0 Swap Out(so)=0 | Per CPU with 10 page/s | More Swap In & Swap Out |
磁盘 | iowait % < 20% | iowait % =35% | iowait % >= 50% |
其中:
%user: 表示 CPU 处在用户模式下的时间百分比.%sys: 表示 CPU 处在系统模式下的时间百分比.%iowait: 表示 CPU 等待输入输出完成时间的百分比. swap in: 即 si, 表示虚拟内存的页导入, 即从 SWAP DISK 交换到 RAMswap out: 即 so, 表示虚拟内存的页导出, 即从 RAM 交换到 SWAP DISK
2.1.3 系统性能分析工具
1. 常用系统命令
Vmstat,sar,iostat,netstat,free,ps,top 等
2. 常用组合方式
vmstat,sar,iostat 检测是否是 CPU 瓶颈 free,vmstat 检测是否是内存瓶颈 iostat 检测是否是磁盘 I/O 瓶颈 netstat 检测是否是网络带宽瓶颈
2.1.4 Linux 性能评估与优化
系统整体性能评估(uptime 命令)uptime
16:38:00 up 118 days, 3:01, 5 users,load average: 1.22, 1.02, 0.91
注意:
load average 三值大小一般不能大于系统 CPU 的个数.
系统有 8 个 CPU, 如 load average 三值长期大于 8, 说明 CPU 很繁忙, 负载很高, 可能会影响系统性能.
但偶尔大于 8, 一般不会影响系统性能.
如 load average 输出值小于 CPU 个数, 则表示 CPU 有空闲时间片, 比如本例中的输出, CPU 是非常空闲的
2.2.1 CPU 性能评估
1. 利用 vmstat 命令监控系统 CPU
显示系统各种资源之间相关性能简要信息, 主要看 CPU 负载情况.
下面是 vmstat 命令在某个系统的输出结果:
[root@node1 ~]#vmstat 2 3procs ----memory---- -swap- --io-- -system- --cpu--r b swpd freebuff cache si so bi bo incs us sy idwa st0 0 0 162240 8304 67032 0 0 13 21 1007 23 0 1 98 0 00 0 0 162240 8304 67032 0 0 1 0 1010 20 0 1 100 0 00 0 0 162240 8304 67032 0 0 1 1 1009 18 0 1 99 0 0Procs
r-- 运行和等待 cpu 时间片的进程数, 这个值如果长期大于系统 CPU 的个数, 说明 CPU 不足, 需要增加 CPU
b-- 在等待资源的进程数, 比如正在等待 I/O, 或者内存交换等.
CPU
# us
用户进程消耗的 CPU 时间百分比. us 的值比较高时, 说明用户进程消耗的 cpu 时间多, 但是如果长期大于 50%, 就需要考虑优化程序或算法.
# sy
内核进程消耗的 CPU 时间百分比. Sy 的值较高时, 说明内核消耗的 CPU 资源很多.
根据经验, us+sy 的参考值为 80%, 如果 us+sy 大于 80% 说明可能存在 CPU 资源不足.
2. 利用 sar 命令监控系统 CPU
sar 对系统每方面进行单独统计, 但会增加系统开销, 不过开销可以评估, 对系统的统计结果不会有很大影响.
下面是 sar 命令对某个系统的 CPU 统计输出:
[root@webserver ~]# sar -u 3 5Linux 2.6.9-42.ELsmp (webserver) 11/28/2008_i686_ (8 CPU)11:41:24 AM CPU %user %nice%system %iowait %steal %idle11:41:27 AM all 0.88 0.00 0.29 0.00 0.00 98.8311:41:30 AM all 0.13 0.00 0.17 0.21 0.00 99.5011:41:33 AM all 0.04 0.00 0.04 0.00 0.00 99.9211:41:36 AM all 90.08 0.00 0.13 0.16 0.00 9.6311:41:39 AM all 0.38 0.00 0.17 0.04 0.00 99.41Average: all 0.34 0.00 0.16 0.05 0.00 99.45
输出解释如下:
%user 列显示了用户进程消耗的 CPU 时间百分比.%nice 列显示了运行正常进程所消耗的 CPU 时间百分比.%system 列显示了系统进程消耗的 CPU 时间百分比.%iowait 列显示了 IO 等待所占用的 CPU 时间百分比 %steal 列显示了在内存相对紧张的环境下 pagein 强制对不同的页面进行的 steal 操作 .%idle 列显示了 CPU 处在空闲状态的时间百分比. 问题
你是否遇到过系统 CPU 整体利用率不高, 而应用缓慢的现象?
在一个多 CPU 的系统中, 如果程序使用了单线程, 会出现这么一个现象, CPU 的整体使用率不高, 但是系统应用却响应缓慢, 这可能是由于程序使用单线程的原因, 单线程只使用一个 CPU, 导致这个 CPU 占用率为 100%, 无法处理其它请求, 而其它的 CPU 却闲置, 这就导致了整体 CPU 使用率不高, 而应用缓慢现象的发生.
2.3.1 内存性能评估
1. 利用 free 指令监控内存
free 是监控 Linux 内存使用状况最常用的指令, 看下面的一个输出:
[root@webserver ~]# free -mtotal used freeshared buffers cachedMem: 8111 7185 926 0 243 6299 -/+ buffers/cache: 643 7468Swap: 8189 0 8189
经验公式:
应用程序可用内存 / 系统物理内存 > 70%, 表示系统内存资源非常充足, 不影响系统性能; 应用程序可用内存 / 系统物理内存 < 20%, 表示系统内存资源紧缺, 需要增加系统内存; 20%<应用程序可用内存 / 系统物理内存 < 70%, 表示系统内存资源基本能满足应用需求, 暂时不影响系统性能
2. 利用 vmstat 命令监控内存
- [root@node1 ~]# vmstat 2 3procs ----memory---- -swap- --io-- -system- --cpu--r b swpd freebuff cache si so bi bo incs us sy idwa st0 0 0 162240 8304 67032 0 0 13 21 1007 23 0 1 98 0 00 0 0 162240 8304 67032 0 0 1 0 1010 20 0 1 100 0 00 0 0 162240 8304 67032 0 0 1 1 1009 18 0 1 99 0 0
- memory
swpd-- 切换到内存交换区的内存数量(k 为单位). 如 swpd 值偶尔非 0, 不影响系统性能 free-- 当前空闲的物理内存数量(k 为单位)buff--buffers cache 的内存数量, 一般对块设备的读写才需要缓冲 cache--page cached 的内存数量
一般作为文件系统 cached, 频繁访问的文件都会被 cached, 如 cache 值较大, 说明 cached 的文件数较多, 如果此时 IO 中 bi 比较小, 说明文件系统效率比较好.
swap
si-- 由磁盘调入内存, 也就是内存进入内存交换区的数量. so-- 由内存调入磁盘, 也就是内存交换区进入内存的数量.
si,so 的值长期不为 0, 表示系统内存不足. 需增加系统内存.
2.4.1 磁盘 I/O 性能评估
1. 磁盘存储基础
频繁访问的文件或数据尽可能用内存读写代替直接磁盘 I/O, 效率高千倍.
将经常进行读写的文件与长期不变的文件独立出来, 分别放置到不同的磁盘设备上.
对于写操作频繁的数据, 可以考虑使用裸设备代替文件系统.
裸设备优点:
数据可直接读写, 不需经过操作系统级缓存, 节省内存资源, 避免内存资源争用; 避免文件系统级维护开销, 如文件系统需维护超级块, I-node 等; 避免了操作系统 cache 预读功能, 减少了 I/O 请求
使用裸设备的缺点是:
数据管理, 空间管理不灵活, 需要很专业的人来操作.
2. 利用 iostat 评估磁盘性能
[root@webserver ~]# iostat -d 2 3Linux 2.6.9-42.ELsmp (webserver) 12/01/2008_i686_ (8 CPU)Device: tps Blk_read/sBlk_wrtn/sBlk_read Blk_wrtnsda 1.87 2.58 114.12 6479462 286537372Device: tps Blk_read/sBlk_wrtn/sBlk_read Blk_wrtnsda 0.00 0.00 0.00 0 0Device: tps Blk_read/sBlk_wrtn/sBlk_read Blk_wrtnsda 1.00 0.00 12.00 0 24
解释如下:
Blk_read/s-- 每秒读取数据块数 Blk_wrtn/s-- 每秒写入数据块数 Blk_read-- 读取的所有块数 Blk_wrtn-- 写入的所有块数
可通过 Blk_read/s 和 Blk_wrtn/s 值对磁盘的读写性能有一个基本的了解. 如 Blk_wrtn/s 值很大, 表示磁盘写操作频繁, 考虑优化磁盘或程序, 如 Blk_read/s 值很大, 表示磁盘直接读操作很多, 可将读取的数据放入内存
规则遵循:
长期的, 超大的数据读写, 肯定是不正常的, 这种情况一定会影响系统性能.
3. 利用 sar 评估磁盘性能
通过 "sar -d" 组合, 可以对系统的磁盘 IO 做一个基本的统计, 请看下面的一个输出:
[root@webserver ~]# sar -d 2 3Linux 2.6.9-42.ELsmp (webserver) 11/30/2008_i686_ (8 CPU)11:09:33 PM DEV tps rd_sec/swr_sec/savgrq-sz avgqu-sz await svctm %util11:09:35 PM dev8-0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.0011:09:35 PM DEV tps rd_sec/swr_sec/savgrq-sz avgqu-sz await svctm %util11:09:37 PM dev8-0 1.00 0.00 12.00 12.00 0.00 0.00 0.00 0.0011:09:37 PM DEV tps rd_sec/swr_sec/savgrq-sz avgqu-sz await svctm %util11:09:39 PM dev8-0 1.99 0.00 47.76 24.00 0.00 0.50 0.25 0.05Average: DEV tps rd_sec/swr_sec/savgrq-sz avgqu-sz await svctm %utilAverage: dev8-0 1.00 0.00 19.97 20.00 0.00 0.33 0.17 0.02
参数含义:
await-- 平均每次设备 I/O 操作等待时间(毫秒)svctm-- 平均每次设备 I/O 操作的服务时间(毫秒)%util-- 一秒中有百分之几的时间用于 I/O 操作
对磁盘 IO 性能评判标准:
正常 svctm 应小于 await 值, 而 svctm 和磁盘性能有关, CPU, 内存负荷也会对 svctm 值造成影响, 过多的请求也会间接的导致 svctm 值的增加.
await 值取决 svctm 和 I/O 队列长度以及 I/O 请求模式, 如果 svctm 的值与 await 很接近, 表示几乎没有 I/O 等待, 磁盘性能很好, 如果 await 的值远高于 svctm 的值, 则表示 I/O 队列等待太长, 系统上运行的应用程序将变慢, 此时可以通过更换更快的硬盘来解决问题.
%util-- 衡量磁盘 I/O 重要指标,
如 %util 接近 100%, 表示磁盘产生的 I/O 请求太多, I/O 系统已经满负荷工作, 该磁盘可能存在瓶颈.
可优化程序或者 通过更换 更高, 更快的磁盘.
2.5.1. 网络性能评估
(1)通过 ping 命令检测网络的连通性 (2) 通过 netstat -i 组合检测网络接口状况 (3) 通过 netstat -r 组合检测系统的路由表信息 (4) 通过 sar -n 组合显示系统的网络运行状态
三 Linux 服务器性能调优
1. 为磁盘 I/O 调整 Linux 内核电梯算法
选择文件系统后, 该算法可以平衡低延迟需求, 收集足够数据, 有效组织对磁盘读写请求.
2. 禁用不必要的守护进程, 节省内存和 CPU 资源
许多守护进程或服务通常非必需, 消耗宝贵内存和 CPU 时间. 将服务器置于险地. 禁用可加快启动时间, 释放内存. 减少 CPU 要处理的进程数
一些应被禁用的 Linux 守护进程, 默认自动运行:
序号 守护进程 描述 1 Apmd 高级电源管理守护进程 2 Nfslock 用于 NFS 文件锁定 3 Isdn ISDN Moderm 支持 4 Autofs 在后台自动挂载文件系统(如自动挂载 CD-ROM)5 Sendmail 邮件传输代理 6 Xfs X Window 的字体服务器
3. 关掉 GUI
4, 清理不需要的模块或功能
服务器软件包中太多被启动的功能或模块实际上是不需要的(如 Apache 中的许多功能模块), 禁用掉有助于提高系统内存可用量, 腾出资源给那些真正需要的软件, 让它们运行得更快.
5, 禁用控制面板
在 Linux 中, 有许多流行的控制面板, 如 Cpanel,Plesk,Webmin 和 phpMyAdmin 等, 禁用释放出大约 120MB 内存, 内存使用量大约下降 30-40%.
6, 改善 Linux Exim 服务器性能
使用 DNS 缓存守护进程, 可降低解析 DNS 记录需要的带宽和 CPU 时间, DNS 缓存通过消除每次都从根节点开始查找 DNS 记录的需求, 从而改善网络性能.
Djbdns 是一个非常强大的 DNS 服务器, 它具有 DNS 缓存功能, Djbdns 比 BIND DNS 服务器更安全, 性能更好, 可以直接通过 http://cr.yp.to / 下载, 或通过 Red Hat 提供的软件包获得.
7, 使用 AES256 增强 gpg 文件加密安全
为提高备份文件或敏感信息安全, 许多 Linux 系统管理员都使用 gpg 进行加密, 在使用 gpg 时, 最好指定 gpg 使用 AES256 加密算法, AES256 使用 256 位密钥, 它是一个开放的加密算法, 美国国家安全局 (NSA) 使用它保护绝密信息.
8, 远程备份服务安全
安全是选择远程备份服务最重要的因素, 大多数系统管理员都害怕两件事:(黑客)可以删除备份文件, 不能从备份恢复系统.
为了保证备份文件 100% 的安全, 备份服务公司提供远程备份服务器, 使用 scp 脚本或 RSYNC 通过 SSH 传输数据, 这样, 没有人可以直接进入和访问远程系统, 因此, 也没有人可以从备份服务删除数据. 在选择远程备份服务提供商时, 最好从多个方面了解其服务强壮性, 如果可以, 可以亲自测试一下.
9, 更新默认内核参数设置
为了顺利和成功运行企业应用程序, 如数据库服务器, 可能需要更新一些默认的内核参数设置, 例如, 2.4.x 系列内核消息队列参数 msgmni 有一个默认值(例如, 共享内存, 或 shmmax 在 Red Hat 系统上默认只有 33554432 字节), 它只允许有限的数据库并发连接, 下面为数据库服务器更好地运行提供了一些建议值(来自 IBM DB2 支持网站):
kernel.shmmax=268435456 (32 位)kernel.shmmax=1073741824 (64 位)kernel.msgmni=1024 fs.file-max=8192kernel.sem="250 32000 32 1024
10, 优化 TCP
优化 TCP 协议有助于提高网络吞吐量, 跨广域网的通信使用的带宽越大, 延迟时间越长时, 建议使用越大的 TCP Linux 大小, 以提高数据传输速率, TCP Linux 大小决定了发送主机在没有收到数据传输确认时, 可以向接收主机发送多少数据.
11, 选择正确的文件系统
使用 ext4 文件系统取代 ext3
Ext4 是 ext3 文件系统的增强版, 扩展了存储限制
具有日志功能, 保证高水平的数据完整性(在非正常关闭事件中)
非正常关闭和重启时, 它不需要检查磁盘(这是一个非常耗时的动作)
更快的写入速度, ext4 日志优化了硬盘磁头动作
12, 使用 noatime 文件系统挂载选项
在文件系统启动配置文件 fstab 中使用 noatime 选项, 如果使用了外部存储, 这个挂载选项可以有效改善性能.
13, 调整 Linux 文件描述符限制
Linux 限制了任何进程可以打开的文件描述符数量, 默认限制是每进程 1024, 这些限制可能会阻碍基准测试客户端 (如 httperf 和 apachebench) 和 Web 服务器本身获得最佳性能, Apache 每个连接使用一个进程, 因此不会受到影响, 但单进程 Web 服务器, 如 Zeus 是每连接使用一个文件描述符, 因此很容易受默认限制的影响.
打开文件限制是一个可以用 ulimit 命令调整的限制, ulimit -aS 命令显示当前的限制, ulimit -aH 命令显示硬限制(在未调整 / proc 中的内核参数前, 你不能增加限制).
Linux 第三方应用程序性能技巧
对于运行在 Linux 上的第三方应用程序, 一样有许多性能优化技巧, 这些技巧可以帮助你提高 Linux 服务器的性能, 降低运行成本.
14, 正确配置 MySQL
为了给 MySQL 分配更多的内存, 可设置 MySQL 缓存大小, 要是 MySQL 服务器实例使用了更多内存, 就减少缓存大小, 如果 MySQL 在请求增多时停滞不动, 就增加 MySQL 缓存.
15, 正确配置 Apache
检查 Apache 使用了多少内存, 再调整 StartServers 和 MinSpareServers 参数, 以释放更多的内存, 将有助于你节省 30-40% 的内存.
16, 分析 Linux 服务器性能
提高系统效率最好的办法是找出导致整体速度下降的瓶颈并解决掉, 下面是找出系统关键瓶颈的一些基本技巧:
当大型应用程序, 如 OpenOffice 和 Firefox 同时运行时, 计算机可能会开始变慢, 内存不足的出现几率更高.
如果启动时真的很慢, 可能是应用程序初次启动需要较长的加载时间, 一旦启动好后运行就正常了, 否则很可能是硬盘太慢了.
CPU 负载持续很高, 内存也够用, 但 CPU 利用率很低, 可以使用 CPU 负载分析工具监控负载时间.
17, 学习 5 个 Linux 性能命令
使用几个命令就可以管理 Linux 系统的性能了, 下面列出了 5 个最常用的 Linux 性能命令, 包括 top,vmstat,iostat,free 和 sar, 它们有助于系统管理员快速解决性能问题.
(1)top
当前内核服务的任务, 还显示许多主机状态的统计数据, 默认情况下, 它每隔 5 秒自动更新一次. 如: 当前正常运行时间, 系统负载, 进程数量和内存使用率,
此外, 这个命令也显示了那些使用最多 CPU 时间的进程(包括每个进程的各种信息, 如运行用户, 执行的命令等).
(2)vmstat
Vmstat 命令提供当前 CPU,IO, 进程和内存使用率的快照, 它和 top 命令类似, 自动更新数据, 如:
- $ vmstat 10
- (3)iostat
Iostat 提供三个报告: CPU 利用率, 设备利用率和网络文件系统利用率, 使用 - c,-d 和 - h 参数可以分别独立显示这三个报告.
(4)free
显示主内存和交换空间内存统计数据, 指定 - t 参数显示总内存, 指定 - b 参数按字节为单位, 使用 - m 则以兆为单位, 默认情况下千字节为单位.
Free 命令也可以使用 - s 参数加一个延迟时间 (单位: 秒) 连续运行, 如:
- $ free -s 5
- (5)sar
收集, 查看和记录性能数据, 这个命令比前面几个命令历史更悠久, 它可以收集和显示较长周期的数据.
其它
下面是一些归类为其它的性能技巧:
18, 将日志文件转移到内存中
当一台机器处于运行中时, 最好是将系统日志放在内存中, 当系统关闭时再将其复制到硬盘, 当你运行一台开启了 syslog 功能的笔记本电脑或移动设备时, ramlog 可以帮助你提高系统电池或移动设备闪存驱动器的寿命, 使用 ramlog 的一个好处是, 不用再担心某个守护进程每隔 30 秒向 syslog 发送一条消息, 放在以前, 硬盘必须随时保持运转, 这样对硬盘和电池都不好.
19, 先打包, 后写入
在内存中划分出固定大小的空间保存日志文件, 这意味着笔记本电脑硬盘不用一直保持运转, 只有当某个守护进程需要写入日志时才运转, 注意 ramlog 使用的内存空间大小是固定的, 否则系统内存会很快被用光, 如果笔记本使用固态硬盘, 可以分配 50-80MB 内存给 ramlog 使用, ramlog 可以减少许多写入周期, 极大地提高固态硬盘的使用寿命.
20, 一般调优技巧
尽可能使用静态内容替代动态内容, 如果你在生成天气预告, 或其它每隔 1 小时就必须更新的数据, 最好是写一个程序, 每隔 1 小时生成一个静态的文件, 而不是让用户运行一个 CGI 动态地生成报告.
为动态应用程序选择最快最合适的 API,CGI 可能最容易编程, 但它会为每个请求产生一个进程, 通常, 这是一个成本很高, 且不必要的过程, FastCGI 是更好的选择, 和 Apache 的 mod_perl 一样, 都可以极大地提高应用程序的性能.
种一棵树, 最好的时间是十年前, 其次是现在.
来源: https://juejin.im/entry/5b1cafe26fb9a01e30607fc8