LAMP:Linux+Apache+Mariadb(Mysql)+PHP

为了测试方便,全部机子清空防火墙规则或者关闭防火墙,但SELinux开着。

图片.png

httpd: 192.168.10.201【RHEL7.0主机名:node1】

mariadb 192.168.10.202【RHEL7.3主机名:node2】

php192.168.10.203【RHEL7.3主机名:node3】

一、编译安装httpdnode1

0、安装依赖包

yum  install  libexpat*  pcre*  -y

yum  groupinstall  "Development  tools"  -y

1、下载安装apr,这里使用1.6.3版本

·下载地址:http://mirror.bit.edu.cn/apache/apr/apr-1.6.3.tar.gz

·解压安装:

[root@node1 ~]# tar xf apr-1.6.3.tar.gz

[root@node1 ~]# cd apr-1.6.3/

[root@node1 apr-1.6.3]# ./configure –prefix=/usr/local/apr

[root@node1 apr-1.6.3]# make && make install

2、下载安装apr-util,这里使用1.6.1版本

·下载地址:http://mirror.bit.edu.cn/apache/apr/apr-util-1.6.1.tar.gz

·解压安装:

[root@node1 ~]# tar xf apr-util-1.6.1.tar.gz

[root@node1 ~]# cd apr-util-1.6.1/

[root@node1 apr-util-1.6.1]# ./configure –prefix=/usr/local/apr-util  –with-apr=/usr/local/apr/

[root@node1 apr-util-1.6.1]# make && make install

3、下载httpd,这里使用2.4.49版本

下载地址:http://mirrors.tuna.tsinghua.edu.cn/apache/httpd/httpd-2.4.29.tar.gz

4、解压安装httpd

[root@node1 ~]# tar xf httpd-2.4.29.tar.gz

[root@node1 ~]# cd httpd-2.4.29/

[root@node1 httpd-2.4.29]# ./configure –prefix=/usr/local/apache –sysconfdir=/etc/httpd –enable-so –enable-ssl –enable-cgi –enable-rewrite –with-zlib –with-pcre –with-apr=/usr/local/apr –with-apr-util=/usr/local/apr-util/ –enable-modules=all –enable-mpms-shared=all –with-mpm=prefork

[root@node1 httpd-2.4.29]# make && make install

参数解释:

–sysconfdir=/etc/httpd  指定配置文件路径

–enable-so  启动模块动态装卸载

–enable-ssl  编译ssl模块

–enable-cgi 支持cgi机制(能够让静态web服务器能够解析动态请求的一个协议)

–enable-rewrite  支持url重写

–with-zlib  支持数据包压缩

–with-pcre  支持正则表达式

–with-apr=/usr/local/apr  指明依赖的apr所在目录

–with-apr-util=/usr/local/apr-util/  指明依赖的apr-util所在的目录

–enable-modules=all 启用的模块

–enable-mpms-shared=all   以共享方式编译的模块

–with-mpm=prefork     指明httpd的工作方式为prefork,工作模式3种:preforkeventworker

3、设置环境变量

[root@node1 ~]# vim /etc/profile.d/httpd.sh

export  PATH=/usr/local/apache/bin:$PATH

[root@node1 ~]# source /etc/profile.d/httpd.sh

4、配置服务脚本

httpd源码包解压后build/rpm目录下httpd.init文件就是服务脚本

[root@node1 ~]# cp httpd-2.4.29/build/rpm/httpd.init /etc/rc.d/init.d/httpd

[root@node1 ~]#vim /etc/rc.d/init.d/httpd

httpd=${HTTPD-/usr/local/apache/bin/httpd}

pidfile=${PIDFILE-/usr/local/apache/logs/${prog}.pid}

CONFFILE=/etc/httpd/httpd.conf

根据实际情况修改以上三项

[root@node1 init.d]# chmod +x httpd

httpd服务添加到系统服务:

[root@node1 init.d]# chkconfig –add httpd

5、修改httpd配置文件的ServerName,以及pidfile

[root@node1 ~]# vim /etc/httpd/httpd.conf

ServerName localhost:80

PidFile /var/run/httpd.pid

6、启动httpd

[root@node1 ~]# systemctl start httpd

浏览器打开:192.168.10.201

图片.png

OK。。。httpd编译安装完成。

二、编译安装mariadbnode2

1、安装依赖包

[root@node2 ~]#yum -y install perl perl-devel

2、下载mariadb5.5.57,这里使用的是二进制安装包

http://mirrors.neusoft.edu.cn/mariadb/mariadb-5.5.57/source/mariadb-5.5.57.tar.gz 

