LAMP介绍 LAM(M)P: L: linux A: apache (httpd) M: mysql, mariadb M:memcached P: php, perl, python WEB资源类型: 静态资源:原始形式与响应内容一致,在客户端浏览器执行 动态资源:原始形式通常为程序文件,需要在服务器端执行之后,将执行结果返回给客户端 Web相关语言 客户端技术: html,javascript 服务器端技术:php, jsp,python,asp

CGI CGI:Common Gateway Interface 可以让一个客户端,从网页浏览器通过http服务器向执行在网络服务器上的程序传输数据;CGI描述了客户端和服务器程序之间传输的一种标准 请求流程: Client -- (httpd) --> httpd -- (cgi) --> application server (program file) -- (mysql) --> mysql php: 脚本编程语言、嵌入到html中的嵌入式web程序语言 基于zend编译成opcode(二进制格式的字节码,重复运行,可省略编译环境

PHP的Opcode Opcode是一种PHP脚本编译后的中间语言,类似于Java的ByteCode,或者.NET的MSL。PHP执行PHP脚本代码一般会经过如下4个步骤(确切的来说,应该是PHP的语言引擎Zend) 1、Scanning 词法分析,将PHP代码转换为语言片段(Tokens) 2、Parsing 语义分析,将Tokens转换成简单而有意义的表达式 3、Compilation 将表达式编译成Opocde 4、Execution 顺次执行Opcodes,每次一条,从而实现PHP脚本的功能 扫描-->分析-->编译-->执行

php配置 php:脚本语言解释器 配置文件:/etc/php.ini, /etc/php.d/*.ini 配置文件在php解释器启动时被读取 对配置文件的修改生效方法 Modules:重启httpd服务 FastCGI:重启php-fpm服务 /etc/php.ini配置文件格式: [foo]:Section Header directive = value 注释符:较新的版本中,已经完全使用;进行注释 #:纯粹的注释信息 ;:用于注释可启用的directive php.ini的核心配置选项文档: http://php.net/manual/zh/ini.core.php php.ini配置选项列表: http://php.net/manual/zh/ini.list.php php语言格式 <?php ...php code... ?>

php设置: max_execution_time= 30 最长执行时间30s memory_limit 128M 生产不够,可调大 display_errors off 调试使用,不要打开,否则可能暴露重要信息 display_startup_errors off 建议关闭 post_max_size 8M 最大上传数据大小,生产可能临时要调大,比下面项要大 upload_max_filesize 2M 最大上传文件单个,生产可能要调大 max_file_uploads = 20 同时上传最多文件数 date.timezone =Asia/Shanghai 指定时区 short_open_tag=on 开启短标签,如<? phpinfo();?>

注意时间格式需要在企业中更高一下: vim /var/www/html/tt.php echo date("Y/m/d H:i:s"); 加上时间

vim /etc/php/ini
    date.timezone = Asia/Shanghai   中国时间戳

LAMP LAMP httpd:接收用户的web请求;静态资源则直接响应;动态资源为php脚本,对此类资源的请求将交由php来运行 php:运行php程序 MariaDB:数据管理系统 http与php结合的方式 CGI FastCGI modules (将php编译成为httpd的模块,默认方式) MPM: prefork: libphp5.so event, worker: libphp5-zts.so

php代码 格式1 <?php echo "Hello world!" ?> 格式2

    <?php echo "Hello world!" ?>
    
php测试代码
    <?php
    echo date("Y/m/d H:i:s");
    phpinfo();
    ?>

布署phpMyadmin:图形界面管理数据库 下载:https://www.phpmyadmin.net/downloads/ phpMyAdmin-4.0.10.20-all-languages.zip

yum -y install httpd php php-mysql php-mbstring mariadb-server
systemctl start httpd
systemctl start mariadb

解压缩:phpMyAdmin-4.0.10.20-all-languages.zip
unzip phpMyAdmin-4.0.10.20-all-languages.zip
生成:
phpMyAdmin-4.0.10.20-all-languages

mv phpMyAdmin-4.0.10.20-all-languages /var/www/html

cd /var/www/html

mv phpMyAdmin-4.0.10.20-all-languages pm

cd phpMyAdmin-4.0.10.20-all-languages

cp config.sample.inc.php config.inc.php

vim config.sample.inc.php config.inc.php
$cfg['blowfish_secret'] = 'waxxz1314xx'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! */   误冲突

mysql_secure_installation  运行创建MySQL数据安全密码服务
Set root password? [Y/n] y 
设置用户密码

Remove anonymous users? [Y/n] y
删除匿名用户

Disallow root login remotely? [Y/n] n
不允许远程root登录

Remove test database and access to it? [Y/n] n
删除测试数据库并访问它

Reload privilege tables now? [Y/n] 
现在重新加载权限表

浏览器访问172.20.126.180/mp 即可

部署wordpress: 下载:https://cn.wordpress.org/txt-download/ wordpress-4.9.4-zh_CN.tar.gz

解压缩:tar xvf wordpress-4.9.4-zh_CN.tar.gz
生成:wordpress
mv wordpress /var/www/html/wp

cd /var/www/htmlwp

cp wp-config-sample.php wp-config.php

vim wp-config.php
    // ** MySQL 设置 - 具体信息来自您正在使用的主机 ** //
    /** WordPress数据库的名称 */
    define('DB_NAME', 'wps');
    
    /** MySQL数据库用户名 */
    define('DB_USER', 'wpuser');
    
    /** MySQL数据库密码 */
    define('DB_PASSWORD', 'chen001230');
    
    /** MySQL主机 */
    define('DB_HOST', '172.20.126.180');
    
    /** 创建数据表时默认的文字编码 */
    define('DB_CHARSET', 'utf8');
    
Mariadb创建用户:
mysql -uroot -p

MariaDB [(none)]> GRANT ALL ON wps.* TO 'wpuser'@'172.20.%.%' IDENTIFIED BY 'chen001230';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

浏览器登录172.20.126.180/wp即可

php的加速器:提升性能 php的加速器:基于PHP的特殊扩展机制如opcode缓存扩展也可以将opcode缓存于php的共享内存中,从而可以让同一段代码的后续重复执行时跳过编译阶段以提高性能。这些加速器并非真正提高了opcode的运行速度,而仅是通过分析opcode后并将它们重新排列以达到快速执行的目的 常见的php加速器有: 1、APC (Alternative PHP Cache) 遵循PHP License的开源框架,PHP opcode缓存加速器,目前的版本不适用于PHP 5.4项目地址http://pecl.php.net/package/APC 2、eAccelerator 源于Turck MMCache,早期的版本包含了一个PHP encoder和PHP loader,目前encoder已经不在支持。项目地址 http://eaccelerator.net 3、XCache 快速而且稳定的PHP opcode缓存,经过严格测试且被大量用于生产环境。项目地址:http://xcache.lighttpd.net/,收录EPEL源 下载: xcache-3.2. 0.tar.gz包 yum -y groupinstall "Development tool" yum -y install php-devel

解压: xcache-3.2.0.tar.gz
    tar xvf  xcache-3.2.0.tar.gz
    生成:xcache-3.2.0
    
    cd xcache-3.2.0
    
    phpize
    
    ./configure --enable-xcache --with-php-config=/usr/bin/php-config
    make -j 4 && make install
    
    cp xcache-3.2.0/xcache.ini  /etc/php.ini
    
    systemctl restart httpd.service

        
    4、Zend Optimizer和Zend Guard Loader
        Zend Optimizer并非一个opcode加速器,它是由Zend Technologies为PHP5.2及以前的版本提供的一个免费、闭源的PHP扩展,其能够运行由Zend Guard生成的加密的PHP代码或模糊代码。 而Zend Guard Loader则是专为PHP5.3提供的类似于Zend Optimizer功能的扩展。项目地址http://www.zend.com/en/products/guard/runtime-decoders
    5、NuSphere PhpExpress
        NuSphere的一款开源PHP加速器,它支持装载通过NuSphere PHP Encoder编码的PHP程序文件,并能够实现对常规PHP文件的执行加速。项目地址,http://www.nusphere.com/products/phpexpress.htm

php httpd+php结合的方式: module: php cgi fastcgi : php-fpm php-fpm: CentOS 6: PHP-5.3.2之前:默认不支持fpm机制;需要自行打补丁并编译安装 httpd-2.2:默认不支持fcgi协议,需要自行编译此模块 解决方案:编译安装httpd-2.4, php-5.3.3+ CentOS 7: httpd-2.4:rpm包默认编译支持fcgi模块 php-fpm包:专用于将php运行于fpm模式

配置fastcgi php配置 配置文件:/etc/php.ini,/etc/php.d/.ini Module下,重启Httpd服务 FastCGI模式下,重启php-fpm服务 配置文件格式 配置文件格式:[foo]:Section Header Directive=value 注释符:# 纯粹的注释信息 ; 用于注释可启动的指令 说明:在较新的版本中,已经完全使用”;”进行注释 php.ini核心配置的详细说明: http://php.net/manual/zh/ini.core.php Php.ini配置选项列表: http://php.net/manual/zh/ini.list.php fcgi服务配置文件:/etc/php-fpm.conf, /etc/php-fpm.d/.conf 连接池: pm = static|dynamic static:固定数量的子进程;pm.max_children dynamic:子进程数量以动态模式管理 pm.max_children pm.start_servers pm.min_spare_servers pm.max_spare_servers pm.max_requests = 500 确保运行php-fpm进程的用户对session目录有读写权限 mkdir /var/lib/php/session chown apache.apache /var/lib/php/session 配置fastcgi (1) 配置httpd,添加/etc/httpd/conf.d/fcgi.conf配置文件,内容类似 DirectoryIndex index.php ProxyRequests Off ProxyPassMatch ^/(.*.php)$ fcgi://127.0.0.1:9000/var/www/html/$1 注意:在HTTPD服务器上必须启用proxy_fcgi_module模块,充当PHP客户端 httpd –M |grep fcgi cat /etc/httpd/conf.modules.d/00-proxy.conf

(2) 虚拟主机配置
    vim /etc/httpd/conf.d/vhosts.conf
    DirectoryIndex index.php
    <VirtualHost *:80>
    ServerName www.b.net
    DocumentRoot /apps/vhosts/b.net
    ProxyRequests Off
    ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/apps/vhosts/b.net/$1
    <Directory "/apps/vhosts/b.net">
            Options None
            AllowOverride None
            Require all granted
        </Directory>
    </VirtualHost>

实例:基于fastcgi搭建lamp架构在一台主机上搭建: yum install httpd php-fpm php-mysql mariadb-server

vim /etc/httpd/conf.d/fcgi.conf
DirectoryIndex index.php
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/var/www/html/$1

vim /var/www/html/index.php 测试页面
<?php
$dsn='mysql:host=localhost;dbname=mysql';
$username='root';
$passwd='';
$dbh=new PDO($dsn,$username,$passwd);
var_dump($dbh);
?>

systemctl start httpd
systemctl start mariadb-server

实例:172.20.102.70:httpd服务器 172.20.126.180:php-fpm服务器 172.20.126.229:mysql服务器分布式搭建lamp的Discuz论坛: 做实验之前将iptable和selinux关闭: 70:yum -y install httpd vim /etc/httpd/conf.d/test.conf DirectoryIndex index.php ProxyRequests Off ProxyPassMatch ^/(.*.php)$ fcgi://172.20.126.180:9000/data/www/$1

180:yum -y install php-fpm php-mysql vim /etc/php-fpm.d/www.conf listen = 9000 #listen.allowed_clients = 127.0.0.1

mkdir -pv /data/www

vim /data/www/index.html    用于测试
    <?php
    try {
    $user='test';
    $pass='chen001230';
    $dbh = new PDO('mysql:host=172.20.126.229;dbname=mysql', $user, $pass);
    foreach($dbh->query('SELECT user,host from user') as $row) {
    print_r($row);
    }
    $dbh = null;
    } catch (PDOException $e) {
    print "Error!: " . $e->getMessage() . "<br/>";
    die();
    }
    ?>

systemctl start php-fpm.service 

下载:Discuz_X3.2_SC_UTF8.zip 
unzip Discuz_X3.2_SC_UTF8.zip 
生成:
unpload
cd upload/

cp -r * /data/www/      覆盖掉index.php

setfacl -R -m u:apache:rwx /data/www/

systemctl php-fpm.service

setfacl -R -b /data/www     回收权限

229:yum -y install mariadb-server systemctl start mariadb.server

MariaDB [(none)]> grant all on *.* to test@'172.20.126.%' identified by 'chen001230';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

用浏览器访问172.20.102.70/install/index.php 一步步安装即可; 注意没有显示图片

在172.20.126.180:上安装httpd: yum -y install httpd

vim /data/www

vim /etc/httpd/conf.d/test.conf DirectoryIndex index.php ProxyRequests Off ProxyPassMatch ^/(.*.php)$ fcgi://127.0.0.1:9000/data/www/$1

vim /etc/httpd/conf/httpd.conf DocumentRoot "/data/www/" <Directory "/data/www"> AllowOverride None # Allow open access: Require all granted </Directory>

systemctl start httpd.service

浏览器访问:172.20.126.180即可;

在172.20.126.180上在搭建一个wordpress博客网站实现虚拟主机两个服务同时使用: 下载:wordpress-4.9.4-zh_CN.tar.gz 解压生成: wordpress

mkdir -pv /data/www2

cp -r wordpress/* /data/www2

cd /data/www2/

cp wp-config-sample.php wp-config.php

172.20.126.229:mysql MariaDB [(none)]> create database wpdb; Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> grant all on *.* to wp@'172.20.126.%' identified by 'chen001230';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.01 sec)

172.20.126.180:httpd vim /data/www2/wp-config.php / ** MySQL 设置 - 具体信息来自您正在使用的主机 ** // /** WordPress数据库的名称 */ define('DB_NAME', 'wpdb');

/** MySQL数据库用户名 */
define('DB_USER', 'wp');

/** MySQL数据库密码 */
define('DB_PASSWORD', 'chen001230');

/** MySQL主机 */
define('DB_HOST', '172.20.126.229');

/** 创建数据表时默认的文字编码 */
define('DB_CHARSET', 'utf8');

创建虚拟主机: vim /etc/httpd/conf.d/host.conf <Virtualhost :80> servername www.xabbs.com documentroot /data/www DirectoryIndex index.php ProxyRequests Off ProxyPassMatch ^/(..php)$ fcgi://127.0.0.1:9000/data/www/$1 <directory /data/www> require all granted </directory> </Virtualhost>

<Virtualhost *:80>
servername www.wp.com
documentroot /data/www2
DirectoryIndex index.php
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/data/www2/$1
<directory /data/www2>
require all granted
</directory>
</Virtualhost>

用一个新的主机访问: vim /etc/hosts 172.20.102.79 www.xabbs.com www.wp.com

用局域网中的浏览器访问即可www.xabbs.com www.wp.com/index.php

源码编译安装:lamp:搭建WordPress: 两台机器: yum -y groupinstall "development tools" yum -y install pcre-devel openssl-devel expat-devel

    172.20.102.70:
        apr-1.6.3.tar.gz  
        apr-util-1.6.1.tar.gz  
        httpd-2.4.33.tar.bz2  
        php-7.1.18.tar.bz2  
        wordpress-4.9.4-zh_CN.tar.gz
    
                
    172.20.102.70:机器下:
        tar xvf apr-1.6.3.tar.gz
        tar xvf apr-util-1.6.1.tar.gz
        tar xvf httpd-2.4.33.tar.bz2
        
        mv apr-1.6.3 httpd-2.4.33/srclib/apr
        mv apr-util-1.6.1 httpd-2.4.33/srclib/apr-util
        
        cd cd httpd-2.4.33/

        ./configure --prefix=/app/httpd24 \
        --enable-so \
        --enable-ssl \
        --enable-cgi \
        --enable-rewrite \
        --with-zlib \
        --with-pcre \
        --with-included-apr \
        --enable-modules=most \
        --enable-mpms-shared=all \
        --with-mpm=prefork

        make -j 4 && make install
        
        echo PATH=/app/http24/bin:$PATH > /etc/profile.d/httpd.sh
        . /etc/profile.d/httpd.sh
        
        apachectl  启用服务
        
    172.20.126.229:mariadb 编译安装
    yum -y groupinstall "development tools"
    yum install bison bison-devel zlib-devel libcurl-devel libarchive-devel boost-devel gcc gcc-c++ cmake libevent-devel gnutls-devel libaio-devel openssl-devel ncurses-devel libxml2-devel
    
    tar xvf mariadb-10.2.15.tar.gz
    
    cd  mariadb-10.2.15
    
    mkdir /data/mysqldb
    
    useradd -r -s /sbin/nologin mysql
    
    chown maria.maria /data/mysqldb
        
安装:cmake . \
    -DCMAKE_INSTALL_PREFIX=/app/mysql \     
    -DMYSQL_DATADIR=/data/mysqldb/ \
    -DSYSCONFDIR=/etc \
    -DMYSQL_USER=mysql \
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \
    -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
    -DWITH_PARTITION_STORAGE_ENGINE=1 \
    -DWITHOUT_MROONGA_STORAGE_ENGINE=1 \
    -DWITH_DEBUG=0 \
    -DWITH_READLINE=1 \
    -DWITH_SSL=system \
    -DWITH_ZLIB=system \
    -DWITH_LIBWRAP=0 \
    -DENABLED_LOCAL_INFILE=1 \
    -DMYSQL_UNIX_ADDR=/app/mysql/mysql.sock \
    -DDEFAULT_CHARSET=utf8 \
    -DDEFAULT_COLLATION=utf8_general_ci
    
    make -j 4 && make install 
    
    echo PATH=/app/mysql/bin:$PAHT > /etc/profile.d/mysql.sh
    . /etc/profile.d/mysql.sh
    
    生成数据库:
    cd /app/mysql
    scripts/mysql_install_db --datadir=/data/mysqldb/ --user=mysql --basedir=/app/mysql
    
    cp /app/mysql/support-files/my-huge.cnf   /etc/my.cnf
    
    #setfacl -R -m u:mysql:rwx /app/mysql/  (不用加)
    
    cp /app/mysql/support-files/mysql.server /etc/init.d/mysqld
    
    vim /etc/my.conf
    [mysqld]
    log_bin
    datadir = /data/mysqldb
            
    service mysqld start
    
    chkconfig --add mysqld  开机启动
    chkconfig --list      查看
    
    创建WordPress的数据库、用户:
    MariaDB [(none)]> create database wpdb;
    Query OK, 1 row affected (0.01 sec)
    
    MariaDB [(none)]> grant all on wpdb.* to wpuser@'172.20.102.%' identified by 'chen001230';
    Query OK, 0 rows affected (0.00 sec)
    
    MariaDB [(none)]> flush privileges;
    Query OK, 0 rows affected (0.00 sec)
    


172.20.102.70:机器下:编译基于fastcgi的php:
    tar xvf php-7.1.18.tar.bz2
    
    ./configure --prefix=/app/php \
    --enable-mysqlnd \
    --with-mysqli=mysqlnd \
    --with-openssl \
    --with-pdo-mysql=mysqlnd \
    --enable-mbstring \
    --with-freetype-dir \
    --with-jpeg-dir \
    --with-png-dir \
    --with-zlib \
    --with-libxml-dir=/usr \
    --enable-xml \
    --enable-sockets \
    --enable-fpm \
    --with-config-file-path=/etc \
    --with-config-file-scan-dir=/etc/php.d \
    --enable-maintainer-zts \
    --disable-fileinfo
    
    make -j 4 && make install
    
    tar xvf wordpress-4.9.4-zh_CN.tar.gz
    
    mv wordpress/* /app/httpd24/htdocs/
    
    /app/httpd24/htdocs
    cp wp-config-sample.php wp-config.php 
    
    vim wp-config.php
    // ** MySQL 设置 - 具体信息来自您正在使用的主机 ** //
    /** WordPress数据库的名称 */
    define('DB_NAME', 'wpdb');
    
    /** MySQL数据库用户名 */
    define('DB_USER', 'wpuser');
    
    /** MySQL数据库密码 */
    define('DB_PASSWORD', 'chen001230');
    
    /** MySQL主机 */
    define('DB_HOST', '172.20.126.229');
    
    vim /etc/profile.d/httpd.sh
    PATH=/app/php/bin:/app/php/sbin:/app/httpd24/bin:/app/http24/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
    . /etc/profile.d
    
    准备php的配置文件:
    cp php-7.1.18/php.ini-production /etc/php.ini
    
    cp php-7.1.18/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm  服务启动脚
    chmod +x /etc/init.d/php-fpm 
    
    chkconfig --add php-fpm
    
    cd /app/php/etc/
    cp php-fpm.conf.default php-fpm.conf    改成后缀.conf可生效文件
    cd php-fpm.d/
    cp www.conf.default www.conf
    
    useradd -r -s /sbin/nologin mysql
    
    vim /app/php/etc/php-fpm.d/www.conf
    user = apache
    
    service php-fpm start
    
    vim /app/httpd24/conf/httpd.conf    默认是注销的,需要启用
    LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
    LoadModule proxy_module modules/mod_proxy.so
    
    <IfModule dir_module>
        DirectoryIndex index.php index.html     优先使用.php的后缀文件
    </IfModule>
    
    加在最后即可:
    AddType application/x-httpd-php .php        识别php的后缀文件
    AddType application/x-httpd-php-source .phps
    ProxyRequests Off
    ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/app/httpd24/htdocs/$1
    
    apache restart  
    
    用浏览器访问172.20.102.70即可看是否出现WordPress博客网站;
    
    ab -c 10 -n 200 http://172.20.102.70/   测试性能
    Requests per second:    32.65 [#/sec] (mean)