目录
一、安装nginx
因为nginx平台也是基于nginx来搭建的,所以需要事先安装nginx
1、安装nginx依赖环境
yum -y install pcre-devel zlib-devel gcc gcc-c++ make
依赖环境安装完成之后,就可以进行下一步的操作
2、创建一个nginx账户
useradd -M -s /sbin/nologin nginx
3、解压nginx安装包并且进行解析跟编译
这是编译需要用到的三个安装包,有需要的可以自己下载一下
链接:https://pan.baidu.com/s/1ZVfe5n9d7gNCKYM_94Sw-A
提取码:3323
tar zxvf nginx-1.12.0.tar.gz
cd nginx-1.12.0/
#解压并且移动到文件夹内,路径可以自己选择
./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module
#进行解析
make && make install
#编译安装
等待,完成之后,可以做个连接,方便后续使用
ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/
4、添加配置文件
cd /lib/systemd/system #进入目录下
添加一个配置文件
vim nginx.service
将下面数据写进文件内
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/bin/kill -s HUP $MAINPID
ExecStop=/usr/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
注释:
[Unit]
Description=nginx ####描述
After=network.target ####描述服务类别
[Service]
Type=forking ###后台运行形式
PIDFile=/usr/local/nginx/logs/nginx.pid ###PID文件位置
ExecStart=/usr/local/nginx/sbin/nginx ###启动服务
ExecReload=/usr/bin/kill -s HUP $MAINPID ###根据PID重载配置
ExecStop=/usr/bin/kill -s QUIT $MAINPID ###根据PID终止进程
PrivateTmp=true
[Install]
WantedBy=multi-user.target
5、启动nginx
systemctl start nginx.service
二、编译安装mysql
1、安装依赖环境以及创建服务器账号
yum -y install ncurses ncurses-devel bison cmake
useradd -M -s /sbin/nologin mysql
2、解压压缩包并且编译安装
tar zxf mysql-boost-5.7.20.tar.gz
cd mysql-5.7.20/
#解压并移动到文件中
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_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=boost \
-DWITH_SYSTEMD=1
#解析文件
make && make install
#编译安装
注释:
-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_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 \
#指定boost的路径,
-DWITH_SYSTEMD=1
#生成便于systemctl管理的文件
3、修改配置文件
安装成功之后,mysql会在/usr/local/下生成一个文件,需要将文件的属主属组更改一下
chown -R mysql:mysql /usr/local/mysql
进入mysql的配置问价,进行修改数据
vim /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
最后一段的注释:
NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
STRICT_TRANS_TABLES
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_AUTO_CREATE_USER
禁止:GRANT创建密码为空的用户
NO_AUTO_VALUE_ON_ZERO
mysql中的自增长列可以从o开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错
NO_ZERO_IN_DATE
mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
ERROR_FOR_DIVISION_BY_ZERO
在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MysQL返回NULL
IPES_AS_CONCAT
将"||"视为字符串的连接操作符而非或运算符,这和oracle数据库是一样的,
ANSI QUOTES
启用ANSI QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符
将该文件属主属组也修改为mysql账户
chown mysql:mysql /etc/my.cnf
修改环境变量
echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
echo 'export PATH' >> /etc/profile
source /etc/profile
4、初始化mysql
cd /usr/local/mysql/ #移动到目标目录下
对mysql进行初始化
bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
5、添加启动文件
cd usr/lib/systemd/system
移动到该目录下之后,会有一个mysqld.service文件,将其复制一份
cp mysqld.service /lib/systemd/system/
验证是否启动完成
systemctl enable mysqld.service
#为下列字样,为验证通过
Created symlink from /etc/systemd/system/multi-user.target.wants/mysqld.service to /usr/lib/systemd/system/mysqld.service.
启动mysql
systemctl start mysqld.service
启动mysql之后,可以直接使用mysql进行进入数据库,也可以进行添加一个密码
mysqladmin -u root -p password '123123'
Enter password: #会让你输入旧密码,因为刚刚安装成功,是没有密码的,直接下一步即可
进入mysql
mysql -u root -p
确定可以进入之后,输入quit退出即可
三、安装php
1、安装依赖环境
yum -y install \
libjpeg \
libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 \
libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel
解压
tar jxf php-7.1.10.tar.bz2
解析
./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-mysqli \
--with-zlib \
--with-curl \
--with-gd \
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \
--with-openssl \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zip
编译安装
make && make install
2、修改配置文件
编译完成之后,会产生一些文件
需要将如图的这个配置文件进行复制一份
cp php.ini-development /usr/local/php/lib/php.ini
#进行复制以及重命名
进入复制后的文件内
vim /usr/local/php/lib/php.ini
第939行添加内容
date.timezone = Asia/Shanghai #作用是修改时区
#等号后为新加的内容,本行前面带的有一个 ; ,将该符号删掉
在第1170行,后面假如命令
mysqli.default_socket = /usr/local/mysql/mysql.sock
#等号为新加的
好了之后,保存退出
查看已安装验证模块
/usr/local/php/bin/php -m
3、配置优化FPM模块
修改配置文件
移动到配置文件所在的目录中,并将需要修改的文件重命名
cd /usr/local/php/etc/
cp php-fpm.conf.default php-fpm.conf
进入文件内进行更改文件
vim php-fpm.conf
将图中标注的pid一行开启即可
4、开启php
移动到启动文件所在的目录
cd php-fpm.d/
将目录中的文件进行复制以及重命名
cp www.conf.default www.conf
开启服务
/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
查看开启的状况
ss -natp | grep php
配置完之后,可以进行做一个软连接,方便后面使用
ln -s /usr/local/php/bin/* /usr/local/bin/
四、nginx开启php
1、开启php服务
进入配置文件
vi /usr/local/nginx/conf/nginx.conf
在文件内找到这些内容,在第65行,可能根据版本有所不同
将其全部开启之后,修改倒数第二行的配置,位置是文件所在的目录
fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;
检查是否能正常运行
nginx -t
#为下面字段为正常开启
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
2、新建一个站点
先移动到站点目录下
cd /usr/local/nginx/html/
新建一个站点文件
vim index.php
在站点文件内加入一些内容
<?php
phpinfo();
?>
#这边就偷懒随便写一个开头
开启服务
systemctl restart nginx
3、测试
用另一台客户端进行浏览器访问该网址
http://自己的IP地址/index.php
到这里php就搭建成功了
五、搭建BBS论坛
1、进入mysql
mysql -u root -p
添加论坛账号以及密码
CREATE DATABASE bbs;
GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';
GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'admin123';
flush privileges;
注!!!bbsuser是你登录论坛用的账户,admin123是登录用的密码
查看是否创建成功
有这个库名既是创建成功
退出mysql,指定论坛文件存储位置以及字符类型
解压字符格式压缩包
unzip Discuz_X3.4_SC_UTF8.zip
解压之后,进入目录,将该文件复制一份到bbs文件下
cp -r upload/ /usr/local/nginx/html/bbs/
移动到目录下,修改属组权限,以及文件执行权限
/usr/local/nginx/html/bbs/
chown -R root:nginx ./config/
chown -R root:nginx ./data/
chown -R root:nginx ./uc_client/
chown -R root:nginx ./uc_server/
chmod -R 777 ./config/
chmod -R 777 ./data/
chmod -R 777 ./uc_client/
chmod -R 777 ./uc_server/
修改论坛配置文件内容
vi /usr/local/nginx/html/index.php
<?php
$link=mysqli_connect('192.168.75.51','bbsuser','admin123');
if($link) echo "<h1>Success!!</h1>";
else echo "Fail!!";
?>
重启nginx
systemctl restart nginx.service
2、验证
在客户端,时候浏览器进行访问网页
http://自己服务器IP地址/bbs/install/index.php
进入安装向导,点击我同意
然后一直下一步,直到登录页面
进入论坛
进入论坛即可
如果进不去,报错403的话,可以进入配置文件修改网址后缀名即可
vim /usr/local/nginx/conf/nginx.conf
将如图这个更改为php即可进入论坛
安装一次之后,使用下面网址,可以直接登录论坛
http://自己服务器IP地址/bbs/index.php