编译软件的过程与经验:
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




安装绘图引擎模块p_w_picpathmagick,与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与p_w_picpathmagick的通道)

# 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测试页面来测试
        phpinfo();
?>



使用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!,则表示成功

$mem = new Memcache;
$mem->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