【运维工程师学习六】LAM部署搭建个人Discuz论坛

【运维工程师学习六】LAM部署搭建个人Discuz论坛

1、先卸载Mariadb再安装Mysql

powershell 复制代码
systemctl stop mariadb
yum remove mariadb

2、MySQL官网rpm包下载

https://dev.mysql.com/downloads/repo/yum/

powershell 复制代码
wget https://dev.mysql.com/get/你要下载的rpm包
powershell 复制代码
wget https://dev.mysql.com/get/mysql80-community-release-el8-5.noarch.rpm
  • 找到下载位置
powershell 复制代码
ls /etc/yum.repos.d
  • 不在上面位置的话就在刚刚下载的路径下
powershell 复制代码
ls 

3、在rpm包路径下安装 YUM Repo 文件

powershell 复制代码
yum localinstall mysql80-community-release-el8-5.noarch.rpm

4、更新软件仓库本地数据库信息

powershell 复制代码
yum makecache
powershell 复制代码
yum list | grep mysql
powershell 复制代码
mysql_upgrade -u root --p
  • 更新数据库(密码为你之前的MariaDB的root密码)。至此DB安装完成。

5、开始部署------php的安装

默认安装的apache不支持php。

系统自带软件仓库中同样有php二进制包,但软件仓库中的关于php的二进制包按功能组件单独编译,即php主程序被编译成一个包,其它组件如gd库、mysql库、xml库等等都被单独编译,如果网站代码中需要用到这些库则都需要安装,一般代码的说明文档会说明需要哪些库支持的。看了Discuz的readme文件,除对数据库有说明,其它的均没有说明,则本次只安装两个。使用如下安装命令:

powershell 复制代码
yum install -y php php-mysql
  • 报错Error: Unable to find a match: php-mysql
    原因新版的名字发生了改变,为避免下次还发生改变,使用下次命令查清名字后再安装

6、搜索yum包

powershell 复制代码
yum search php-mysql
  • 修改名字后开始安装
powershell 复制代码
yum install -y php php-mysqlnd

7、开始部署------配置apache以支持php

(1)配置使apache能执行php脚本

安装了php及相关组件(库),需要在apache中作相关配置才能使apache能执行php脚本(代码)。配置如下:

编辑httpd.conf(yum安装的apache配置文件路径为/etc/httpd/conf/httpd.conf)文件

1、查找AddType text/html .shtml,在其它下方添加AddType application/x-httpd-php .php

2、查找DirectoryIndex index.html,将其修改为DirectoryIndex index.html index.php


(2)修改配置后重启apache使配置生效。

powershell 复制代码
systemctl restart httpd

8、开始部署------配置apache以支持php

配置完成apache后,需要检验apache是否正常支持php。检验方法是在网站根目录中添加一个php文件,文件名随意,如phptest.php,文件内容如下:

powershell 复制代码
<?php
phpinfo();
?>

这是最简单的php代码,因为其只有一个函数phpinfo()。由于这个文件的作用是探测服务器是否支持PHP,因此这个文件又叫探针。但这是最简单的探针文件,网络上有不少功能强大的php探针脚本,可搜索下载来看看。

我这边把phptest.php设置为了默认启动页可以直接通过ip访问,当然通过路径去访问也行

9、journalctl排错

配置过程中如果出现报错启动不了,可以通过journalctl -xe排查错误,具体操作可以参考下例:

powershell 复制代码
journalctl -xe
  • 去到指定文件把311行内容删除

10、开始部署------创建数据库

powershell 复制代码
create database discuz;
show databases;

11、为discuz创建独立账户

powershell 复制代码
CREATE USER 'dztest'@'localhost'IDENTIFIED BY '123456';
GRANT ALL PRIVILEGES ON discuz.* TO 'dztest'@'localhost';
  • 上传网站代码至apache指定DocumentRoot目录

这里使用Xftp进行上传,上传成功后,请确保网站根目录下所有文件的所有者为apache运行用户。使用yum安装的apache运行用户名为gee(这里改为你的用户名),因此上传代码文件后,我执行了权限修改命令,确保网站所有文件的所有者均为gee。命令如下:

powershell 复制代码
chown -R apache:gee /var/www/html

12、网站安装程序

powershell 复制代码
你的ip/upload/install/index.php


(1)依赖补充

  • 通过yum搜索缺少的依赖全称,这里以缺少json依赖为例(具体缺啥就搜啥):
powershell 复制代码
yum search php-json  #search啥看你缺少啥,他会提示的,我这里缺少的是json
yum install php-json


  • 数据库创建为前面创建的discuz,当然你用他默认的也行只要你后期维护知道是Discuz的论坛数据库就行




  • 到此就安装完毕啦,下面展示Discuz的用户管理中心、主页、管理后台



相关推荐
StickToForever1 小时前
第4章 信息系统架构(五)
经验分享·笔记·学习·职场和发展
勤奋的凯尔森同学2 小时前
webmin配置终端显示样式,模仿UbuntuDesktop终端
linux·运维·服务器·ubuntu·webmin
月光水岸New3 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
我爱松子鱼3 小时前
mysql之规则优化器RBO
数据库·mysql
人间打气筒(Ada)5 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231115 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql
和道一文字yyds5 小时前
MySQL 中的索引数量是否越多越好?为什么?如何使用 MySQL 的 EXPLAIN 语句进行查询分析?MySQL 中如何进行 SQL 调优?
数据库·sql·mysql
Moonnnn.6 小时前
51单片机学习——动态数码管显示
笔记·嵌入式硬件·学习·51单片机
南宫生6 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
技术小齐6 小时前
网络运维学习笔记 016网工初级(HCIA-Datacom与CCNA-EI)PPP点对点协议和PPPoE以太网上的点对点协议(此处只讲华为)
运维·网络·学习