【运维工程师学习六】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的用户管理中心、主页、管理后台



相关推荐
开挖掘机上班31 分钟前
mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
数据库·mysql
花月C32 分钟前
Mysql-定时删除数据库中的验证码
数据库·后端·mysql·spring
jugt35 分钟前
CentOS 7.9安装Nginx1.24.0时报 checking for LuaJIT 2.x ... not found
linux·运维·centos
21号 12 小时前
9.进程间通信
linux·运维·服务器
阿阳微客5 小时前
Steam 搬砖项目深度拆解:从抵触到真香的转型之路
前端·笔记·学习·游戏
@小红花5 小时前
MySQL数据库从0到1
数据库·mysql·oracle
[听得时光枕水眠]6 小时前
MySQL基础(三)DQL(Data Query Language,数据查询语言)
数据库·mysql·oracle
搬码临时工8 小时前
电脑同时连接内网和外网的方法,附外网连接局域网的操作设置
运维·服务器·网络
藥瓿亭8 小时前
K8S认证|CKS题库+答案| 3. 默认网络策略
运维·ubuntu·docker·云原生·容器·kubernetes·cks
Gaoithe8 小时前
ubuntu 端口复用
linux·运维·ubuntu