全面优化—配置高性能lnmp架构

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

本文不涉及大型web架构,旨在单台服务器上通过各种手段最大化的优化和加速lnmp,适合单台服务器或者vps站长们使用。笔者水平有限,要是有更好的优化手段请留言,我会不断完善此架构

 

笔者罗列以下主要的方式进行优化,一些小细节的优化在下面的配置中再具体说明:(有更好的招数欢迎大家留言)

1.利用fastcgi_cache缓存,减少nginx与PHP交互,减轻php和数据库(mysql)的压力


2.为zend引擎缓存opcode,使用X-cache缓存opcode,减少php脚本语句转换中间代码的次数


3.利用TCMalloc优化Nginx和mysql的内存分配效率访问性能,提高高并发的性能(nginx本身对内存优化就很好,这里主要是针对mysql优化)


4.安装最新的libevent提高nginx和php的事件触发性能


5.开启gzip压缩网页文件


6.优化nginx中fastcgi参数


7.优化php-fpm参数


8.一些细节下面具体配置再说

 

 

 

 

先罗列下需要用到包 
1.开发环境:自行yum安装 
2.nginx-1.0.14.tar 
3.php-5.3.6.tar.bz2 
4.xcache-1.3.2.tar.gz 
5. mysql-5.5.22-linux2.6-i686.tar.gz 
6.gperftools-2.0.tar.gz

7.最新的libevent库 
8.php额外的一些插件

一、Nginx:

1、解决依赖关系和优化所需的组件 
编译安装nginx需要事先需要安装开发包组"Development Tools" 。同时,安装pcre-devel包,用yum安装即可

安装TCMalloc和google-perftools(TCMalloc只是google-perftools的一个组件,主要是优化内存分配效率和速度的),如果是64位系统请先安装libunwind库,我是32位系统,就不安装了 
下载google-perftools 
http://gperftools.googlecode.com/files/gperftools-2.0.tar.gz

tar xf gperftools-2.0.tar.gz 
./configure 
make && make install


安装最新的libevent 提高事件性能 
tar xf tar libevent-2.0.19-stable.tar.gz 
./configure 
make && make install 
echo “usr/local/lib” >/etc/ld.so.conf.d/local.conf 
ldconfig

2、安装

首先添加用户nginx,实现以之运行nginx服务进程: 
# groupadd -r nginx 
# useradd -r -g nginx -s /bin/false -M nginx

tar xf nginx-1.0.14.tar.gz 
接着开始编译和安装: 
# ./configure \ 
  --prefix=/usr \ 
  --sbin-path=/usr/sbin/nginx \ 
  --conf-path=/etc/nginx/nginx.conf \ 
  --error-log-path=/var/log/nginx/error.log \ 
  --http-log-path=/var/log/nginx/access.log \ 
  --pid-path=/var/run/nginx/nginx.pid  \ 
  --lock-path=/var/lock/nginx.lock \ 
  --user=nginx \ 
  --group=nginx \ 
  --with-http_ssl_module \ 
  --with-http_flv_module \ 
  --with-http_stub_status_module \ 
  --with-http_gzip_static_module \ #加载gzip压缩模块 
  --http-client-body-temp-path=/var/tmp/nginx/client/ \ 
  --http-proxy-temp-path=/var/tmp/nginx/proxy/ \ 
  --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \ 
  --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \ 
  --http-scgi-temp-path=/var/tmp/nginx/scgi \ 
  --with-pcre \ 
--with-google_perftools_module \ #加载 google_perftools模块 
--with-cc-opt='-O3' \ #优化GCC编译 
--with-cup-opt=pentium4 \ # 指定处理器类型,具体类型执行./configure --help帮助


# make && make install


3、为nginx提供SysV init脚本:

新建文件/etc/rc.d/init.d/nginx,内容如下: 
#!/bin/sh 

# nginx - this script starts and stops the nginx daemon 

# chkconfig:   - 85 15 
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \ 
#               proxy and IMAP/POP3 proxy server 
# processname: nginx 
# config:      /etc/nginx/nginx.conf 
# config:      /etc/sysconfig/nginx 
# pidfile:     /var/run/nginx.pid 
  
# Source function library. 
. /etc/rc.d/init.d/functions 
  
# Source networking configuration. 
. /etc/sysconfig/network 
  
# Check that networking is up. 
[ "$NETWORKING" = "no" ] && exit 0 
  
