小白爱折腾·其四:Linux部署Lnmp+PHPMyadmin环境

【写在前面】


很久没有更新这一系列的文章了,最近应工作要求部署一套在线学习系统,在官方文档只提到Windows平台部署的情况下,经过漫长乏味的摸索,终于实现在Linux(Debian9)环境下部署。这篇文章是整个部署工作的前置部分,完工后的现在趁着整理笔记的功夫写下这篇文章,以备不时之需。


【系统环境】


Debian9+(Nginx+MariaDB10.1+PHP7.0+PHPMyadmin4.6.6)


括号内是本篇要部署的部分


【通用操作】


在整个部署过程中,涉及Nginx、PHP、MariaDB配置更改的操作,都建议重启一次相关服务:


service nginx restart


service php7.0-fpm restart


service mysql restart


【部署过程】


更新Debian系统(安装源)


apt update


安装Nginx


apt-get -y install nginx


对Nginx进行初步配置(以适配后期PHP应用)


编辑/etc/nginx/sites-available/default文件,如下图:



nginx额外配置(可选)


编辑/etc/nginx/nginx.conf文件


在http项下增加 client_max_body_size 10m;



安装PHP常用模块(Debian9默认提供的一般是7.0版本,这里跟随默认)


apt install php-fpm php-opcache php-cli php-gd php-curl php-mysql


PHP额外配置(可选)


编辑/etc/php/7.0/fpm/php.ini文件


将upload_max_filesize 改为20M



安装MariaDB(普通安装并不会提示设置root密码,但后续装PHPMyadmin时要用)


apt -y install mariadb-server


安全安装(数据库root密码自定,具体选项配置按各自需求)


mysql_secure_installation


安全安装中,除了设定root密码外,其他选项都选N(否),最后一个生效选项选Y(是)


部署到这里,Lnmp环境已经搭建完成,下面就要进行PHPMyadmin的安装与配置。


安装PHPMyadmin


apt install phpmyadmin


这里多说一句,关于PHPMyadmin的安装除了apt方法外,还可以用官网压缩包解压的方法进行。无论哪种方式都要注意版本问题,因为高版本需要PHP7.x以上才能支持,据PHPMyadmin官网说明,PHPMyadmin5.0以前的版本(4.4-4.97)都可以适配PHP7.0,因此这里选择PHP7.0打底加上apt install的安装方式。


初始网络配置选择,Apache和Lighthttp都不选,按Tab跳至OK回车


是否使用dbconfig-common配置应用程序数据库 YES


为PHPMyadmin MySQL用户定义新密码 留空跳至OK回车


将PHPMyadmin链接至Nginx网站根目录(/var/www/html),相当于创建快捷方式


ln -s /usr/share/phpmyadmin /var/www/html


数据库相关配置(命令行状态下,非PHPMyadmin)


进入MariaDB


mysql –uroot -p


更改登录认证方式(密码认证)


use mysql; #使用MySQL数据库


update user set plugin='mysql_native_password' where user='root'; #root用户认证方式更改


flush privileges; #刷新配置


select user, plugin from mysql.user; #查看用户认证方式,下图为修改后状态


exit #退出MariaDB




PHPMyadmin相关配置


编辑/usr/share/phpmyadmin/config.inc.php文件,如下图:



配置完毕后,务必重启Nginx、PHP、MariaDB相关服务,然后访问站点即可访问PHPMyadmin


(域名或IP)/phpmyadmin


界面如下图,可以用root和root密码登录,因为Debian默认系统root用户可以使用数据库,因此初次安装省略了配置数据库root密码的步骤,如果不进行认证方式更改,登录PHPMyadmin时将出现Acess Denied的错误(就算用对了数据库root用户和密码)

以上~

举报
评论 0