LAMP配置与应用

LAMP配置与应用

LAMP简述

LAMP 环境指的是在 Linux 操作系统中分别安装 Apache 网页服务器、MySQL 数据库服务器和 PHP 开发服务器,以及一些对应的扩展软件。AMP也支持win操作系统 (sccm 域升级版)

LAMP架构的组成

  • L:linux
  • A:apache (httpd)
  • M:mysql, mariadb
  • P:php, perl, python

在搭建LAMP时安装顺序一般是linux Apache mysql php 。一般PHP放在最后,负责沟通web服务器和数据库系统以协同工作。

apache

简述

Apache:作为LAMP架构的前端,是一款功能强大,稳定性好的web服务器程序,该服务器直接面向用户提供网站访问,发送网页,图片等内容。

功能

  1. 第一:处理http的请求、构建响应报文等自身服务;
  2. 第二:配置让Apache支持PHP程序的响应(通过PHP模块或FPM);
  3. 第三:配置Apache具体处理php程序的方法,如通过反向代理将php程序交给fcgi处理。

MySQL

简述

作为LAMP架构的后端,是一款流行的开源关系型数据库。在企业网站、业务系统应用中,各种账户信息、产品信息,客户资料、业务数据等都可以存储到mysql数据库,其他程序可以通过sql语句来查询,更改这些信息。

功能

  1. 第一:提供PHP程序对数据的存储;
  2. 第二:提供PHP程序对数据的读取(通常情况下从性能的角度考虑,尽量实现数据库的读写分离)。

PHP

介绍

PHP(Hypertext Preprocessor 超文本预处理器)是通用服务器端脚本编程语言,主要用于web开发实现动态web页面,也是最早实现将脚本嵌入HTML源码文档中的服务器端脚本语言之一

功能

  1. 第一:提供apache的访问接口,即CGI或Fast CGI(FPM);

  2. 第二:提供PHP程序的解释器;

  3. 第三:提供mysql数据库的连接函数的基本环境。

语言

Opcode是一种PHP脚本编译后的中间语言,类似于Java的ByteCode,或者.NET的MSL

执行代码的步骤

1、Scanning 词法分析,将PHP代码转换为语言片段(Tokens) 2、Parsing 语义分析,将Tokens转换成简单而有意义的表达式 3、Compilation 将表达式编译成Opcode 4、Execution 顺次执行Opcode,每次一条,从而实现PHP脚本的功能

即:扫描-->分析-->编译-->执行

配置文件

