-- 编译软件的过程与经验: 1,./configure 通过指定参数,来确认你想要安装的软件安装在哪里,加上哪些功能和去掉哪些功能(如果这一步报错,基本都是缺少依赖包; 解决方法:使用yum去安装,一般来说,rhel做为一个成熟的linux操作系统,常见的底层依赖包都自带了,所以去安装下面这两个组,一般都会有你所需要的依赖包。 # yum groupinstall "Development tools" -y # yum groupinstall "Desktop Platform Development" -y 如果缺少依赖包在rhel的yum源里找不到,则上网下载第三方的软件,先编译第三方软件,再编译本软件 2,make 相当于是把你上一步定义好的,把这个软件给做出来(这一步一般很少出错,如果出错,问题都比较麻烦。可能是一些兼容性的问题等等,你可以尝试上网查询解决方法,如果查不到,只能换个环境或者换个软件版本或者换些编译参数重新编译) 3, make install 把做好的软件,安装到你第一步所指定的安装目录里(这一步几 乎不会出错的) -------------------------------- 讨论1: 关于./configure参数选择的基本方法: ./configure --help 查看所有的编译参数 第一个重要参数 --prefix= 此参数指定安装目录(一般安装到/usr/local/或者/usr/local/软件名下) 第二类重要参数: --enable-xxx 打开一个功能(默认是关闭的) --disable-xxx 关闭一个功能(默认是打开的) 如果你是新手,你就不加任何功能参数,全部使用默认值。但又如果你怕少了功能造成以后需要重编,你可以加上所有的enable参数(但加得越多,错误概率也越大,因为调用的依赖会多,有可能会因为少包而报错) 第三类参数: --with-xxx=DIR 指定一个目录,调用此目录的功能 讨论2: 假设一个软件abc,安装到/usr/local和安装到/usr/local/abc之间的区别? 安装到/usr/local下: 优点:此软件的命令一般会安装到/usr/local/bin或/usr/local/sbin等;这些路径都默认在$PATH里,所以安装的命令可以直接用,而不用使用绝对路径。 库文件一般都会安装到/usr/local/lib下,所以把它加入ldconfig,以后所有安装在此目录的库文件都可以被找到。 缺点:不方便删除,因为很多软件都安装到/usr/local下 安装到/usr/local/abc下: 优缺点与上面正好相反 最终建议:小软件一般默认安装/usr/local/;大软件安装/usr/local/软件名/下 讨论3: 关于ldconfig,一个软件的库文件是有可能被其它软件所调用,那么其它软件能否找到你的库文件呢? 一般来说,库文件安装到/lib,/lib64,/usr/lib/,/usr/lib64等,都可以被找得到.那么如果一个软件abc把库文件安装到/usr/local/abc/lib,别人想要找到,你就要把这个路径加入到ldconfig可以找到的路径列表里面去。 做法为: # vim /etc/ld.so.conf --在这个主配置文件里加上一行,写上让别人要查找库文件的路径 include ld.so.conf.d/*.conf --或者在这里的任意.conf结尾的子配置文件里加上一行也可以 /usr/local/abc/lib # ldconfig --上面加入路径后,就使用此命令让其生效 ================================================================= nginx survey.netcraft.net 查看各大网站使用的web服务器,使用下面的命令 curl -I www.sina.com 结论:现在大型网站几乎统一都使用nginx或nginx做二次开发的版本(如tengine,OpenResty等) nginx相对于apache的优势? 资源占用少 支持大并发 linux+nginx+mysql+php(fastcgi) lnmp搭建过程 (nginx,mysql,php这三个软件用新的编译方法编译顺序无所谓) 编译lnmp所有的软件包在 笔记目录/lnmp_soft/ Discuz_X3.2_SC_UTF8.zip mcrypt-2.6.6.tar.gz ngx_cache_purge-2.3.tar.gz ImageMagick-6.7.8-9.tar.gz memcache-2.2.7.tgz pcre-7.9.tar.gz imagick-3.1.2.tgz memcached-1.4.22.tar.gz php-5.6.12.tar.bz2 libevent-1.4.11-stable.tar.gz mhash-0.9.9.9.tar.bz2 webbench-1.5.tar.gz libiconv-1.13.tar.gz mysql-5.6.26.tar.gz libmcrypt-2.5.8.tar.bz2 nginx-1.8.0.tar.gz 只下载共享的软件包的方法 # wget -m -np -k http://10.1.1.35/program/lnmp_soft/ --m是镜像下载,k是转成本地链接,np表示noparent(也就是只下载当前目录,不会下载上级目录) 编译安装前准备,先确认编译所需要的依赖软件包已经安装 # yum groupinstall "Desktop Platform Development" -y # yum groupinstall "Development tools" -y # yum install curl-devel ncurses-devel net-snmp-* *icu* libxml2-devel -y 第一大步: 编译mysql mysql-5.6.26.tar.gz # rm /mysqldata56 -rf # rm /usr/local/mysql -rf # rm /usr/src/mysql-*/ -rf --删除以前编译过的,重新编译 # yum install cmake # tar xvf mysql-5.6.26.tar.gz -C /usr/src/ # cd /usr/src/mysql-5.6.26/ # cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=gbk,gb2312 -DENABLED_LOCAL_INFILE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 # make ;make install 安装后 1,手动编写my.cnf配置文件 # mkdir /usr/local/mysql/etc # vim /usr/local/mysql/etc/my.cnf [mysqld] port=3307 datadir=/mysqldata56 pid-file=/mysqldata56/mysql56.pid socket=/mysqldata56/mysql56.socket log-error=/mysqldata56/mysql56-err.log user=mysql [client] socket=/mysqldata56/mysql56.socket 2:创建相关目录,并修改权限 # mkdir /mysqldata56 # chown mysql.mysql /mysqldata56 /usr/local/mysql/ -R 3:初始化数据库 # /usr/local/mysql/scripts/mysql_install_db --defaults-file=/usr/local/mysql/etc/my.cnf --user=mysql --basedir=/usr/local/mysql/ 4:启动服务 # /usr/local/mysql/bin/mysqld_safe --defaults-file=/usr/local/mysql/etc/my.cnf & 5:登录 # /usr/local/mysql/bin/mysql 第二大步:编译安装php 编译之前,确认把以前编译过的给删除 # rm -rf /usr/src/lnmp # rm -rf /usr/local/php 1,在安装php之前,先安装php扩展包,这些包是rpm里没有自带,所以这里还是编译一下 libiconv-1.13.tar.gz --语言编码转换 # mkdir /usr/src/lnmp/ --我这里自己专门建立一个目录存放lnmp项目的所有源码 # tar xvf libiconv-1.13.tar.gz -C /usr/src/lnmp/ # cd /usr/src/lnmp/libiconv-1.13/ # ./configure ;make ;make install # echo /usr/local/lib > /etc/ld.so.conf.d/lnmp.conf # /sbin/ldconfig pcre-7.9.tar.gz --perl兼容正则表达式,或者使用rpm自带的也可以(yum install pcre pcre-devel -y) # tar xvf pcre-7.9.tar.gz -C /usr/src/lnmp/ # cd /usr/src/lnmp/pcre-7.9/ # ./configure ;make ;make install # /sbin/ldconfig # tar xf php-5.6.12.tar.bz2 -C /usr/src/lnmp/ # cd /usr/src/lnmp/php-5.6.12/ # ./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-iconv-dir=/usr/local --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --enable-mbregex --enable-fpm --enable-mbstring --enable-ftp --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-gettext --enable-mysqlnd --with-pcre-dir=/usr/local/ --enable-opcache # make # make install --上面的编译参数要注意的几点; 一,php安装路径这一次不是默认的/usr/local,我换成了/usr/local/php,你不换也是可以的,我这里只是不想去覆盖以前的lamp编译到/usr/local下的php 二,with-pcre-dir是指定pcre库的路径,因为我前面使用的是编译版本的pcre,路径装到/usr/local/下 三,with-pdo-mysql是指定php与mysql的连接,以前pdo-mysql是得去php官网单独下载安装的,较新的php版本都自带了,用这个参数指定mysql的路径就可以了 四,with-config-file-path这是指定php.ini配置文件的路径,没有使用默认的路径,这一步也是可选的,无论你指定到哪,后面的过程要使用php.ini,路径与你现在编译的对应好就行 五:--enable-fpm参数是支持php的fastcgi模式 六:关于--with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 三个参数的说明 传统的安装php的方式中,我们在编译PHP时,一般需要指定以下几项: --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-pdo-mysql=/usr/local/mysql 这实际上就是使用了mysql官方自带的libmysql驱动, 这是比较老的驱动, PHP 5.3开始已经不建议使用它了, 而建议使用mysqlnd 因为mysqlnd内置于PHP源代码,故你在编译安装php时就不需要预先安装mysql server也可以提供mysql client API (mysql_connect, pdo , mysqli),这样就可以实现不用安装mysql,也可以编译php(上次讲lamp时讲的先装mysql,再编php,最后不用mysql,而用远程的另一个mysql的做法为老的做法) 把上面的三个参数换为--with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 就可以了 ----------------------------------------------- 编译php时可能会出现的几种错误总结: 错误一: # ./configure时报下面的错误 configure: error: Don't know how to define struct flock on this system, set --enable-opcache=no 解决方法: # ln -s /usr/local/mysql/lib/libmysqlclient.so /usr/lib/ # ln -s /usr/local/mysql/lib/libmysqlclient.so.18 /usr/lib/libmysqlclient.so.18 # ldconfig --或者echo /usr/local/mysql/lib >> /etc/ld.so.conf.d/lnmp.conf && ldconfig 错误二: # ./configure之后如果直接make会报下面的错误 collect2: ld returned 1 exit status make: *** [sapi/cli/php] Error 1 --就最好删掉php的源码目录,再重新解压,重新编译,使用下面的参数来编译 # make ZEND_EXTRA_LIBS='-liconv' # make install 错误三: chmod: cannot access `ext/phar/phar.phar': No such file or directory" # cp ext/phar/phar.php ext/phar/phar.phar ------------------------------------------------ 2,php成功安装后,继续安装php第三方模块 安装缓存模块memcache # tar xvf memcache-2.2.7.tgz -C /usr/src/lnmp/ # cd /usr/src/lnmp/memcache-2.2.7/ # /usr/local/php/bin/phpize --用phpize生成编译的configure文件。注意使用的路径要为编译的/usr/local/php的路径; phpize prepare a PHP extension for compiling 如果你不用phpize,你的这个目录里根本就没有configure这个文件 # ./configure --with-php-config=/usr/local/php/bin/php-config # make ;make install 注意安装信息 Libraries have been installed in: /usr/src/lnmp/memcache-2.2.7/modules Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/ # echo /usr/src/lnmp/memcache-2.2.7/modules/ >> /etc/ld.so.conf.d/lnmp.conf # /sbin/ldconfig 安装绘图引擎模块imagemagick,与GD类似 # tar xf ImageMagick-6.7.8-9.tar.gz -C /usr/src/lnmp/ # cd /usr/src/lnmp/ImageMagick-6.7.8-9/ # ./configure # make;make install # /sbin/ldconfig 安装imagick(连接php与imagemagick的通道) # tar xf imagick-3.1.2.tgz -C /usr/src/lnmp/ # cd /usr/src/lnmp/imagick-3.1.2/ # /usr/local/php/bin/phpize # ./configure --with-php-config=/usr/local/php/bin/php-config # make;make install 注意安装的库路径的模块路径信息 Libraries have been installed in: /usr/src/lnmp/imagick-3.1.2/modules Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/ # echo /usr/src/lnmp/imagick-3.1.2/modules >> /etc/ld.so.conf.d/lnmp.conf # /sbin/ldconfig 到此,与nginx之前要编译的所有软件及扩展模块完成 验证此目录里有三个安装模块,表示安装OK # ls /usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/ imagick.so memcache.so opcache.so opcache.a -------------------------------------------- 3,拷贝并配置php配置文件,加上前面所编译的模块支持 # cp /usr/src/lnmp/php-5.6.12/php.ini-production /usr/local/php/etc/php.ini --拷配置文件,拷的路径是根据编译时的--sysconfigdir参数决定的(因为,我指定安装路径为/usr/local/php,所以就要拷到/usr/local/php/etc/) 配置php.ini文件加上前面安装的扩展的模块支持 # vim /usr/local/php/etc/php.ini --直接在最后加上下面一段 extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/" extension = "memcache.so" extension = "imagick.so" [opcache] zend_extension = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/opcache.so" opcache.enable=1 opcache.enable_cli=1 opcache.memory_consumption=128 opcache.optimization_level=1 opcache.interned_strings_buffer=8 opcache.max_accelerated_files=4000 opcache.revalidate_freq=60 opcache.fast_shutdown=1 opcache.save_comments=0 关于下面几个参数的说明 opcache.memory_consumption=128 --共享内存大小, 这个根据你们的需求可调 opcache.interned_strings_buffer=8 --interned string的内存大小, 也可调 opcache.max_accelerated_files=4000 --最大缓存的文件数目 opcache.revalidate_freq=60 --60s检查一次文件更新 opcache.fast_shutdown=1 --打开快速关闭, 打开这个在PHP Request Shutdown的时候回收内存的速度会提高 opcache.save_comments=0 --不保存文件或函数的注释 ------------------------------------------------------ 第三大步:编译安装nginx --今天使用的是稳定版1.8.0版本的nginx来做 # useradd -r -d /dev/null -s /sbin/nologin nginx --我这里建立一个用户来跑nginx,不做也可以,它默认是用daemon用户来跑 # id nginx --nginx的uid,gid无所谓是多少 uid=493(nginx) gid=487(nginx) groups=487(nginx) # tar xf nginx-1.8.0.tar.gz -C /usr/src/lnmp/ # cd /usr/src/lnmp/nginx-1.8.0/ # ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_gzip_static_module --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/ --with-http_stub_status_module模块记得要加,后面做查看nginx状态需要这个模块 # make ;make install # ls /usr/local/nginx --看到这些文件,则表示nginx安装成功 conf html logs sbin ========================================================= 第四大步:配置优化php的fastcgi配置文件,并启动fastcgi模式的php 配置php-fpm配置文件 (配置fastcgi) # cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf --先改名,把.default去掉 要在些配置文件配置的选项有: 监听的IP,端口或者socket 初始化的进程数 执行身份 错误是否显示 打开的资源限制等 # vim /usr/local/php/etc/php-fpm.conf 164 listen = /var/run/fastcgi/fastcgi.socket 534 php_flag[display_errors] = on 149 user = nginx 150 group = nginx 235 pm.max_children = 64 240 pm.start_servers = 20 255 pm.min_spare_servers = 5 250 pm.max_spare_servers = 35 261 pm.max_requests = 3000 458 rlimit_files = 65535 175 listen.owner = nginx 176 listen.group = nginx 177 listen.mode = 0660 --这三行是控制启动fastcgi之后的socket文件的权限(特别是新版本的php,修复了以前socket访问权限的bug,所以这里指好权限,那么nginx才能有权限读取socket来访问fastcgi) # mkdir /var/run/fastcgi # chown nginx.nginx /var/run/fastcgi/ 启动php fastcgi进程 # /usr/local/php/sbin/php-fpm -D -y /usr/local/php/etc/php-fpm.conf --启动fastcgi,直接这样启动,5.3.3版本之前的php需要加start参数来启动 ls /var/run/fastcgi/ --启动过后,就可以在/var/run/fastcgi/目录下找到socket文件 fastcgi.socket # ps -ef |grep fpm --也可以用此命令来查看php的factcgi的进程,有20个进程,因为我在前面配置pm.start_servers = 20 --如果要关闭fpm,可以直接pkill fpm就可以了 =============================================================== 第五大步: 配置nginx.conf主配置文件 # vim /usr/local/nginx/conf/nginx.conf user nginx nginx; --运行用户和组 worker_processes 8; --启动ngnix的服务的工作进程数 error_log logs/error.log info; --错误日志以及日志等级 pid logs/nginx.pid; --pid文件 worker_rlimit_nofile 65535; --能打开的最大的文件描述符 events { use epoll; --epoll工作模式 worker_connections 65535; --每个进程允许打开的并发连接数 } http { include mime.types; default_type application/octet-stream; server_tokens off; sendfile on; tcp_nopush on; keepalive_timeout 65; gzip on; server { listen 8000; --监听的端口 server_name 10.1.1.35; --域名或者IP charset utf8; --字符集 root /lnmp/web; --家目录 index index.php index.html index.htm; --主页文件 error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } location ~ .*\.php$ { fastcgi_pass unix:/var/run/fastcgi/fastcgi.socket;--对应php-fpm.conf里的设置 fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; --把/scripts改成$document_root,表示家目录下的.php文件也当会以php来执行 include fastcgi_params; } } } # mkdir /lnmp/web -p --把定义的网站家目录也创建出来 启动nginx # /usr/local/nginx/sbin/nginx reload的方法 # /usr/local/nginx/sbin/nginx -s reload 关闭的方法 # /usr/local/nginx/sbin/nginx -s stop 最基本的验证: vim /lnmp/web/index.html --建立一个主页,去访问它 # vim /lnmp/web/test.php --和以前lamp时一样,在家目录下建立一个php测试页面来测试 使用http://10.1.1.35:8000/test.php能验证支持php,说明整个基本的lnmp搭建完成 ===================================================================== ngnix 基本配置 例 1 server { listen 80; --端口 root /web; --使用绝对路径配置网站家目录 server_name li.cluster.com; --绑定域名或者IP index index.php index.html; --主页文件 } 例 2 虚拟主机的配置 基于ip的虚拟主机 基于端口的虚拟主机 基于域名的虚拟主机 基于ip的 http { server { listen 80; server_name 10.1.1.35; root /web1; } server { listen 80; server_name 10.1.1.9; root /web2; } } 基于端口的 http { server { listen 80; server_name 10.1.1.35; root /web1; } server { listen 8080; server_name 10.1.1.35; root /web2; } } 基于域名的 需要DNS的支持 http { server { listen 80; server_name new.cluster.com; root /web1; } server { listen 80; server_name sports.cluster.com; root /web2; } } 例 3 访问控制的实现 写法一: http { server { listen 80; server_name li.cluster.com; root /web location /sports/ { deny 10.1.1.35; allow all; --location标签,只拒绝35访问 } } 写法二 http { server { listen 80; server_name li.cluster.com; root /web; deny 10.1.1.35; allow all; --不使用location标签,只拒绝35访问 } } 写法三; 全局控制 http { deny 10.1.1.35; allow all; --全局的访问控制要写到http { }的大括号里 server { listen 80; server_name li.cluster.com; root /web; } server { listen 80; server_name sports.cluster.com; root /web2; } } 例 4 在server {} 配置段里加上下面一段 location /nginxstatus { stub_status on; access_log on; auth_basic "nginxstatus"; } 访问http://10.1.1.35:8000/nginxstatus Active connections: 3 --活动的连接数 server accepts handled requests 206909 206909 207011 --共创建了206909个连接,成功创建206909次握手,总共处理了207011个请求 Reading: 0 Writing: 1 Waiting: 2 例五: 日志格式,和日志切割 在server { } 配置段里加上下面一段日志格式的控制 log_format main '$remote_addr - $remote_user [$time_local] "$request"' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" $http_x_forwarded_for'; access_log logs/access.log main; 访问日志的切割,把每天的access.log保存到一个日期的目录下 提示如何打印昨天的时间,使用-d 'yesterday' [root@li ~]# date -d 'yesterday' +'%Y-%m-%d' 2015-08-29 vim /usr/local/nginx/sbin/nginx_logrotate.sh logpath="/usr/local/nginx/logs" year=`date -d 'yesterday' +'%Y'` month=`date -d 'yesterday' +'%m'` day=`date -d 'yesterday' +'%Y-%m-%d'` mkdir $logpath/$year/$month -p mv $logpath/access.log $logpath/$year/$month/$day.accesslog touch $logpath/access.log kill -USR1 `cat /usr/local/nginx/logs/nginx.pid` ---USR1是一个自定义的singal,(相当于reload刷新,在apache的日志切割脚本里用kill -HUP)主要是mv了日志之后,让nginx新产生一个空的日志 最后把这个写到crontab里,让它每天晚上凌晨执行 crontab -e 01 0 * * * sh /usr/local/nginx/sbin/nginx_logrotate.sh =================================================================== 安装Discuz论坛 Discuz_X3.2_SC_UTF8.zip # unzip Discuz_X3.2_SC_UTF8.zip -d /lnmp/web/ # cd /lnmp/web # mv upload/* . # rm upload/ -rf 然后使用firefox用下面的路径来安装 http://10.1.1.35:8000/install/ 环境检查这一步,有些目录和文件权限需要修改 # chown nginx.nginx /lnmp/web/ -R 数据库授权 # /usr/local/mysql/bin/mysql mysql> create database discuz; --创建一个库,用于存放将要安装的discuz论坛的表 mysql> grant all on discuz.* to 'discuzuser'@'localhost' identified by '123'; --授权一个用户,用于discuz论坛程序连接mysql mysql> flush privileges; 安装会出现下面的报错 Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) 解决方法1: 把mysql的配置socket路径改成/tmp/mysql.sock # vim /usr/local/mysql/etc/my.cnf [mysqld] port=3307 datadir=/mysqldata56 pid-file=/mysqldata56/mysql56.pid socket=/tmp/mysql.sock log-error=/mysqldata56/mysql56-err.log [client] socket=/tmp/mysql.sock 改完后,重启mysql 解决方法2: 如果不想改,可以把原来的socket做一个软链接到/tmp/mysql.sock # ln -s /mysqldata56/mysql56.socket /tmp/mysql.sock 解决方法3: 不使用socket连接,直接在安装界面填mysql的host为127.0.0.1:3307指定以tcp/ip协议的3307端口来连接 ========================================= memcache介绍与安装 memcache是一个开源分布式的内存对象缓存系统(另一个类似功能的软件叫redis).一般放在web程序与数据库,帮助缓存程序取数据库的数据。 web | memcache | mysql 笔记目录/lnmp_soft/ libevent-1.4.11-stable.tar.gz --memcache的事件驱动库 memcached-1.4.22.tar.gz --memcache主程序包(memcache官网下载) memcache-2.2.7.tgz --php的memcache扩展包(php官网下载) 上面三个软件包,第三个在安装php第三方扩展模块时就已经安装并支持了,所以下面继续安装另两个软件包 # tar xf libevent-1.4.11-stable.tar.gz -C /usr/src/lnmp # cd /usr/src/lnmp/libevent-1.4.11-stable/ # ./configure ;make ;make install # tar xf memcached-1.4.22.tar.gz -C /usr/src/lnmp # cd /usr/src/lnmp/memcached-1.4.22/ # ./configure --with-libevent=/usr/local/ ;make ;make install # /usr/local/bin/memcached -d -m 100 -u root --启动memcached守护进程,-d表示启动daemon,-m 100表示分配100MB内存给memcached做缓存,-u root指定以root用户来跑这个daemon 关闭方法(kill -TERM PID) # lsof -i:11211 --默认端口为11211 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME memcached 28795 root 26u IPv4 268755 0t0 TCP *:memcache (LISTEN) memcached 28795 root 27u IPv6 268756 0t0 TCP *:memcache (LISTEN) memcached 28795 root 28u IPv4 268759 0t0 UDP *:memcache memcached 28795 root 29u IPv4 268759 0t0 UDP *:memcache memcached 28795 root 30u IPv4 268759 0t0 UDP *:memcache memcached 28795 root 31u IPv4 268759 0t0 UDP *:memcache memcached 28795 root 32u IPv6 268760 0t0 UDP *:memcache memcached 28795 root 33u IPv6 268760 0t0 UDP *:memcache memcached 28795 root 34u IPv6 268760 0t0 UDP *:memcache memcached 28795 root 35u IPv6 268760 0t0 UDP *:memcache 测试:做完上面的步骤,其实你的工作基本就完成了,只需要告诉php开发人员,你的memcache的端口和IP,他们就可以写程序连接了 # vim /lnmp/web/memcachetest.php --在家目录下做一个测试页面,使用firefox访问这个页面,如果能显示This is a test!,则表示成功 connect("127.0.0.1", 11211); $mem->set('key', 'This is a test!', 0, 60); $val = $mem->get('key'); echo $val; ?> 测试memcache方法一 (开memcache显示,关闭memcache不能显示) # vim /usr/local/php/etc/php.ini ;extension = "memcache.so" --前面加;符号注释来模拟关闭 # pkill fpm # /usr/local/php/sbin/php-fpm -D -y /usr/local/php/etc/php-fpm.conf --再使用这两句把php的fastcgi重启,使之生效 测试memcache方法二 关闭memcache的11211,上面的This is a test!就无法显示.打开就OK ----------------- 上面是安装完memcached后,可以让开发人员使用。 如果是象discuz这种开源论坛安装完后,我没有开发能力,如何让discuz使用memcache? 使用安装时的admin用户和密码登陆后台http://172.16.2.35:8000/admin.php 点全局--》性能优化--》内存优化 可以看到memcache是支持,但是关闭的 把关闭状态改成打开的方法为: # vim /lnmp/web/config/config_global.php 25 $_config['memory']['memcache']['server'] = '127.0.0.1'; --把这个IP127.0.0.1配上(如果memcache在另一台机器上,就写它的IP) 保存后,再刷新后台的内存优化界面状态就变为打开了 ==================================================================== 补充一: 如果你编译安装好的lnmp在安装某个应用时,出现了php模块功能(或者叫extension扩展)缺失的报错,如何解决? 例: 我今天前面的php编译参数里并没有加--enable-mcrypt这个编译参数,所以并不支持mcrypt这个功能 可以通过三个方法来验证: 1,安装一个需要使用mcrypt功能的应用,就会告诉你缺少此功能(但这样比较麻烦,所以这里我选择后面两种) 2,访问http://172.16.2.35:8000/test.php,查找mcrypt功能,发现没有支持mcrypt 3,使用/usr/local/bin/php -m 命令显示所有php支持的extension扩展,发现没有支持mcrypt 解决方法: 第一种方法:重新编译php,在原来参数基础上加上--enable-mcrypt 第二种方法:不需要重编译php(也分两种情况自带扩展或第三方扩展) 1,ls /usr/src/lnmp/php-5.6.12/ext/ 看一下php的安装源码目录下的ext子目录里,这里就有自带的各种php扩展,如果你少了一个第三方的,那么就直接下载相关的软件包,编译安装成xxx.so,然后修改php.ini配置文件,加上这个so的支持就可以了 2,如果是/usr/src/lnmp/php-5.6.12/ext/目录里有的扩展,那么可以不用重编php,编译这个扩展,并加上此功能 (我这里以增加mcrypt扩展功能为例,操作过程如下:) 先安装mcrypt的依赖包mhash和libmcrypt(但rhel6.5没有自带,需要第三方下载再安装) mhash-0.9.9.9.tar.bz2 # tar xvf mhash-0.9.9.9.tar.bz2 -C /usr/src/lnmp/ # cd /usr/src/lnmp/mhash-0.9.9.9/ # ./configure ;make ;make install # /sbin/ldconfig libmcrypt-2.5.8.tar.bz2 # tar xvf libmcrypt-2.5.8.tar.bz2 -C /usr/src/lnmp/ # cd /usr/src/lnmp/libmcrypt-2.5.8/ # ./configure ;make ;make install # /sbin/ldconfig # cd /usr/src/lnmp/php-5.6.12/ext/mcrypt/ # /usr/local/php/bin/phpize --目录默认没有configure文件,需要使用你安装的对应版本phpize命令执行一下,才会出现configure # ./configure --with-php-config=/usr/local/php/bin/php-config # make # make install # ls /usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/mcrypt.so --产生了mcrpyt.so,表示安装成功 # vim /usr/local/php/etc/php.ini --在配置文件最后加上扩展的信息(这里顺便把opcache扩展也加上了) extension = mcrypt.so 最后重启php的fastcgi # pkill fpm # /usr/local/php/sbin/php-fpm -D -y /usr/local/php/etc/php-fpm.conf # /usr/local/php/bin/php -m |grep mcrypt --可以验证php支持了mcrypt扩展 mcrypt ====================================== 补充二: 一个web应用做好后,需要做一下测试,但一般要注意以下几点: 1,压力测试工作应该放到产品上线之前,而不是上线以后 2,测试时尽量跨公网进行,而不是内网 3,测试时并发应当由小逐渐加大,比如并发100时观察一下网站负载是多少、打开是否流程,并发200时又是多少、网站打开缓慢时并发是多少、网站打不开时并发又是多少 4,应尽量进行单元测试,如B2C网站可以着重测试购物车、推广页面等,因为这些页面占整个网站访问量比重较大 我们这里是内网做一些基本测试比较来说明lnmp的原理 测试工具 1,ab命令 apache自带 2,webbench # tar xf 笔记目录/lnmp_soft/webbench-1.5.tar.gz -C /usr/src/lnmp/ # cd /usr/src/lnmp/webbench-1.5/ # make ;make install 测试一:测试opcache(php代码缓存加速软件,以前有叫apc,xcache,eaccelerator,zend opimizer等等很多) 有支持opcache的lnmp做如下测试 # ab -n 1000 -c 1000 http://172.16.2.35:8000/index.php Concurrency Level: 1000 Time taken for tests: 0.122 seconds Complete requests: 1000 Failed requests: 853 (Connect: 0, Receive: 0, Length: 853, Exceptions: 0) Write errors: 0 Non-2xx responses: 1000 Total transferred: 646678 bytes HTML transferred: 458061 bytes Requests per second: 8226.05 [#/sec] (mean) Time per request: 121.565 [ms] (mean) Time per request: 0.122 [ms] (mean, across all concurrent requests) Transfer rate: 5194.93 [Kbytes/sec] received # webbench -c 1000 http://172.16.2.35:8000/index.php Webbench - Simple Web Benchmark 1.5 Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. Benchmarking: GET http://172.16.2.35:8000/index.php 1000 clients, running 30 sec. Speed=492092 pages/min, 2901688 bytes/sec. Requests: 246001 susceed, 45 failed. # vim /usr/local/php/etc/php.ini --把opcache相关配置注释掉然后重启php # pkill fpm # /usr/local/php/sbin/php-fpm -D -y /usr/local/php/etc/php-fpm.conf 没有支持opcache的lnmp做如下测试 # ab -n 1000 -c 1000 http://172.16.2.35:8000/index.php Concurrency Level: 1000 Time taken for tests: 0.197 seconds Complete requests: 1000 Failed requests: 158 (Connect: 0, Receive: 0, Length: 158, Exceptions: 0) Write errors: 0 Non-2xx responses: 1000 Total transferred: 640892 bytes HTML transferred: 452154 bytes Requests per second: 5070.76 [#/sec] (mean) Time per request: 197.209 [ms] (mean) Time per request: 0.197 [ms] (mean, across all concurrent requests) Transfer rate: 3173.64 [Kbytes/sec] received # webbench -c 1000 http://172.16.2.35:8000/index.php Webbench - Simple Web Benchmark 1.5 Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software. Benchmarking: GET http://172.16.2.35:8000/index.php 1000 clients, running 30 sec. Speed=309968 pages/min, 2615130 bytes/sec. Requests: 154966 susceed, 18 failed. --测试结论:有opcache的性能好(因为我这里是nginx,加上资源比较充足,所以测试结果差异不大) 课后测试实践: 1,在相同的机器上安装lamp和安装lnmp,都安装同一个论坛,然后使用测试工具分别对其测试,然后比较结果 2,lnmp里discuz论坛打开memcache和关闭memcache的测试比较 补充三: 把单机lnmp分离成多机 你可以把nginx,mysql,php分成三台服务器都可以(或者把nginx和php做成一台) 跟单机lnmp的区别在于: 1,php的编译如果用下面的参数,那么编译没什么区别,远程一样可以让php支持mysql --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 2,在安装论坛时,mysql授权时要写php的IP # grant all on discuz.* to 'discuzuser'@'PHP服务器IP' identified by '123'; # flush privileges; 3,在安装论坛的web页面,写mysql在哪里,要写mysql的IP加端口,而不是localhost