正在加载...
分页: 69/186 第一页 上页 64 65 66 67 68 69 70 71 72 73 下页 最后页 [ 显示模式: 摘要 | 列表 ]

2009系统架构师大会演讲PPT

[ 2009/09/03 16:18 | by selboo ]

http://linux.chinaunix.net/SACC2009/SACC2009_AppServer.rar
http://linux.chinaunix.net/SACC2009/SACC2009_database.rar
http://linux.chinaunix.net/SACC2009/SACC2009_education.rar
http://linux.chinaunix.net/SACC2009/SACC2009_monitor.rar
http://linux.chinaunix.net/SACC2009/SACC2009_network.rar
http://linux.chinaunix.net/SACC2009/SACC2009_Storage.rar
http://linux.chinaunix.net/SACC2009/SACC2009_SystemArch.rar
Tags: ,

LAMP网站架构方案分析

[ 2009/08/31 15:26 | by selboo ]
    LAMP(Linux-Apache-MySQL-PHP)网站架构是目前国际流行的Web框架, 该框架包括:Linux操作系统,Apache网络服务器,MySQL数据库,Perl、PHP或者Python编程语言,所有组成产品均是开源软件,是 国际上成熟的架构框架,很多流行的商业应用都是采取这个架构,和Java/J2EE架构相比,LAMP具有Web资源丰富、轻量、快速开发等特点,微软 的.NET架构相比,LAMP具有通用、跨平台、高性能、低价格的优势,因此LAMP无论是性能、质量还是价格都是企业搭建网站的首选平台。

    对于大流量、大并发量的网站系统架构来说,除了硬件上使用高性能的服务器、负载均衡、CDN等之外,在软件架构上需要重点关注下面几个环节:使用高性能 的操作系统(OS)、高性能的网页服务器(Web Server)、高性能的数据库(Databse)、高效率的编程语言等。下面我将从这几点对其一一讨论。

操作系统

    Linux操作系统有很多个不同的发行版,如Red Hat Enterprise Linux、SUSE Linux Enterprice、Debian、Ubuntu、CentOS等,每一个发行版都有自己的特色,比如RHEL的稳定,Ubuntu的易用,基于稳定性 和性能的考虑,操作系统选择CentOS(Community ENTerprise Operating System)是一个理想的方案。

    CentOS(Community ENTerprise Operating System)是Linux发行版之一,是RHEL/Red Hat Enterprise Linux的精简免费版,和RHEL为同样的源代码,不过,RHEL和SUSE LE等企业版,提供的升级服务均是收费升级,无法免费在线升级,因此要求免费的高度稳定性的服务器可以用CentOS替代Red Hat Enterprise Linux使用。

Web服务器、缓存和PHP加速

Apache是LAMP架构最核心的Web Server,开源、稳定、模块丰富是Apache的优势。但Apache的缺点是有些臃肿,内存和CPU开销大,性能上有损耗,不如一些轻量级的Web 服务器(例如nginx)高效,轻量级的Web服务器对于静态文件的响应能力来说远高于Apache服务器。

Apache做为Web Server是负载PHP的最佳选择,如果流量很大的话,可以采用nginx来负载非PHP的Web请求。nginx是一个高性能的HTTP和反向代理服 务器,Nginx以它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。Nginx不支持Windows,只能在包括Linux等环境下安 装,也不支持PHP和CGI等,但支持负载均衡和容错,可和Apache配合使用,是轻量级的HTTP服务器的首选。

Web服务器的缓 存也有多种方案,Apache提供了自己的缓存模块,也可以使用外加的Squid模块进行缓存,这两种方式均可以有效的提高Apache的访问响应能力。 Squid Cache是一个Web缓存服务器,支持高效的缓存,可以作为网页服务器的前置cache服务器缓存相关请求来提高Web服务器的速度,把Squid放在 Apache的前端来缓存Web服务器生成的动态内容,而Web应用程序只需要适当地设置页面实效时间即可。如访问量巨大则可考虑使用memcache作 为分布式缓存。