在官网中:源码安装包:mariadb-5.5.57.tar.gz,二进制安装包:mariadb-5.5.57-linux-x86_64.tar.gz,这里使用的是非官网的。

官网下载地址:https://downloads.mariadb.org/mariadb/5.5.57/

blob.png

3、创建数据库数据存放目录

[root@node2 ~]# mkdir /mydata/data -pv

[root@node2 ~]# chown -R mysql.mysql /mydata/data/

4、创建mysql用户和组

[root@node2 ~]# groupadd -r -g 306 mysql

[root@node2 ~]# useradd -r -g 306 -u 306 -s /sbin/nologin mysql

5、安装maraidb

5.1解压maradb/usr/local目录创建mysql连接

[root@node2 ~]# tar xf mariadb-5.5.57.tar.gz -C /usr/local/

[root@node2 ~]# cd /usr/local/

[root@node2 local]# ln -sv mariadb-5.5.57/ mysql

5.2修改mysql目录中全部文件的属主属组

[root@node2 local]# cd mysql/

[root@node2 mysql]# chown -R root.mysql ./*

图片.png

5.4数据库初始化

[root@node2 mysql]# scripts/mysql_install_db –user=mysql –datadir=/mydata/data/

6、数据库配置文件

support-files/my-large.cnf文件到/etc/mysql,名字为my.cnf

[root@node2 mysql]# mkdir /etc/mysql

[root@node2 mysql]# cp  support-files/my-large.cnf /etc/mysql/my.cnf

7、修改my.cnf配置文件

[root@node2 mysql]# vim /etc/mysql/my.cnf

添加以下内容:

datadir = /mydata/data

innodb_file_per = on

skip_name_resolve = on

图片.png

8、配置服务脚本

support-files/mysql.server复制到/etc/rc.d/init.d/目录,命名为mysqld

[root@node2 mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld

9、新建/var/log/mysqld.log文件

[root@node2 mysql]# touch /var/log/mysqld.log

10.、将mysqld添加到系统服务

[root@node2 mysql]# chkconfig –add mysqld

11、修改环境变量

[root@node2 mysql]# vim /etc/profile.d/mysql.sh

export PATH=/usr/local/mysql/bin:$PATH

[root@node2 mysql]# source /etc/profile.d/mysql.sh

12、启动mysqld服务

[root@node2 mysql]# systemctl start mysqld

13、为root用户授权

在实战中root用户不能远程登录,可以授权普通用户远程登录。

[root@node2 mysql]# mysql

MariaDB [(none)]> GRANT ALL ON *.* TO 'root'@'%' IDENTIFIED BY '123456';

MariaDB [(none)]> FLUSH PRIVILEGES;

node1上测试连接数据库:

[root@node1 ~]# mysql -uroot -h192.168.10.202 -p123456

三、编译安装phpnode3

1、安装相关依赖包

[root@node3 ~]# yum -y install libxml2-devel bzip2-devel libcurl-devel libmcrypt-devel openssl openssl-devel php-mysql

2、下载 php-5.6.33.tar.gz

http://php.net/distributions/php-5.6.33.tar.gz

3、编译安装php

[root@node3 ~]# tar xf php-5.6.33.tar.gz

[root@node3 ~]# cd php-5.6.33/

[root@node3 php-5.6.33]# ./configure –prefix=/usr/local/php5 –with-mysql=mysqlnd –with-pdo-mysql=mysqlnd –with-mysqli=mysqlnd –with-openssl –enable-mbstring –with-freetype-dir –with-jpeg-dir –with-png-dir –with-zlib –with-libxml-dir=/usr –enable-xml –enable-sockets –enable-fpm –with-mcrypt –with-config-file-path=/etc/php5/ –with-config-file-scan-dir=/etc/php5.d –with-bz2

[root@node3 php-5.6.33]# make -j 2 && make install

4、配置php-fpm

4.1复制php.ini-production /etc/php5/php.ini

[root@node3 php-5.6.33]# mkdir /etc/php5{,.d}

[root@node3 php-5.6.33]# cp php.ini-production /etc/php5/php.ini

4.2复制sapi/fpm/init.d.php-fpm/etc/rc.d/init.d/php-fpm

[root@node3 php-5.6.33]# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm

4.3添加执行权限:php-fpm

[root@node3 php-5.6.33]# chmod +x /etc/rc.d/init.d/php-fpm

4.4php-fpm添加到系统服务

[root@node3 php-5.6.33]# chkconfig –add php-fpm

4.5修改php-fpm.conf配置文件

[root@node3 php-5.6.33]# cd /usr/local/php5/etc/

[root@node3 etc]# cp php-fpm.conf.default php-fpm.conf

[root@node3 etc]# vim php-fpm.conf

user = www

group = www

修改监听为:listen = 0.0.0.0:9000

设置进程并发数,默认为5pm.max_children = 50

刚开始的进程数,默认为2pm.start_servers = 5

最少空闲进程数,默认为1pm.min_spare_servers = 2

最少空闲进程数,默认为3pm.max_spare_servers = 5

修改pid  = /usr/local/php5/var/run/php-fpm.pid

4.7 新建一个mysql用户,用户和组idnode2一样

[root@node3 etc]# groupadd -r -g 306 mysql

[root@node3 etc]# useradd -r -g 306 -u 306 -s  /sbin/nologin mysql

4.8 修改php.ini文件

[root@node3 etc]# pwd

/usr/local/php5/etc

[root@node3 etc]# vim /etc/php5/php.ini

short_open_tag = On

4.9启动php-fpm服务

[root@node3 etc]# systemctl start php-fpm

四、整合httpdphp

node1node3节点创建一个名字为www的系统用户,用户和组的id301

# groupadd -r -g 301 www

# useradd -r -g 301 -u 301 -s /sbin/nologin www

1)网站目录设置