nginx="/usr/sbin/nginx" 
prog=$(basename $nginx) 
  
NGINX_CONF_FILE="/etc/nginx/nginx.conf" 
  
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx 
  
lockfile=/var/lock/subsys/nginx 
  
make_dirs() { 
   # make required directories 
   user=`nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -` 
   options=`$nginx -V 2>&1 | grep 'configure arguments:'` 
   for opt in $options; do 
       if [ `echo $opt | grep '.*-temp-path'` ]; then 
           value=`echo $opt | cut -d "=" -f 2` 
           if [ ! -d "$value" ]; then 
               # echo "creating" $value 
               mkdir -p $value && chown -R $user $value 
           fi 
       fi 
   done 

  
start() { 
    [ -x $nginx ] || exit 5 
    [ -f $NGINX_CONF_FILE ] || exit 6 
    make_dirs 
    echo -n $"Starting $prog: " 
    daemon $nginx -c $NGINX_CONF_FILE 
    retval=$? 
    echo 
    [ $retval -eq 0 ] && touch $lockfile 
    return $retval 

  
stop() { 
    echo -n $"Stopping $prog: " 
    killproc $prog -TERM 
    retval=$? 
    echo 
    [ $retval -eq 0 ] && rm -f $lockfile 
    return $retval 

  
restart() { 
    configtest || return $? 
    stop 
    sleep 1 
    start 

  
reload() { 
    configtest || return $? 
    echo -n $"Reloading $prog: " 
    killproc $nginx -HUP 
    RETVAL=$? 
    echo 

  
force_reload() { 
    restart 

  
configtest() { 
  $nginx -t -c $NGINX_CONF_FILE 

  
rh_status() { 
    status $prog 

  
rh_status_q() { 
    rh_status >/dev/null 2>&1 

  
case "$1" in 
    start) 
        rh_status_q && exit 0 
        $1 
        ;; 
    stop) 
        rh_status_q || exit 0 
        $1 
        ;; 
    restart|configtest) 
        $1 
        ;; 
    reload) 
        rh_status_q || exit 7 
        $1 
        ;; 
    force-reload) 
        force_reload 
        ;; 
    status) 
        rh_status 
        ;; 
    condrestart|try-restart) 
        rh_status_q || exit 0 
            ;; 
    *) 
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}" 
        exit 2 
esac

而后为此脚本赋予执行权限: 
# chmod +x /etc/rc.d/init.d/nginx

添加至服务管理列表,并让其开机自动启动: 
# chkconfig --add nginx 
# chkconfig nginx on

而后就可以启动服务并测试了: 
# service nginx start


二、安装mysql-5.5.20


1、新建用户以安全方式运行进程:

# groupadd -r mysql 
# useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql 
# chown -R mysql:mysql /mydata/data

2、安装并初始化mysql-5.5.20

# tar xf mysql-5.5.20-linux2.6-i686.tar.gz -C /usr/local 
# cd /usr/local/ 
# ln -sv mysql-5.5.20-linux2.6-i686  mysql 
# cd mysql

# chown -R mysql:mysql  . 
# scripts/mysql_install_db --user=mysql --datadir=/mydata/data 
# chown -R root  .

3、为mysql提供主配置文件:

# cd /usr/local/mysql 
# cp support-files/my-large.cnf  /etc/my.cnf

并修改此文件中thread_concurrency的值为你的CPU个数乘以2,我这里是单核的: 
thread_concurrency = 2

另外还需要添加如下行指定mysql数据文件的存放位置: 
datadir = /mydata/data


4、为mysql提供sysv服务脚本:

# cd /usr/local/mysql 
# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld 
#修改启动脚本 添加

添加至服务列表: 
# chkconfig --add mysqld 
# chkconfig mysqld on

5、输出mysql的头文件至系统头文件路径/usr/include:

这可以通过简单的创建链接实现: 
# ln -sv /usr/local/mysql/include  /usr/include/mysql

6、输出mysql的库文件给系统库查找路径:

# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

而后让系统重新载入系统库: 
# ldconfig

7、修改PATH环境变量,让系统可以直接使用mysql的相关命令。

10.设置Mysql运行时加载tcmalloc,提高内存效率 
vi /usr/local/mysql/bin/mysqld_safe 
在# executing mysqld_safe的下一行,加入以下内容 
export LD_PRELOAD="/usr/local/lib/libtcmalloc.so"

 