PHP的加速使用eAccelerator加速器,eAccelerator是一个自由开放源码PHP加速器,优化和动 态内容缓存,提高了性能PHP脚本的缓存性能,使得PHP脚本在编译的状态下,对服务器的开销几乎完全消除。它还有对脚本起优化作用,以加快其执行效率。 使PHP程序代码执效率能提高1-10倍。

点击在新窗口中浏览此图片

具体的解决方案有以下几种:

1、squid + Apache + PHP + eAccelerator

使用Apache负载PHP,使用squid进行缓存,html或图片的请求可以直接由squid返回给用户。很多大型网站都采用这种架构。

2、nginx/Apache + PHP(fastcgi) + eAccelerator

使用nginx或Apache负载PHP,PHP使用fastcgi方式运行,效率较高。

3、nginx + Apache + PHP + eAccelerator

此方案综合了nginx和Apache的优点,使用Apache负载PHP,nginx负责解析其他Web请求,使用nginx的rewrite模块,Apache端口不对外开放。

数据库

开源的数据库中,MySQL在性能、稳定性和功能上是首选,可以达到百万级别的数据存储,网站初期可以将MySQL和Web服务器放在一起,但是当访问 量达到一定规模后,应该将MySQL数据库从Web Server上独立出来,在单独的服务器上运行,同时保持Web Server和MySQL服务器的稳定连接。

当数据库访问量达到更大的级别,可以考虑使用MySQL Cluster等数据库集群或者库表散列等解决方案。

总的来说,LAMP架构的网站性能会远远优于Windows IIS + ASP + Access(例如月光博客)这样的网站,可以负载的访问量也非常大,国内的大量个人网站如果想要支撑大访问量,采用LAMP架构是一个不错的方案。

综上所述,基于LAMP架构设计具有成本低廉、部署灵活、快速开发、安全稳定等特点,是Web网络应用和环境的优秀组合。

Tags: ,
The authenticity of host '64.71.167.20 (64.71.167.20)' can't be established.
RSA key fingerprint is bf:fd:e4:52:fe:25:9c:72:f5:1f:49:77:cf:3b:85:79.
Are you sure you want to continue connecting (yes/no)?

ssh 连接时经常能碰到如上信息,如果一两台还可以手动输入,如果多了就麻烦下

可以使用 -oStrictHostKeyChecking=no 参数进行过滤

ssh -oStrictHostKeyChecking=no 64.61.167.20

也可以使用 expect 命令模拟键盘输入"yes"
Tags:

TIME_WAIT解决办法

[ 2009/08/26 21:47 | by selboo ]
netstat -an
192.168.12.13:3306      192.168.12.12:30443      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30444      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30445      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30446      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30447      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30448      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30449      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30450      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30451      TIME_WAIT
192.168.12.13:3306      192.168.12.12:30452      TIME_WAIT
... ...
      根据TCP协议定义的3次握手断开连接规定,发起socket主动关闭的一方 socket将进入TIME_WAIT状态,TIME_WAIT状态将持续2个MSL(Max Segment Lifetime),在Windows下默认为4分钟,即240秒,TIME_WAIT状态下的socket不能被回收使用. 具体现象是对于一个处理大量短连接的服务器,如果是由服务器主动关闭客户端的连接,将导致服务器端存在大量的处于TIME_WAIT状态的socket, 甚至比处于Established状态下的socket多的多,严重影响服务器的处理能力,甚至耗尽可用的socket,停止服务. TIME_WAIT是TCP协议用以保证被重新分配的socket不会受到之前残留的延迟重发报文影响的机制,是必要的逻辑保证.
      在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters,添加名为TcpTimedWaitDelay的
DWORD键,设置为60,以缩短TIME_WAIT的等待时间

vi /etc/sysctl.conf

编辑文件,加入以下内容:
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_fin_timeout = 30

