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服务器程序,该服务器直接面向用户提供网站访问,发送网页,图片等内容。
功能
- 第一:处理http的请求、构建响应报文等自身服务;
- 第二:配置让Apache支持PHP程序的响应(通过PHP模块或FPM);
- 第三:配置Apache具体处理php程序的方法,如通过反向代理将php程序交给fcgi处理。
MySQL
简述
作为LAMP架构的后端,是一款流行的开源关系型数据库。在企业网站、业务系统应用中,各种账户信息、产品信息,客户资料、业务数据等都可以存储到mysql数据库,其他程序可以通过sql语句来查询,更改这些信息。
功能
- 第一:提供PHP程序对数据的存储;
- 第二:提供PHP程序对数据的读取(通常情况下从性能的角度考虑,尽量实现数据库的读写分离)。
PHP
介绍
PHP(Hypertext Preprocessor 超文本预处理器)是通用服务器端脚本编程语言,主要用于web开发实现动态web页面,也是最早实现将脚本嵌入HTML源码文档中的服务器端脚本语言之一
功能
-
第一:提供apache的访问接口,即CGI或Fast CGI(FPM);
-
第二:提供PHP程序的解释器;
-
第三:提供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,出现下边网页,然后下一步