bash 复制代码
/etc/php.ini
/etc/php.d/*.ini
文件注释符
以#开头,纯粹的注释信息
以 ; 开头,用于注释可启用的directive
较新的版本中,已经完全使用 " ; " 进行注释

文件常见配置

bash 复制代码
expose_php = On   #响应报文显示首部字段x-powered-by: PHP/x.y.z,暴露php版本,建议为off 
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();?>

LAMP应用过程

需要编译安装Apache http服务和MySQL

准备编译安装的压缩包

1、关闭防火墙,准备好压缩包

bash 复制代码
[root@localhost opt]systemctl stop firewalld.service 
[root@localhost opt]setenforce 0

2、安装环境依赖包

bash 复制代码
[root@localhost opt]yum -y install gcc gcc-c++ make pcre-devel expat-devel perl pcre

gcc \                #c语言编译器
gcc-c++ \            #c编译器
make \               #源代码编译器
pcre\                #pcre函数库
pcre-devel \         #pcre接口开发包
expat-devel \        #用于支持网站解析HTML、XML文件
perl                 #perl 语言编译器

3、编译安装httpd

bash 复制代码
[root@localhost opt]cd /opt/  #切换目录
[root@localhost opt]tar xf apr-1.6.2.tar.gz
[root@localhost opt]tar xf apr-util-1.6.0.tar.gz
[root@localhost opt]tar xf httpd-2.4.29.tar.bz2  #解压这三个压缩包
[root@localhost opt]mv apr-1.6.2 httpd-2.4.29/srclib/apr 
[root@localhost opt]mv apr-util-1.6.0 httpd-2.4.29/srclib/apr-util#移动apr包 apr-util包到安装目录中

[root@localhost opt]cd httpd-2.4.29 #切换到此目录下
[root@localhost httpd-2.4.29]./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi#检测安装依赖环境
[root@localhost httpd-2.4.29]make -j2 && make install#编译并安装

--prefix=/usr/local/httpd \  #指定httpd的安装目录
--enable-so \                #启用动态加载模块支持,使httpd具备进一步扩展功能的能力
--enable-rewrite \           #启用网页地址的重写功能,用于网站优化、防盗链及目录迁移维护   
--enable-charset-lite \      #启用字符集支持,以便支持使用各种字符集编码的页面
--enable-cgi      			 #启用CGI(通用网关接口)脚本程序支持,便于网站外部扩展应用访问的能力

建立软连接,可以方便操作,可以补全
[root@localhost httpd-2.4.29]cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
#将文件拷入/etc/init.d/httpd
[root@localhost httpd-2.4.29]ln -s /usr/local/httpd/conf/httpd.conf /etc/
#建立配置文件软连接放入etc目录下
[root@localhost httpd-2.4.29]ln -s /usr/local/httpd/bin/* /usr/local/bin/
#将启动文件放入/usr/local/bin/目录下可以直接使用

4、添加httpd系统服务

bash 复制代码
[root@localhost httpd-2.4.29]vim /lib/systemd/system/httpd.service #创建 httpd.service文件
将下边文件复制进去
[Unit]
Description=The Apache HTTP Server    
After=network.target 
[Service]
Type=forking
PIDFile=/usr/local/httpd/logs/httpd.pid
ExecStart=/usr/local/bin/apachectl $OPTIONS
ExecReload=/bin/kill -HUP ${MAINPID}
[Install]
WantedBy=multi-user.target

[root@localhost httpd-2.4.29]systemctl start httpd.service #开启httpd服务
[root@localhost httpd-2.4.29]systemctl daemon-reload #重新加载
[root@localhost httpd-2.4.29]netstat -ntap |grep 80 #查看httpd端口是否开启

5、编译安装MySQL

bash 复制代码
[root@localhost ~]yum install -y ncurses-devel autoconf cmake #安装依赖包
yum -y install \  
ncurses \              #字符终端下图形互动功能的动态库
ncurses-devel \        #ncurses开发包
bison \                #语法分析器
cmake                  #mysql需要用到的cmake编译安装包

[root@localhost ~]useradd -s /sbin/nologin  mysql#创建一个MySQL用户不允许登录
[root@localhost ~]cd /opt
[root@localhost opt]tar xf mysql-boost-5.7.20.tar.gz #解压压缩包
[root@localhost opt]cd /opt/mysql-5.7.20/#切换目录
[root@localhost mysql-5.7.20]cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #指定将 mysql 数据库程序安装到某目录下
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ #指定套接字文件的存储路径,数据库连接的文件
-DSYSCONFDIR=/etc \ #指定初始化参数文件目录
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8  \ #指定默认使用的字符集编码,如 utf8。
-DDEFAULT_COLLATION=utf8_general_ci \ #指定默认使用的字符集校对规则,
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安装INNOBASE存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \  #安装ARCHIVE存储引擎 
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ #安装BLACKHOLE存储引擎
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ #安装FEDERATED存储引擎 
-DMYSQL_DATADIR=/usr/local/mysql/data \  #数据安装路径 
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1

[root@localhost mysql-5.7.20]make -j2 && make install#编译安装
[root@localhost mysql-5.7.20]chown -R mysql:mysql /usr/local/mysql/#修改数据库目录权限
编辑配置文件
vi /etc/my.cnf

[client]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysql]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

[root@localhost mysql-5.7.20]chown mysql:mysql /etc/my.cnf#修改文件权限
#设置环境变量
[root@localhost mysql-5.7.20]echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
[root@localhost mysql-5.7.20]echo 'export PATH' >> /etc/profile
[root@localhost mysql-5.7.20]source /etc/profile

[root@localhost mysql-5.7.20]cd /usr/local/mysql/
#初始化数据库
[root@localhost mysql]bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data

[root@localhost mysql]cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
[root@localhost mysql]systemctl start mysqld #开启MySQL服务
[root@localhost mysql]systemctl status mysqld#查看服务状态
[root@localhost mysql]netstat -anpt | grep 3306 #查看MySQL服务端口号是否开启
[root@localhost mysql]mysqladmin -u root -p password "abc123"  #设置root用户的登录密码
出现下图,直接回车,初始密码是空白的
[root@localhost mysql]mysql -u root -pabc123 #输入root用户和和密码登录数据库
#quit和Ctrl+D可以退出数据库

6、编译安装PHP

bash 复制代码
#安装GD库和GD库关联程序,用来处理和生成图片
[root@localhost opt]#
yum -y install \
gd \
libjpeg libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel
[root@localhost opt]tar jxvf php-7.1.10.tar.bz2#解压
[root@localhost opt]cd /opt/php-7.1.10/#切换目录
[root@localhost php-7.1.10] ./configure \
--prefix=/usr/local/php7 \							#指定将 PHP 程序的安装路径
--with-apxs2=/usr/local/httpd/bin/apxs \			#指定Apache httpd服务提供的apxs 模块支持程序的文件位置
--with-mysql-sock=/usr/local/mysql/mysql.sock \		#指定mysql 数据库连接文件的存储路径
--with-config-file-path=/usr/local/php7				#设置 PHP 的配置文件 php.ini 将要存放的位置
--with-mysqli \										#添加 MySQL 扩展支持 mysqli扩展技术不仅可以调用MySQL的存储过程、处理MySQL事务,而且还可以使访问数据库工作变得更加稳定
--with-zlib \										#支持zlib功能,提供数据压缩
--with-curl \										#开启curl扩展功能,实现HTTP的Get下载和Post请求的方法
--with-gd \											#激活gd 库的支持
--with-jpeg-dir \									#激活jpeg 的支持
--with-png-dir \									#激活png 的支持
--with-freetype-dir \
--with-openssl \
--enable-mbstring \									#启用多字节字符串功能,以便支持中文等代码
--enable-xml \										#开启扩展性标记语言模块
--enable-session \									#会话
--enable-ftp \										#文本传输协议
--enable-pdo \										#函数库
--enable-tokenizer \								#令牌解释器
--enable-zip										#zip压缩格式

[root@localhost php-7.1.10] make -j2 && make install #编译安装
[root@localhost php-7.1.10]cp /opt/php-7.1.10/php.ini-development /usr/local/php7/php.ini#复制模版文件作为PHP 的主配置文件,并进行修改
#编辑文件
vim /usr/local/php7/php.ini
mysqli.default_socket = /usr/local/mysql/mysql.sock   #1170行 1170 G,直接跳转
date.timezone = Asia/Shanghai #939行

#优化把PHP 的可执行程序文件放入路径环境变量的目录中便于系统识别
ln -s /usr/local/php7/bin/* /usr/local/bin/
php -m 			  #查看PHP 加载了哪些模块

#修改httpd 服务的配置文件,让apache支持PHP
[root@localhost php-7.1.10]vim /etc/httpd.conf 
AddType application/x-httpd-php .php       #393行,插入两行,原文不删
AddType application/x-httpd-php-source .phps   ##这里的点前面空格一定要加,否报错
DirectoryIndex index.html index.php    #255行 修改首页文件名设置
LoadModule php7_module        modules/libphp7.so  #156行 检查支持php7的模块是否存在(可以用'/'在文件中查找 )

#验证PHP 测试页
[root@localhost php-7.1.10]rm -rf /usr/local/httpd/htdocs/index.html
[root@localhost php-7.1.10]vim /usr/local/httpd/htdocs/index.php
<?php
phpinfo();
?>
[root@localhost php-7.1.10]systemctl restart httpd.service
在浏览器输入本机地址出现以下网页

建立论坛

bash 复制代码
mysql -u root -pabc123 #进入数据库
mysql> CREATE DATABASE bbs;  #创建一个数据库
mysql> GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';   #把bbs数据库里面所有表的权限授予给bbsuser,并设置密码
mysql>flush privileges; #刷新数据库

unzip /opt/Discuz_X3.4_SC_UTF8.zip -d /opt/dis#解压论坛压缩包
cd /opt/dis
cd dir_SC_UTF8 
cp -r upload/ /usr/local/httpd/htdocs/bbs #将压缩包中内容复制到数据库中
cd /usr/local/httpd/htdocs/bbs
#修改文件的属主
chown -R daemon ./config
chown -R daemon ./data
chown -R daemon ./uc_client
chown -R daemon ./uc_server/data

在浏览器输入192.168.65.102/bbs/install,出现下边网页,然后下一步
相关推荐
sumatch5 小时前
RPC是什么?和HTTP区别?
网络协议·http·rpc
雨中rain1 天前
Linux -- HTTP 请求 与 响应 报文
网络·网络协议·http
浅念同学1 天前
网络编程-网络原理HTTP上
网络·网络协议·http
zhu09021501022 天前
minio https配置
网络协议·http·https
鹅肝手握高V五色2 天前
免费代理抓包工具SniffMaster(嗅探大师)抓取https
网络协议·http·https
Zfox_2 天前
应用层协议 HTTP 讲解&实战:从0实现HTTP 服务器
linux·服务器·网络·c++·网络协议·http
前端没钱2 天前
flutter入门系列教程<2>:Http请求库-dio的使用
网络协议·flutter·http
幽兰的天空3 天前
介绍 HTTP 请求如何实现跨域
网络·网络协议·http
lisenustc3 天前
HTTP post请求工具类
网络·网络协议·http
心平气和️3 天前
HTTP 配置与应用(不同网段)
网络·网络协议·计算机网络·http