然后执行 /sbin/sysctl -p 让参数生效。

net.ipv4.tcp_syncookies = 1 表示开启SYN Cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;
net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;
net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。
net.ipv4.tcp_fin_timeout 修改系統默认的 TIMEOUT 时间

发现大量的TIME_WAIT 已不存在,mysql进程的占用率很快就降下来的,各网站访问正常!!
以上只是暂时的解决方法,最后仔细巡查发现是前天新上线的一个系统,程序代码中没有使用mysql.colse(),才导致大量的mysql  TIME_WAIT  

官方文章 http://technet.microsoft.com/en-us/library/cc938217.aspx
Windows 7 Ultimate (x86) - DVD (Chinese-Simplified)
文件名 cn_windows_7_ultimate_x86_dvd_x15-65907.iso 邮寄日期 (UTC): 8/23/2009 10:16:24 PM SHA1: B589336602E3B7E134E222ED47FC94938B04354F ISO/CRC: E6FDF910 Windows 7 Ultimate (x64) - DVD (Chinese-Simplified)
文件名 cn_windows_7_ultimate_x64_dvd_x15-66043.iso 邮寄日期 (UTC): 8/23/2009 10:16:25 PM SHA1: 4A98A2F1ED794425674D04A37B70B9763522B0D4 ISO/CRC: 05E9026C

Windows 7 Enterprise (x86) - DVD (Chinese-Simplified)
文件名 cn_windows_7_enterprise_x86_dvd_x15-70737.iso 邮寄日期 (UTC): 8/23/2009 10:15:32 PM SHA1: 50F2900D293C8DF63A9D23125AFEEA7662FF9E54 ISO/CRC: CEEE9884

Windows 7 Enterprise (x64) - DVD (Chinese-Simplified)
文件名 cn_windows_7_enterprise_x64_dvd_x15-70741.iso 邮寄日期 (UTC): 8/23/2009 10:15:32 PM SHA1: EE20DAF2CDEDD71C374E241340DEB651728A69C4 ISO/CRC: 18FF22E5

Windows 7 Professional (x86) - DVD (Chinese-Simplified)
文件名 cn_windows_7_professional_x86_dvd_x15-65790.iso 邮寄日期 (UTC): 8/23/2009 10:16:03 PM SHA1: EBD595C3099CCF57C6FF53810F73339835CFBB9D ISO/CRC: 55F360AB

Windows 7 Professional (x64) - DVD (Chinese-Simplified)

文件名 cn_windows_7_professional_x64_dvd_x15-65791.iso 邮寄日期 (UTC): 8/23/2009 10:16:03 PM SHA1: 5669A51195CD79D73CD18161D51E7E8D43DF53D1 ISO/CRC: 998E430C

Windows 7 Home Premium (x86) - DVD (Chinese-Simplified)

文件名 cn_windows_7_home_premium_x86_dvd_x15-65717.iso 邮寄日期 (UTC): 8/23/2009 10:15:52 PM SHA1: CBA410DB30FA1561F874E1CC155E575F4A836B37 ISO/CRC: E4819CB1

Windows 7 Home Premium (x64) - DVD (Chinese-Simplified)

文件名 cn_windows_7_enterprise_x86_dvd_x15-70737.iso 邮寄日期 (UTC): 8/23/2009 10:15:32 PM SHA1: 50F2900D293C8DF63A9D23125AFEEA7662FF9E54 ISO/CRC: CEEE9884

============ 下载分割线============

Windows 7 Ultimte (x86) - DVD (Chinese-Simplified)

下载地址:

Windows 7 Professional (x86) - DVD (Chinese-Simplified)

下载地址:

Windows 7 Enterprise (x86) - DVD (Chinese-Simplified)

下载地址:

分页: 69/186 第一页 上页 64 65 66 67 68 69 70 71 72 73 下页 最后页 [ 显示模式: 摘要 | 列表 ]