1、在node1上创建网站目录web

[root@node1 ~]# mkdir /web

[root@node1 ~]# chown -R www.www /web

2、设置SELinux

[root@node1 ~]# semanage fcontext -a -t httpd_sys_content_t /web

[root@node1 ~]# restorecon -Rv /web/

图片.png

3nfs共享/web目录

[root@node1 ~]# vim /etc/exports

/web *(rw,no_root_squash)

[root@node1 ~]# exportfs -rv

4、新建测试页:

[root@node1 ~]# vim /web/index.php

<?php

    $conn = mysql_connect('192.168.10.202','root','123456');

    if($conn)

      echo "connect Database OK…";

    else

      echo "connect Database Fail…";

    mysql_close();

    phpinfo();

?>

5node3挂载node1共享的/web目录

[root@node3 ~]# mkdir /web

[root@node3 ~]# chown -R www.www /web

[root@node3 ~]# semanage fcontext -a -t httpd_sys_content_t /web

[root@node3 ~]# restorecon -Rv /web/

[root@node3 ~]# mount -t nfs 192.168.10.201:/web/ /web/

[root@node3 ~]# mount

图片.png

2http配置

1、修改httpd配置文件

[root@node1 ~]# vim /etc/httpd/httpd.conf

<IfModule dir_module>

    DirectoryIndex index.php index.html

</IfModule>

LoadModule proxy_module modules/mod_proxy.so

LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so

AddType application/x-httpd-php .php

AddType application/x-httpd-php-source .phps

Include /etc/httpd/extra/ vhost.conf

2、新建一个虚拟主机配置文件,文件名:vhost.conf

[root@node1 ~]# vim /etc/httpd/extra/vhost.conf

<VirtualHost *:80>

    DocumentRoot "/web"

    ServerName haha

    ProxyRequests Off

    ProxyPassMatch ^/(.*.php)$ fcgi://192.168.10.203:9000/web/$1

  <Directory "/web">

    AllowOVerride None

    Require all granted

  </Directory>

</VirtualHost>

五、测试LAMP

1、修改node1node2node3SELinux

setsebool -P httpd_can_network_connect 1

2、重启httpdmysqlphp-fpm服务

浏览器打开:192.168.10.201

图片.png

LAMP搭建成功。

xcache加速器编译安装

 

node3上安装xcache,为php加速

1、下载xcache-3.2.0.tar.bz2

http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.bz2

2、解压

[root@node3 ~]# tar xf xcache-3.2.0.tar.bz2

[root@node3 ~]# cd xcache-3.2.0/

3、执行phpize命令

[root@node3 xcache-3.2.0]# /usr/local/php5/bin/phpize

图片.png

4、编译安装xcache

[root@node3 xcache-3.2.0]# ./configure –enable-xcache –with-php-config=/usr/local/php5/bin/php-config

[root@node3 xcache-3.2.0]# make && make install

….

记住以下信息:

Installing shared extensions:

    /usr/local/php5/lib/php/extensions/no-debug-non-zts-20131226/

5、复制xcache.ini /etc/php5.d

[root@node3 xcache-3.2.0]# cp xcache.ini /etc/php5.d

6、配置xcache.ini

[root@node3 ~]# vim /etc/php.d/xcache.ini

extension = /usr/local/php5/lib/php/extensions/no-debug-non-zts-20131226/xcache.so

图片.png

重启httpd、php-fpm服务,浏览器打开:192.168.10.201

图片.png图片.png

压力测试:

[root@node2 ~]# ab -c 200 -n 1000 http://192.168.10.201/index.php