本文介绍: 1.1httphtmlHTTP:为解决“用什么样的网络协议实现整个因特网上的万维网文档”这一难题,就要使万维网客户程序(以浏览器为主,但不限于浏览器)与万维网服务器程序之间交互遵守严格协议,即超文本传送协议(HyperText Transfer Protocol)。HTTP是处于应用层的协议,使用TCP传输层协议进行可靠的传送。

第一章HTTP

1.1httphtml

1.2浏览器访问网站过程

1.3HTTP工作机制

1.4版本

1.5HTTP方法

1.6.http状态

1.7请求报文

1.8 响应报文

第二章Apache简单介绍

1.Apache基础知识

2.Apache配置文件位置

三.LAMP架构

1.LAMP平台概述

2.LAMP各组件主要作用

3.构建LAMP平台顺序

四.Apache三种工作模式

1. prefork模式(默认模式)

2. worker模式

3. event模式

五.LAMP架构搭建论坛实验

实验准备:将所需软件安装包下载到/opt目录下、关闭防火墙配置本地yum仓库(此处已安装不再演示


第一章HTTP

1.1httphtml

HTTP:为解决“用什么样的网络协议实现整个因特网上的万维网文档”这一难题,就要使万维网客户程序(以浏览器为主,但不限于浏览器)与万维网服务器程序之间的交互遵守严格的协议,即超文本传送协议(HyperText Transfer Protocol)。HTTP是处于应用层的协议,使用TCP传输层协议进行可靠的传送。因此,需要特别提醒的是,万维网是基于因特网的一种广泛因特网应用系统,且万维网采用的是HTTP(80/TCP)和 HTTPS(443/TCP)的传输协议,但因特网还有其他的网络应用系统(如:FTP、SMTP等等)。

HTML:为了解决怎样使不同作者创作不同风格的万维网文档,都能在因特网上的各种主机显示出来,同时使用户清楚地知道什么地方存在链接”这一问题,万维网使用超文本标记语言(HyperText Markup Language),使得万维网页面设计可以很方便地用链接从页面的某处链接到因特网的任何一个万维网页面,并且能够自己的主机品目上将这些页面显示出来。HTML与txt一样,仅仅是是一种文档,不同之处在于,这种文档专供于浏览器上为浏览器用户提供统一界面呈现统一规约。且具备结构化特征,这是txt所不具备的强制规定

1.2浏览器访问网站过程

一次完整http请求处理过程

 1.建立连接

2.接收请求接收客户端请求报文中对某项资源的一次请求的过程

3.处理请求,解析,得到处理方法

4.访问资源

5.构建响应报文(响应实体url重定向mime类型

6.发送响应报文

7.记录日志

1.3HTTP工作机制

Web资源web resource一个网页多个资源文件)构成,打开一个页面,通常会有多个资源展示出来,但是每个资源都要单独请求。因此,一个“Web 页面”通常并不是单个资源,而是一组资源的集合

资源类型

静态文件:无需服务端做出额外处理,服务器端客户端文件内容相同

文件后缀:.html, .txt, .jpg, .js, .css, .mp3, .avi

动态文件服务端执行程序返回执行结果,服务器端客户端文件内容不相同

文件后缀:.php, .jsp ,.asp

提高HTTP连接性

1.4版本

0.9/http     只能下载

1.0/http      只能一个请求(没有长连接,下载慢)

1.1/http       一次请求,多次下载(不断开,长连接)

1.5HTTP方法

HTTP 支持几种不同的请求命令,这些命令称为 HTTP 方法(HTTP method)。

每条 HTTP 请求报文都包含一个方法, 告诉服务器执行什么动作,包括:获取一个页面运行一个网关程序删除一个文件等。

最常用的获取资源的方法是 GET、POST、PUT。

HTTP      方法    描述
GET         对服务器资源获取的简单请求
PUT          向服务器提交数据,以修改数据
DELETE    删除服务器上的某些资源
POST      用于发送包含用户提交数据的请求
HEAD      请求页面首部,获取资源的元信息
GET        请求会向数据库发索取数据的请求,从而来获取信息,该请求不会产生副作用。无论进行多少操作结果都是一样的。

PUT请求是向服务器端发送数据的,从而改变信息,无论进行多少次PUT操作,其结果没有不同,与GET不同

POST请求同PUT请求类似,都是向服务器端发送数据的,但是该请求会改变数据的种类等资源,几乎目前所有的提交操作都是用POST请求的。

DELETE请求顾名思义,就是用来删除某一个资源的。

GET 和 POST 比较

GET 方法

指定服务器上获得数据
GET请求能被缓存
GET请求会保存浏览器浏览纪录
GET请求有长度限制
主要用于获取数据
查询字符串显示在URL后缀中,不安全
POST 方法

提交数据给指定服务处理
POST请求不能被缓存
POST请求不会保存在浏览器浏览纪录
POST请求没有长度限制
查询字符串不会显示在URL中,比较安全

1.6.http状态

状态码首位 定义范围 分类
1xx 100-101 信息提示
2xx 200-206 成功
3xx 300-305 重定向
4xx 400-415 客户端错误
5xx 500-505 服务器错误
状态 功能描述
200 一切正常
301 永久重定向
302 临时重定向
401 用户名密码错误
403 禁止访问(客户端IP地址拒绝)
404 请求的文件存在
414 请求URI头部过长
500 服务器内部错误
502 无效网关
503 当前服务不可
504 网关请求超时

 1.7请求报文
请求行:请求行由请求方法、URL 以及协议版本部分组成。
请求头:请求头为请求报文添加了一些附加信息,由“名/值”对组成,每行一对,名和值之间使用冒号分隔
空行:请求头部最后会有一个空行,表示请求头部结束接下来为请求体,这一行非常重要,必不可少。
请求体:请求体是请求提交参数,GET 方法已经在 URL 中指明了参数,所以提交没有数据。POST 方法提交参数在请求体中。
常用的请求头:

请求头    描述
Host    接受请求的服务器地址可以是Ip:端口号,也可以域名
User-Agent    发送请求的应用程序名称
Connection    指定与连接相关属性,如Connection:Keep-Alive
Accept-Charset    通知服务端可以发送编码格式
Accept-Encoding    通知服务端可以发送的数据压缩格式
Accept-Language     通知服务端可以发送语言

1.8 响应报文

状态行:状态行由协议版本状态码,状态码描述三部分组成。
响应头:响应头与请求头部类似,为响应报文添加了一些附加信息
空行:响应头部最后会有一个空行,表示响应头部结束
响应体:服务器返回的相应 HTML 数据,浏览器对其解析显示页面
常见响应头:

响应头    描述
Server    服务器应用程序软件名称版本
Content-Type    响应正文的类型(是图片还是二进制字符串
Content-Length     响应正文长度
Content-Charset    响应正文使用编码
Content-Encoding    响应正文使用的数据压缩格式
Content-Language     响应正文使用语言
 

第二章Apache的简单介绍

1.Apache基础知识

Apache(音译为阿帕奇)是世界使用排名第一的Web服务器软件。 它可以运行在几乎所有广泛使用计算机平台上,由于其跨平台安全性被广泛使用,是最流行的Web服务器端软件之一。 快速可靠并且可通过简单的API扩充,将Perl/Python解释器编译到服务器中

Apache HTTP Server 之所以受到众多企业的青睐,得益于其代码开源跨平台功能模块化、可灵活定制等诸多优点,不仅性能稳定,在安全性方面的表现也十分出色。
 

2.Apache配置文件位置

/etc/httpd/conf/httpd.conf 
#主配置文件

/etc/httpd/conf.d/*.conf 
#子配置文件

/etc/httpd/conf.d/conf.modules.d/ 
#模块加载的配置文件

httpd -t 或 apache2 -t 
#检查配置语法

/usr/lib/systemd/system/httpd.service
#服务单元文件

/etc/sysconfig/httpd
#配置文件

systemctl enable|disable httpd.service
systemctl {start|stop|restart|status|reload} httpd.service
apachectl start|stop|restart|configtest
#服务控制启动

/var/www/html
#站点网页文档根目录

/etc/httpd/modules
/usr/lib64/httpd/modules
#模块文件路径

/usr/sbin/httpd
#主服务器程序文件

/etc/httpd/run/httpd.pid 
#主进程文件

/var/log/httpd
access_log:        #访问日志
error_log:        #错误日志
 
#日志文件目录
 

三.LAMP架构

1.LAMP平台概述

LAMP架构是目前成熟的企业网站应用模式之一,指的是协同工作的一整台系统相关软件能够提供动态web站点服务及其应用开发环境

LAMP是一个缩写词,具体包括Linux操作系统,Apache网站服务器,MySQL数据库服务器,PHP(或perl,Python)网页编程语言

2.LAMP各组件主要作用

(平台)Linux:作为LAMP架构的基础,提供用于支撑Web站点操作系统能够与其他三个组件提供更好稳定性,兼容性(AMP组件也支持Windows、UNIX等平台) 。

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

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

(中间连接)PHP/Perl/Python:作为三种开发动态网页的编程语言负责解释动态网页文件,负责沟通Web服务器和数据库系统以协同工作,并提供Web应用程序的开发和运行环境。其中PHP是一种被广泛应用的开放源代码的多用途脚本语言,它可以嵌入到HTML中,尤其适合于Web应用开发。

3.构建LAMP平台顺序

构建LAMP平台时,各组件安装顺序依次为Linux,Apache,MySQL,PHP

其中Apache和MySQL的安装没有严格顺序要求,而PHP环境的安装一般放到最后负责沟通web服务器和数据库系统以协同工作
 

四.Apache的三种工作模式

Apache的三种工作模式分别是:preforkworkerevent

1. prefork模式(默认模式)

profork模式实现了一种非线程、预派生的Web服务器,用的是进程处理请求,所以比较容易消耗内存,但是稳定性好,某个进程出现问题不会影响到其他请求。

2. worker模式

worker模式使用多个进程每个进程多个线程、由于使用的是线程处理请求,消耗内存小,适合高流量的请求,但是如果某个进程出现问题,那么这个进程下的线程都会出现问题,即稳定性不是很好。

3. event模式

event模式为了解决keep-alive保持长连接出现的一种工作模式,使用keep-alive长连接的时候,某个线程会一直被占用,即使中间没有请求,需要等到超时才会被释放,所以这个时候就出现了event的工作模式。
 

五.LAMP架构与搭建论坛实验

实验准备:将所需软件安装包下载到/opt目录下、关闭防火墙、配置本地yum仓库(此处已安装不再演示

 

5.1yum安装

 

5.2编译安装Apache httpd服务

5.2.1 安装环境依赖

yum -y install gcc gcc-c++ make pcre pcredevel expat-devel perl 
 
#################注释####################
yum -y install
gcc                              C语言编译器
gcc-c++                          C++的编译器
make                              源代码编译器源代码转换成二进制文件)
pcre                              pcre是一个Perl函数库,包括perl 兼容正则表达式
pcredevel                     perl的接口开发包
expat-devel                    用于支持网站解析HTML、XML文件
perl                             perl语言编译器

 5.2.2 解压Apache所需软件包

tar zxvf apr-1.6.2.tar.gz
tar zxvf apr-util-1.6.0.tar.gz
tar jxvf httpd-2.4.29.tar.bz2

 5.2.3 将apr-1.6.2 、apr-util-1.6.0移动到 /httpd-2.4.29/srclib/并改名

5.2.4 配置设置安装目录、安装模块

进入/opt/httpd-2.4.29进行如下配置:

 cd /opt/httpd-2.4.29
./configure
prefix=/usr/local/httpd
enableso
–enablerewrite
–enablecharset-lite
–enable-cgi
 
#####################注释#####################
./configure
 
prefix=/usr/local/httpd    #指定 httpd 服务程序的安装路径
–enable-so                  #启用动态加载核心模块支持,使 httpd 具备进一步扩展功能能力
–enable-rewrite             #启用网页地址重写功能用于网站优化防盗链目录迁移维护
–enable-charset-lite        #启动字符集支持,以便支持使用各种字符集编码页面
–enable-cgi                   #启用CGI(通用网关接口脚本程序支持,便于增强网站的外部扩展应用访问能力

5.2.5 编译安装

make -j2 && make install
#使用两核编译

5.2.6 优化配置文件路径

把httpd服务的可执行程序文件放入路径环境变量目录中便于系统识别(做个软链接)

ln -s /usr/local/httpd/bin/* /usr/local/bin/

 将配置文件放入etc目录下方便查找修改

ln -s /usr/local/httpd/conf/httpd.conf /etc/

 5.2.7 启动apache服务(添加httpd系统服务)

方法一:
cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd        #用于service服务管理
chmod +x /etc/init.d/httpd
vi /etc/init.d/httpd
#!/bin/bash                                             #在第一行插入新行,添加此三行内
# chkconfig: 35 85 21                                 #35级别自动运行  第85个启动 第21个关闭
# description: Apache is a World Wide Web server
 
chkconfigadd httpd                                  #将httpd服务加入service管理器
 
systemctl start httpd.service

service httpd start
 
 
方法二:
vim /lib/systemd/system/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=multiuser.target

 

 

5.2.8 修改httpd服务配置文件 

vim /etc/httpd.conf
–52行–修改
Listen 192.198.79.210:80
 
–197行–取消注释,修改
ServerName www.zhuo.com:80
 
–221行–默认首页存放路径
DocumentRoot “/usr/local/httpd/htdocs
 
–255行–默认首页文件名设置
DirectoryIndex index.html
 
httpd -t  或 apachectl -t            #检查配置文件的配置项是否有误
systemctl restart httpd.service     #重启httpd服务

 

 

 5.2.9 验证输入IP地址访问测试

访问的页面为/usr/local/httpd/htdocs/index.html里的内容

由配置文件 /etc/httpd.conf决定

  将IP地址与域名对应起来写入/etc/hosts文件中输入域名也可以访问http

 5.3编译安装mysql

5.3.1 安装环境依赖

yum -y install gcc gcc-c++ ncurses ncursesdevel bison cmake
 
#########################注释####################
yum -y install
gcc
gcc-c++
ncurses                 字符终端下图互动功能的动态库
ncursesdevel             ncurses开发包
bison                     语法分析器
cmake                    mysql需要用cmake编译安装

 5.3.2 解压软件包并将boost文件夹移动到/usr/local目录下改名

cd /opt
tar zxvf mysql-5.7.17.tar.gz
tar zxvf boost_1_59_0.tar.gz
mv boost_1_59_0 /usr/local/boost

5.3.3 进入mysql-5.7.17配置软件模块

cd /opt/mysql-5.7.17/
cmake
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock
-DSYSCONFDIR=/etc
-DSYSTEMD_PID_DIR=/usr/local/mysql
-DDEFAULT_CHARSET=utf8  
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_EXTRA_CHARSETS=all
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
-DMYSQL_DATADIR=/usr/local/mysql/data
-DWITH_BOOST=/usr/local/boost
-DWITH_SYSTEMD=1
 
############################注释##############################
cmake
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql         指定mysql的安装路径
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock 指定mysql进程监听接字文件(数据库连接文件)的存储路径
-DSYSCONFDIR=/etc                             指定配置文件的存储路径
-DSYSTEMD_PID_DIR=/usr/local/mysql            指定进程文件的存储路径
-DDEFAULT_CHARSET=utf8                         指定默认使用的字符集编码,如 utf8
-DDEFAULT_COLLATION=utf8_general_ci             指定默认使用的字符集校对规则
-DWITH_EXTRA_CHARSETS=all                         指定支持其他字符集编码
-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=/usr/local/boost           指定boost的路径,若使用mysql-boost集成包安装则-DWITH_BOOST=boost
-DWITH_SYSTEMD=1            

注意:如果在CMAKE的过程中有报错,当报错解决后,需要源码目录中的CMakeCache.txt文件删除,然后再重新CMAKE,否则错误依旧

5.3.4 编译安装

make -j2 && make install

5.3.5 创建mysql用户

useradd -M -s /sbin/nologin  mysql

5.3.6 修改mysql配置文件

vim /etc/my.cnf            #清空文件内容删除原配置项,再重新添加下面内容
 
[client]
port = 3306
socket=/usr/local/mysql/mysql.sock
 
[mysqld]
user = mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
port = 3306
character-setserver=utf8
pidfile = /usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock
bindaddress = 0.0.0.0
skipnameresolve
max_connections=2048
defaultstorageengine=INNODB
max_allowed_packet=16M
serverid = 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
 
 
##########################注释####################################
[client]                                    #客户端设置
port = 3306
socket = /usr/local/mysql/mysql.sock            
 
[mysql]                                        #服务端设置
port = 3306
socket = /usr/local/mysql/mysql.sock
autorehash                                    #开启自动补全功能
 
[mysqld]                                    #服务全局设置
user = mysql                                   #设置管理用户
basedir=/usr/local/mysql                    #指定数据库的安装目录
datadir=/usr/local/mysql/data                #指定数据库文件的存储路径
port = 3306                                    #指定端口
character-set-server=utf8                    #设置服务器字符集编码格式为utf8
pidfile = /usr/local/mysql/mysqld.pid        #指定pid 进程文件路径
socket=/usr/local/mysql/mysql.sock            #指定数据库连接文件
bindaddress = 0.0.0.0                        #设置监听地址,0.0.0.0代表允许所有,如允许多个IP需空格隔开
skipnameresolve                            #禁用DNS解析
max_connections=2048                        #设置mysql的最大连接数
default-storage-engine=INNODB                #指定默认存储引擎
max_allowed_packet=16M                        #设置数据库接收数据包大小最大值
serverid = 1                                #指定服务ID号
 
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

sql_mode常用值如下:

NO_ENGINE_SUBSTITUTION:如果需要的存储引擎禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
STRICT_TRANS_TABLES:在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_AUTO_CREATE_USER:禁止GRANT创建密码为空的用户
NO_AUTO_VALUE_ON_ZERO:mysql中的自增长列可以从0开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错
NO_ZERO_IN_DATE:不允许日期月份为零
NO_ZERO_DATE:mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
ERROR_FOR_DIVISION_BY_ZERO:在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MySQL返回NULL
PIPES_AS_CONCAT:将”||”视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
ANSI_QUOTES:启用ANSI_QUOTES后,不能用双引号引用字符串,因为它被解释识别

5.3.7 更改mysql安装目录和配置文件的属主属组

chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf

5.3.8 设置路径环境变量 

echoexport PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH’ >> /etc/profile    
source /etc/profile

 5.3.9 初始化数据库

cd /usr/local/mysql/bin/            #进入mysql配置文件
 
./mysqld
initialize-insecure
user=mysql
basedir=/usr/local/mysql
–datadir=/usr/local/mysql/data
 
 
##########################注释###############################
./mysqld
initialize-insecure                  生成初始化密码为空
user=mysql                       指定管理用户
basedir=/usr/local/mysql         指定数据库的安装目录
–datadir=/usr/local/mysql/data         指定数据库文件的存储路径

 5.3.10 添加mysqld系统服务

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/        #用于systemctl服务管理
systemctl daemonreload         #刷新识别     
systemctl start mysqld.service  #开启服务
systemctl enable mysqld         #开机自启动
ss -ntap | grep 3306       #查看端口

 5.3.11 修改mysqld的登录密码

mysqladmin -u root -p password “123123”     
#给root账号设置密码为123123,提示输入的是原始密码(为空)   不输入直接回车

5.3.12 授权远程登录

mysql -u root -p
grant all privileges on *.* to ‘root‘@’%’ identified by ‘123123’;
#授予root用户可以在所有终端远程登录,使用的密码是abc123,并对所有数据库和所有表有操作权限

 六. 编译安装php

6.1解压需要软件包移至opt目录下

cd /opt
tar jxvf php-7.1.10.tar.bz2

6.2 安装GD库和GD库关联程序用来处理和生成图片

yum -y install
gd
libjpeg libjpeg-devel
libpng libpngdevel
freetype freetypedevel
libxml2 libxml2-devel
zlib zlibdevel
curl curldevel
openssl openssldevel

6.3 配置软件模块

cd /opt/php-7.1.10/
./configure
prefix=/usr/local/php7
with-apxs2=/usr/local/httpd/bin/apxs
with-mysql-sock=/usr/local/mysql/mysql.sock
–with-configfile-path=/usr/local/php7
–with-mysqli
–with-zlib
–with-curl
–with-gd
–with-jpeg-dir
–with-pngdir
–with-freetypedir
–with-openssl
–enable-mbstring
–enable-xml
–enable-session
–enable-ftp
–enable-pdo
–enable-tokenizer
–enable-zip
 
 
#################################注释##################################
./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        

6.4 编译安装

make -j2 && make install

6.5 复制模版文件作为PHP 的主配置文件,并进行修改

cp /opt/php-7.1.10/php.inidevelopment /usr/local/php7/php.ini    
#改名为php.ini
#在测试环境时使用php.inidevelopment文件,而在生产环境时使用php.iniproduction文件
 
vim /usr/local/php7/php.ini
 
–1170行–修改
mysqli.default_socket = /usr/local/mysql/mysql.sock
–939行–取消注释,修改
date.timezone = Asia/Shanghai

6.6 优化把PHP的可执行程序文件放入路径环境变量的目录中便于系统识别

ln -s /usr/local/php7/bin/* /usr/local/bin/   #软链接
 
php -m             #查看PHP 加载哪些模块

6.7 修改httpd服务的配置文件,让apache支持PHP

vim /etc/httpd.conf
 
–393行–插入以下内容
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
 
–256行–修改首页文件名设置
DirectoryIndex index.html index.php
 
检查支持php7的模块是否存在——
LoadModule php7_module        modules/libphp7.so
 
 
systemctl restart httpd.servic
#重启httpd服务

6.8 验证PHP测试

cd /usr/local/httpd/htdocs/
rm -rf index.html
vim /usr/local/httpd/htdocs/index.php
cat index.php (以下为内容
 
<?php
phpinfo();
?>
 
 
systemctl restart httpd.service  #重启httpd服务

 进入火狐浏览验证

7.搭建一个论坛

7.1 登录数据库

mysql -uroot -p123123     #登录数据库
show databases;           #查看当前数据库

7.2 创建数据库

create database bbs;     
#新建数据库

4.3 授权并设置密码

GRANT all ON bbs.* TO ‘bbsuser’@’%’ IDENTIFIED BY ‘admin123′;
#把bbs数据库里面所有表的权限授予给bbsuser,并设置密码admin123

 7.4 刷新数据库

flush privileges;
quit

 7.5 解压论坛压缩包更改属主

unzip /opt/Discuz_X3.4_SC_UTF8.zip -d /opt/dis
cd /opt/dis/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
#更改论坛目录的属主

7.6 浏览器访问验证

论坛页面访问:http://192.168.100.254/bbs
数据库服务器:localhost     ###本地架设就用localhost如何不是在在本机上就要填写IP地址和端口号
数据库名字:bbs
数据库用户名:bbsuser
数据库密码:admin123
管理员账号:admin
管理员密码:admin123
论坛后台管理员页面:
http://192.168.100.254/bbs/admin.php

论坛页面访问输入:http://192.168.79.210/bbs

 点击同意后,进入一步检查无误后点击下一步

 

 

设置完密码后点击下一步,数据库服务器:localhost 

点击访问即可进入论坛

 

  论坛安装成功

 输入http://192.168.100.254/bbs/admin.php即可进入管理后台管理页面

 

原文地址:https://blog.csdn.net/tgzh123/article/details/129801881

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_36430.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注