而后就可以启动服务测试使用了。

三、编译安装php-5.3.6

1、解决依赖关系:

如果想让编译的php支持mcrypt、mcrypt、mhash扩展和libevent,下载如下几个rpm包并安装之(libevent之前装nginx时已经装过): 
libmcrypt-2.5.8-4.el5.centos.i386.rpm 
libmcrypt-devel-2.5.8-4.el5.centos.i386.rpm 
mhash-0.9.9-1.el5.centos.i386.rpm 
mhash-devel-0.9.9-1.el5.centos.i386.rpm 
mcrypt-2.6.8-1.el5.i386.rpm

最好使用升级的方式安装上面的rpm包,命令格式如下: 
# rpm -Uvh *.rpm

2、编译安装php-5.3.10


# tar xf php-5.3.6.tar.bz2 
# cd php-5.3.6 
#  ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --enable-fpm --enable-sockets --enable-sysvshm  --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib-dir --with-libxml-dir=/usr --enable-xml  --with-mhash --with-mcrypt  --with-config-file-path=/etc/php --with-config-file-scan-dir=/etc/php --with-bz2 --with-curl

#注意要结合nginx的fastcgi整合php,必须要打开php-fpm管理程序,使nginx通过交互php-fpm整合PHP

# make && make intall

为php提供配置文件: 
# cp php.ini-production /etc/php/php.ini

为php-fpm提供Sysv init脚本,并将其添加至服务列表: 
# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm 
# chmod +x /etc/rc.d/init.d/php-fpm 
# chkconfig --add php-fpm 
# chkconfig php-fpm on

为php-fpm提供配置文件: 
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

优化php-fpm的配置文件(具体数值按照服务器配置而定): 
# vim /usr/local/php/etc/php-fpm.conf 
优化pm.的配置: 
pm.max_children = 50 #最大进程数 
pm.start_servers = 5 #初始进程数 
pm.min_spare_servers = 2 #最小空闲进程 
pm.max_spare_servers = 8 #最大空闲进程 
pid = /usr/local/php/var/run/php-fpm.pid

接下来就可以启动php-fpm了: 
# service php-fpm start

使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了): 
# ps aux | grep php-fpm


四、整合nginx和php5,利用fastcgi_cache缓存加速nginx和php交互

1、编辑/etc/nginx/nginx.conf,启用如下选项: 
在httpd段加入下面参数 
fastcgi_connect_timeout 300; 
指定连接到后端FastCGI的超时时间。 
fastcgi_send_timeout 300; 
向FastCGI传送请求的超时时间,这个值是指已经完成两次握手后向FastCGI传送请求的超时时间。 
fastcgi_read_timeout 300; 
接收FastCGI应答的超时时间,这个值是指已经完成两次握手后接收FastCGI应答的超时时间。 
fastcgi_buffer_size 32k; 
指定读取FastCGI应答第一部分需要用多大的缓冲区,一般第一部分应答不会超过1k,由于页面大小为4k,所以这里设置为4k。 
fastcgi_buffers 4 32k; 
定本地需要用多少和多大的缓冲区来缓冲FastCGI的应答请求。如果一个PHP脚本所产生的页面大小为256KB,那么会为其分配4个64KB的缓冲区来缓存;如果页面大小大于256KB,那么大于256KB的部分会缓存到fastcgi_temp指定的路径中,但是这并不是好方法,因为内存中的数据处理速度要快于硬盘。一般这个值应该为站点中PHP脚本所产生的页面大小的中间值,如果站点大部分脚本所产生的页面大小为256KB,那么可以把这个值设置为“16 16k”、“4 64k”等。 
fastcgi_busy_buffers_size 64k; 
默认值是fastcgi_buffers的两倍。 
fastcgi_temp_file_write_size 64k; 
在写入fastcgi_temp_path时将用多大的数据块,默认值是fastcgi_buffers的两倍。 
fastcgi_cache_path /var/logs/nginx/fastcgi_cache_dir levels=1:2 keys_zone=cache_fastcgi:64m inactive=1d max_size=10g; 
这个指令为FastCGI缓存指定一个路径(手动创建此目录),目录结构等级,关键字区域存储时间和非活动删除时间。以及最大占用空间。

