LAMP简介与部署
lamp简介
lamp,是由linux+apache+mysql/mariadb+php/perl/python的一组动态网站或者服务器的开源软件,除linux外其它各部件本身都是各自独立的程序,但是因为经常被放在一起使用,拥有了越来越高的兼容度,共同组成了一个强大的web应用程序平台。
lamp指的是linux(操作系统)、apache(http服务器)、mysql(也指mariadb,数据库软件)和php(有时也是指perl或python)的第一个字母,一般用来建立web应用平台。
web服务器工作流程
web服务器的资源分为两种,静态资源和动态资源
- 静态资源就是指静态内容,客户端从服务器获得的资源的表现形式与原文件相同。可以简单的理解为就是直接存储于文件系统中的资源
- 动态资源则通常是程序文件,需要在服务器执行之后,将执行的结果返回给客户端
那么web服务器如何执行程序并将结果返回给客户端呢?下面通过一张图来说明一下web服务器如何处理客户端的请求
如上图所示
阶段①显示的是httpd服务器(即apache)和php服务器通过fastcgi协议进行通信,且php作为独立的服务进程运行
阶段②显示的是php程序和mysql数据库间通过mysql协议进行通信。php与mysql本没有什么联系,但是由php语言写成的程序可以与mysql进行数据交互。同理perl和python写的程序也可以与mysql数据库进行交互
cgi与fastcgi
上图阶段①中提到了fastcgi,下面我们来了解下cgi与fastcgi。
cgi(common gateway interface,通用网关接口),cgi是外部应用程序(cgi程序)与web服务器之间的接口标准,是在cgi程序和web服务器之间传递信息的过程。cgi规范允许web服务器执行外部程序,并将它们的输出发送给web浏览器,cgi将web的一组简单的静态超媒体文档变成一个完整的新的交互式媒体。
fastcgi(fast common gateway interface)是cgi的改良版,cgi是通过启用一个解释器进程来处理每个请求,耗时且耗资源,而fastcgi则是通过master-worker形式来处理每个请求,即启动一个master主进程,然后根据配置启动几个worker进程,当请求进来时,master会从worker进程中选择一个去处理请求,这样就避免了重复的生成和杀死进程带来的频繁cpu上下文切换而导致耗时
httpd与php结合的方式
httpd与php结合的方式有以下三种:
- modules:php将以httpd的扩展模块形式存在,需要加载动态资源时,httpd可以直接通过php模块来加工资源并返回给客户端
- httpd prefork:libphp5.so(多进程模型的php)
- httpd event or worker:libphp5-zts.so(线程模型的php)
- cgi:httpd需要加载动态资源时,通过cgi与php解释器联系,获得php执行的结果,此时httpd负责与php连接的建立和断开等
- fastcgi:利用php-fpm机制,启动为服务进程,php自行运行为一个服务,https通过socket与php通信
较于cgi方式,fastcgi更为常用,很少有人使用cgi方式来加载动态资源
web工作流程
通过上面的图说明一下web的工作流程:
- 客户端通过http协议请求web服务器资源
- web服务器收到请求后判断客户端请求的资源是静态资源或是动态资源
- 若是静态资源则直接从本地文件系统取之返回给客户端。
- 否则若为动态资源则通过fastcgi协议与php服务器联系,通过cgi程序的master进程调度worker进程来执行程序以获得客户端请求的动态资源,并将执行的结果通过fastcgi协议返回给httpd服务器,httpd服务器收到php的执行结果后将其封装为http响应报文响应给客户端。在执行程序获取动态资源时若需要获得数据库中的资源时,由php服务器通过mysql协议与mysql/mariadb服务器交互,取之而后返回给httpd,httpd将从php服务器收到的执行结果封装成http响应报文响应给客户端。
lamp平台构建
环境
- centos7/redhat7-192.168.233.129
- httpd-2.4
- mysql-5.7
- php
- php-mysql
安装次序:
httpd --> mysql --> php
安装httpd
#安装开发工具 [root@lynk ~]# yum -y install epel-release [root@lynk ~]# yum groups mark install 'development tools' #创建apache需要的用户及组 [root@lynk ~]# groupadd -r apache [root@lynk ~]# useradd -r -m -s /sbin/nologin -g apache apache #安装依赖包 [root@lynk ~]# yum -y install openssl-devel pcre-devel expat-devel libtool #安装apr及apr-util [root@lynk ~]# cd /usr/src/ [root@lynk src]# wget http://mirrors.shu.edu.cn/apache//apr/apr-1.6.5.tar.bz2 [root@lynk src]# tar -xf apr-1.6.5.tar.bz2 [root@lynk src]# tar -xf apr-util-1.6.1.tar.bz2 [root@lynk apr-1.6.5]# vim configure 注释掉$rm "$cfgfile"这行 [root@lynk apr-1.6.5]# ./configure --prefix=/usr/local/apr [root@lynk apr-1.6.5]# make && make install [root@lynk apr-1.6.5]# cd /usr/src/apr-util-1.6.1 [root@lynk apr-util-1.6.1]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr [root@lynk apr-util-1.6.1]# make && make install #编译安装httpd [root@lynk apr-util-1.6.1]# cd /usr/src/ [root@lynk src]# tar xf httpd-2.4.37.tar.bz2 [root@lynk src]# cd httpd-2.4.37 [root@lynk httpd-2.4.37]# ./configure --prefix=/usr/local/apache \ --sysconfdir=/etc/httpd24 \ --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=most \ --enable-mpms-shared=all \ --with-mpm=prefork [root@lynk httpd-2.4.37]# make && make install #配置apache [root@lynk httpd-2.4.37]# echo 'export path=/usr/local/apache/bin:$path' > /etc/profile.d/httpd.sh [root@lynk httpd-2.4.37]# source /etc/profile.d/httpd.sh [root@lynk httpd-2.4.37]# ln -s /usr/local/apache/include/ /usr/include/httpd [root@lynk httpd-2.4.37]# echo 'manpath /usr/local/apache/man' >> /etc/man.config [root@lynk httpd-2.4.37]# sed -i '/#servername/s/#//g' /etc/httpd24/httpd.conf #启动apache [root@lynk httpd-2.4.37]# apachectl start [root@lynk httpd-2.4.37]# ss -antl state recv-q send-q local address:port peer address:port listen 0 128 *:22 *:* listen 0 100 127.0.0.1:25 *:* listen 0 128 :::80 :::* listen 0 128 :::22 :::* listen 0 100 ::1:25 :::*
安装mysql
#安装依赖 [root@lynk ~]# yum -y install ncurses-devel openssl-devel openssl cmake mariadb-devel #创建mysql用户 [root@lynk ~]# groupadd -r -g 306 mysql [root@lynk ~]# useradd -m -s /sbin/nologin -g 306 -u 306 mysql #安装mysql [root@lynk ~]# cd /usr/src/ [root@lynk src]# wget https://downloads.mysql.com/archives/get/file/mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz [root@lynk src]# tar xf mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz -c /usr/local/ [root@lynk src]# cd /usr/local/ [root@lynk local]# ln -sv mysql-5.7.22-linux-glibc2.12-x86_64/ mysql "mysql" -> "mysql-5.7.23-linux-glibc2.12-x86_64/" #修改/usr/local/mysql的属主属组 [root@lynk local]# chown -r mysql.mysql /usr/local/mysql #添加环境变量 [root@lynk local]# echo 'export path=/usr/local/mysql/bin:$path' > /etc/profile.d/mysql.sh [root@lynk local]# . /etc/profile.d/mysql.sh [root@lynk local]# echo $path /usr/local/mysql/bin:/usr/local/apache/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin #建立数据存放目录 [root@lynk local]# mkdir /opt/data [root@lynk local]# chown -r mysql.mysql /opt/data/ #初始化数据库 [root@lynk local]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/opt/data/ 2019-02-20t07:46:58.303186z 1 [note] a temporary password is generated for root@localhost: 6rb>gj.>gya/ #记录密码:6rb>gj.>gya/ #配置mysql [root@lynk local]# ln -sv /usr/local/mysql/include/ /usr/local/include/mysql "/usr/local/include/mysql" -> "/usr/local/mysql/include/" [root@lynk local]# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf [root@lynk local]# ldconfig -v #生成配置文件 [root@lynk local]# cat > /etc/my.cnf <<eof > [mysqld] > basedir = /usr/local/mysql > datadir = /opt/data > socket = /tmp/mysql.sock > port = 3306 > pid-file = /opt/data/mysql.pid > user = mysql > skip-name-resolve > eof #配置服务启动脚本 [root@lynk local]# cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld [root@lynk local]# sed -ri 's#^(basedir=).*#\1/usr/local/mysql#g' /etc/init.d/mysqld [root@lynk local]# sed -ri 's#^(datadir=).*#\1/opt/data#g' /etc/init.d/mysqld #启动mysql [root@lynk local]# service mysqld start starting mysql.logging to '/opt/data/lynk.err'. success! #修改密码 [root@lynk local]# mysql -uroot -p enter password: mysql> set password = password('lynk123~'); query ok, 0 rows affected, 1 warning (0.23 sec) mysql> quit bye
安装php
#配置yum [root@lynk ~]# yum -y install epel-release [root@lynk ~]# rpm -uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm #安装依赖 [root@lynk ~]# yum -y install libxml2 libxml2-devel openssl openssl-devel [root@lynk local]# bzip2 bzip2-devel libcurl libcurl-devel libicu-devel libjpeg libjpeg-devel libpng libpng-devel openldap-devel libpcre-devel freetype freetype-devel gmp gmp-devel libmcrypt libmcrypt-devel readline readline-devel libxslt libxslt-devel mhash mhash-devel php72w-mysqlnd #安装php [root@lynk ~]# cd /usr/src/ [root@lynk src]# wget http://cn.php.net/distributions/php-7.2.8.tar.xz [root@lynk src]# tar xf php-7.2.8.tar.xz [root@lynk src]# cd php-7.2.8 [root@lynk php-7.2.8]# ./configure --prefix=/usr/local/php7 \ --with-config-file-path=/etc \ --enable-fpm \ --enable-inline-optimization \ --disable-debug \ --disable-rpath \ --enable-shared \ --enable-soap \ --with-openssl \ --enable-bcmath \ --with-iconv \ --with-bz2 \ --enable-calendar \ --with-curl \ --enable-exif \ --enable-ftp \ --with-gd \ --with-jpeg-dir \ --with-png-dir \ --with-zlib-dir \ --with-freetype-dir \ --with-gettext \ --enable-json \ --enable-mbstring \ --enable-pdo \ --with-mysqli=mysqlnd \ --with-pdo-mysql=mysqlnd \ --with-readline \ --enable-shmop \ --enable-simplexml \ --enable-sockets \ --enable-zip \ --enable-mysqlnd-compression-support \ --with-pear \ --enable-pcntl \ --enable-posix [root@lynk php-7.2.8]# make -j $(cat /proc/cpuinfo |grep processor|wc -l) [root@lynk php-7.2.8]# make install #配置php [root@lynk php-7.2.8]# echo 'export path=/usr/local/php7/bin:$path' > /etc/profile.d/php7.sh [root@lynk php-7.2.8]# source /etc/profile.d/php7.sh [root@lynk php-7.2.8]# php -v php 7.2.8 (cli) (built: feb 20 2019 16:45:01) ( nts ) copyright (c) 1997-2018 the php group zend engine v3.2.0, copyright (c) 1998-2018 zend technologies [root@lynk php-7.2.8]# cp php.ini-production /etc/php.ini [root@lynk php-7.2.8]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm [root@lynk php-7.2.8]# chmod +x /etc/rc.d/init.d/php-fpm [root@lynk php-7.2.8]# cp /usr/local/php7/etc/php-fpm.conf.default /usr/local/php7/etc/php-fpm.conf [root@lynk php-7.2.8]# cp /usr/local/php7/etc/php-fpm.d/www.conf.default /usr/local/php7/etc/php-fpm.d/www.conf #编辑php-fpm配置文件 [root@lynk php-7.2.8]# vim /usr/local/php7/etc/php-fpm.conf pm.max_children = 50 //最多同时提供50个进程提供50个并发服务 pm.start_servers = 5 //启动时启动5个进程 pm.min_spare_servers = 2 //最小空闲进程数 pm.max_spare_servers = 8 //最大空闲进程数 #注意删除斜杠及其后面的内容 #启动php-fpm [root@lynk php-7.2.8]# service php-fpm start starting php-fpm done [root@lynk php-7.2.8]# ss -antl state recv-q send-q local address:port peer address:port listen 0 128 *:22 *:* listen 0 100 127.0.0.1:25 *:* listen 0 128 127.0.0.1:9000 *:* listen 0 128 :::80 :::* listen 0 128 :::22 :::* listen 0 100 ::1:25 :::* listen 0 80 :::3306 :::*
配置apache
启用代理模块
在apache httpd 2.4以后已经专门有一个模块针对fastcgi的实现,此模块为mod_proxy_fcgi.so,它其实是作为mod_proxy.so模块的扩展,因此,这两个模块都要加载,编辑httpd.conf文件,取消以下两行内容的注释:
- loadmodule proxy_module modules/mod_proxy.so
- loadmodule proxy_fcgi_module modules/mod_proxy_fcgi.so
#启用httpd的相关模块 [root@lynk ~]# sed -i '/proxy_module/s/#//g' /etc/httpd24/httpd.conf [root@lynk ~]# sed -i '/proxy_fcgi_module/s/#//g' /etc/httpd24/httpd.conf
配置虚拟主机
在需要使用fcgi的虚拟主机中添加类似如下两行:
#关闭正向代理 proxyrequests off proxypassmatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/path/to/document_root/$1
如:
proxypassmatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/var/www/html/idfsoft.com/$1
以上设置表示把以.php结尾的文件请求发送到php-fpm进程,php-fpm至少需要知道运行的目录和uri,所以这里直接在fcgi://127.0.0.1:9000后指明了这两个参数,其它参数的传递已经被mod_proxy_fcgi.so进行了封装,不需要手动指定。
注意:这里写的/var/www/html/是yum源安装方式生成的网页存放目录,这里需要改成你编译安装指定的网页存放路径,请勿直接复制我这里的路径
这里的idfsoft.com是域名,你需要改成你所使用的域名,请勿直接复制此处的域名
这里的$1表示匹配所有以.php结尾的http请求
[root@lynk ~]# mkdir /usr/local/apache/htdocs/the_legend_of_zelda.com [root@lynk ~]# cat > /usr/local/apache/htdocs/the_legend_of_zelda.com/index.php <<eof > <?php > phpinfo(); > ?> > eof [root@lynk ~]# chown -r apache.apache /usr/local/apache/htdocs/ [root@lynk ~]# vim /etc/httpd24/httpd.conf #在末尾添加类似如下内容 <virtualhost *:80> documentroot "/usr/local/apache/htdocs/the_legend_of_zelda.com" servername www.legendofzelda.com proxyrequests off proxypassmatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/usr/local/apache/htdocs/the_legend_of_zelda.com/$1 <directory "/usr/local/apache/htdocs/the_legend_of_zelda.com"> options none allowoverride none require all granted </directory> </virtualhost> #然后搜索/addtype 在 addtype application/x-compress .z addtype application/x-gzip .gz .tgz 后面添加如下内容: addtype application/x-httpd-php .php addtype application/x-httpd-php-source .phps [root@lynk ~]# sed -i '/ directoryindex/s/index.html/index.php index.html/g' /etc/httpd24/httpd.conf #重启apache [root@lynk ~]# apachectl stop [root@lynk ~]# apachectl start [root@lynk ~]# ss -antl state recv-q send-q local address:port peer address:port listen 0 128 *:22 *:* listen 0 100 127.0.0.1:25 *:* listen 0 128 127.0.0.1:9000 *:* listen 0 128 :::80 :::* listen 0 128 :::22 :::* listen 0 100 ::1:25 :::* listen 0 80 :::3306 :::* #关闭防火墙 [root@lynk ~]# systemctl stop firewalld [root@lynk ~]# systemctl disable firewalld removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service. removed symlink /etc/systemd/system/dbus-org.fedoraproject.firewalld1.service.
验证
用ip或域名登录,看到以下界面代表部署成功
下一篇: spark基础知识点介绍