在调用php的location中调用以上缓存配置 
location ~ \.php$ { 
root /var/www/html/; 
fastcgi_pass 127.0.0.1:9000; 
fastcgi_index index.php; 
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 
include fastcgi_params; 
fastcgi_cache cache_fastcgi; 
表示开启FastCGI缓存并为其指定一个名称。 
fastcgi_cache_valid 200 302 301 1h; 
fastcgi_cache_valid any 1m; 
为指定的应答代码指定缓存时间,如上例中将200,302 301应答缓存一小时,其他为1分钟。 
fastcgi_cache_min_uses 1; 
设置链接请求几次就被缓存。 
fastcgi_cache_use_stale error timeout invalid_header http_500; 
定义哪些情况下用过期缓存 
fastcgi_cache_key $request_method://$host$request_uri; 
注意一定要加上$request_method作为cache key,否则如果HEAD类型的先请求会导致后面的GET请求返回为空 
}

 

2、编辑/etc/nginx/fastcgi_params,将其内容更改为如下内容: 
fastcgi_param  GATEWAY_INTERFACE  CGI/1.1; 
fastcgi_param  SERVER_SOFTWARE    nginx; 
fastcgi_param  QUERY_STRING       $query_string; 
fastcgi_param  REQUEST_METHOD     $request_method; 
fastcgi_param  CONTENT_TYPE       $content_type; 
fastcgi_param  CONTENT_LENGTH     $content_length; 
fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name; 
fastcgi_param  SCRIPT_NAME        $fastcgi_script_name; 
fastcgi_param  REQUEST_URI        $request_uri; 
fastcgi_param  DOCUMENT_URI       $document_uri; 
fastcgi_param  DOCUMENT_ROOT      $document_root; 
fastcgi_param  SERVER_PROTOCOL    $server_protocol; 
fastcgi_param  REMOTE_ADDR        $remote_addr; 
fastcgi_param  REMOTE_PORT        $remote_port; 
fastcgi_param  SERVER_ADDR        $server_addr; 
fastcgi_param  SERVER_PORT        $server_port; 
fastcgi_param  SERVER_NAME        $server_name;

并在所支持的主页面格式中添加php格式的主页,类似如下: 
location / { 
            root   /var/www/html; 
            index  index.php index.html index.htm; 
        } 
        
而后重新载入nginx的配置文件: 
# service nginx reload

3、在/usr/html新建index.php的测试页面,测试php是否能正常工作: 
# cat &gt; /var/www/html/index.php <&lt; EOF 
&lt;?php 
phpinfo(); 
?>

接着就可以通过浏览器访问此测试页面了。


五、安装xcache,为php加速:

1、安装 
# tar xf xcache-1.3.2.tar.gz 
# cd xcache-1.3.2 
# /usr/local/php/bin/phpize 
# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config 
# make && make install

安装结束时,会出现类似如下行: 
Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/

2、编辑php.ini,整合php和xcache:

首先将xcache提供的样例配置导入php.ini 
#  cat xcache.ini &gt;&gt; /etc/php/php.ini

说明:xcache.ini文件在xcache的源码目录中。

接下来编辑/usr/local/php/lib/php.ini,找到zend_extension开头的行,修改为如下行: 
zend_extension = /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/xcache.so

3、重新启动php-fpm 
# service php-fpm restart

全部工作OK。。。



本文转自lustlost 51CTO博客,原文链接:http://blog.51cto.com/lustlost/964845,如需转载请自行联系原作者

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
弹性计算 运维 监控
阿里云云服务诊断工具:合作伙伴架构师的深度洞察与优化建议
作为阿里云的合作伙伴架构师,我深入体验了其云服务诊断工具,该工具通过实时监控与历史趋势分析,自动化检查并提供详细的诊断报告,极大提升了运维效率和系统稳定性,特别在处理ECS实例资源不可用等问题时表现突出。此外,它支持预防性维护,帮助识别潜在问题,减少业务中断。尽管如此,仍建议增强诊断效能、扩大云产品覆盖范围、提供自定义诊断选项、加强教育与培训资源、集成第三方工具,以进一步提升用户体验。
740 243
|
5天前
|
存储 人工智能 并行计算
2025年阿里云弹性裸金属服务器架构解析与资源配置方案
🚀 核心特性与技术创新:提供100%物理机性能输出,支持NVIDIA A100/V100 GPU直通,无虚拟化层损耗。网络与存储优化,400万PPS吞吐量,ESSD云盘IOPS达100万,RDMA延迟<5μs。全球部署覆盖华北、华东、华南及海外节点,支持跨地域负载均衡。典型应用场景包括AI训练、科学计算等,支持分布式训练和并行计算框架。弹性裸金属服务器+OSS存储+高速网络综合部署,满足高性能计算需求。
|
2月前
|
机器学习/深度学习 算法 数据可视化
基于深度混合架构的智能量化交易系统研究: 融合SSDA与LSTM自编码器的特征提取与决策优化方法
本文探讨了在量化交易中结合时序特征和静态特征的混合建模方法。通过整合堆叠稀疏降噪自编码器(SSDA)和基于LSTM的自编码器(LSTM-AE),构建了一个能够全面捕捉市场动态特性的交易系统。SSDA通过降噪技术提取股票数据的鲁棒表示,LSTM-AE则专注于捕捉市场的时序依赖关系。系统采用A2C算法进行强化学习,通过多维度的奖励计算机制,实现了在可接受的风险水平下最大化收益的目标。实验结果显示,该系统在不同波动特征的股票上表现出差异化的适应能力,特别是在存在明确市场趋势的情况下,决策准确性较高。
85 5
基于深度混合架构的智能量化交易系统研究: 融合SSDA与LSTM自编码器的特征提取与决策优化方法
|
1月前
|
消息中间件 监控 小程序
电竞陪玩系统架构优化设计,陪玩app如何提升系统稳定性,陪玩小程序平台的测试与监控
电竞陪玩系统架构涵盖前端(React/Vue)、后端(Spring Boot/php)、数据库(MySQL/MongoDB)、实时通信(WebSocket)及其他组件(Redis、RabbitMQ、Nginx)。通过模块化设计、微服务架构和云计算技术优化,提升系统性能与可靠性。同时,加强全面测试、实时监控及故障管理,确保系统稳定运行。
|
1月前
|
存储 弹性计算 架构师
老板点赞!技术人如何用架构优化打赢降本增效战?
大家好,我是小米,一个喜欢分享技术的小架构师。通过亲身经历,我将介绍如何通过架构优化帮助公司降本增效。两年前,我加入一家初创公司,面对成本高企的问题,通过弹性伸缩、微服务化和数据治理等手段,成功降低了40%的技术成本,提升了60%的系统响应速度。希望我的经验能给你启发!关注我的微信公众号“软件求生”,获取更多技术干货。
48 5
|
2月前
|
存储 机器学习/深度学习 人工智能
【AI系统】计算图优化架构
本文介绍了推理引擎转换中的图优化模块,涵盖算子融合、布局转换、算子替换及内存优化等技术,旨在提升模型推理效率。计算图优化技术通过减少计算冗余、提高计算效率和减少内存占用,显著改善模型在资源受限设备上的运行表现。文中详细探讨了离线优化模块面临的挑战及解决方案,包括结构冗余、精度冗余、算法冗余和读写冗余的处理方法。此外,文章还介绍了ONNX Runtime的图优化机制及其在实际应用中的实现,展示了如何通过图优化提高模型推理性能的具体示例。
76 4
【AI系统】计算图优化架构
|
2月前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
170 3
|
3月前
|
监控 Serverless 云计算
探索Serverless架构:开发实践与优化策略
本文深入探讨了Serverless架构的核心概念、开发实践及优化策略。Serverless让开发者无需管理服务器即可运行代码,具有成本效益、高可扩展性和提升开发效率等优势。文章还详细介绍了函数设计、安全性、监控及性能和成本优化的最佳实践。
|
3月前
|
弹性计算 运维 开发者
后端架构优化:微服务与容器化的协同进化
在现代软件开发中,后端架构的优化是提高系统性能和可维护性的关键。本文探讨了微服务架构与容器化技术如何相辅相成,共同推动后端系统的高效运行。通过分析两者的优势和挑战,我们提出了一系列最佳实践策略,旨在帮助开发者构建更加灵活、可扩展的后端服务。
|
3月前
|
消息中间件 运维 Cloud Native
云原生架构下的微服务优化策略####
本文深入探讨了云原生环境下微服务架构的优化路径,针对服务拆分、通信效率、资源管理及自动化运维等核心环节提出了具体的优化策略。通过案例分析与最佳实践分享,旨在为开发者提供一套系统性的解决方案,以应对日益复杂的业务需求和快速变化的技术挑战,助力企业在云端实现更高效、更稳定的服务部署与运营。 ####