非原创 感谢作者
https://web-security.cn/rapberry_pi_4b_install_php7.3_nginx_mysql/
在树莓派4B上搭建Web服务器环境:PHP7.3 + Nginx + Mariadb。数据库Mariadb是MySQL的一个分支,API和命令行兼容MySQL。
安装PHP7.3
目前官方源已经有PHP7.3的版本,不用添加其它下载源就能安装。首先更新软件列表:
安装PHP7.3:
sudo apt install -y -t buster php7.3-fpm php7.3-curl php7.3-gd php7.3-intl php7.3-mbstring php7.3-mysql php7.3-imap php7.3-opcache php7.3-sqlite3 php7.3-xml php7.3-xmlrpc php7.3-zip
|
通过命令php -v
能够看到PHP版本号7.3,说明安装完成:
pi@raspberrypi:~ $ php -v
PHP 7.3.4-2 (cli) (built: Apr 13 2019 19:05:48) ( NTS )
Copyright (c) 1997-2018 The PHP Group
Zend Engine v3.3.4, Copyright (c) 1998-2018 Zend Technologies
with Zend OPcache v7.3.4-2, Copyright (c) 1999-2018, by Zend Technologies
|
查看php.ini配置文件位置:
pi@raspberrypi:~ $ php -i|grep "Loaded Configuration File"
Loaded Configuration File => /etc/php/7.3/cli/php.ini
|
输出显示配置文件在/etc/php/7.3/cli/php.ini
。注意,实际上配置文件有两个,另外一个在/etc/php/7.3/fpm/php.ini
。通过命令行调用php时,会使用第一个配置文件;通过fpm调用php(例如nginx)会使用第二个配置文件。
php-fpm常用管理命令:
开启php-fpm: sudo systemctl start php7.3-fpm
关闭php-fpm: sudo systemctl stop php7.3-fpm
重启php-fpm: sudo systemctl restart php7.3-fpm
编辑php-fpm配置文件: vi /etc/php/7.3/fpm/php-fpm.ini
安装Nginx
安装nginx:
sudo apt-get install nginx
安装完成后,会自动开启nginx。在浏览器输入树莓派的IP地址,可以看到“Welcome to nginx!”。
或者使用命令行:
pi@raspberrypi:~ $ curl 127.0.0.1
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
.....
|
能够输出html说明nginx安装成功。
默认的网站根目录:/var/www/html
nginx配置文件目录:/etc/nginx/
nginx主配置文件位置:/etc/nginx/nginx.conf
nginx常用管理命令:
启动nginx: sudo systemctl start nginx
关闭nginx:sudo systemctl stop nginx
设置nginx开机启动:sudo systemctl enable nginx
配置nginx解析php
编辑配置nginx文件:
sudo vi /etc/nginx/sites-enabled/default
找到index
指令,添加index.php
。修改后:
index index.php index.html index.htm index.nginx-debian.html;
|
找到# pass PHP scripts to FastCGI server
后面的location,删除注释。修改后如下:
location ~ \.php$ {
include snippets/fastcgi-php.conf;
#
# # With php-fpm (or other unix sockets):
fastcgi_pass unix:/run/php/php7.3-fpm.sock;
# # With php-cgi (or other tcp sockets):
#fastcgi_pass 127.0.0.1:9000;
}
|
保存后重启nginx:
sudo systemctl restart nginx
|
在网站根目录创建一个php文件:
sudo vi /var/www/html/index.php
|
写入以下php代码并保存:
在浏览器中输入树莓派的IP地址即可看到phpinfo。
安装Mairadb数据库
使用以下命令安装mariadb:
sudo apt-get install mariadb-server mariadb-client
|
执行数据库初始化安装:
sudo mysql_secure_installation
|
根据提示设置数据库root用户密码、是否允许外网访问等。
尝试登录数据库:
输入上一步设置的密码,发现无法登录,错误提示如下:
ERROR 1698 (28000): Access denied for user ‘root’@’localhost’
原因: 数据库默认使用系统用户登录,需要修改为使用密码登录。
解决方案: sudo mysql -u root
,登入数据库后,依次执行以下SQL:
use mysql #切换到mysql数据库
update user set plugin='mysql_native_password'; #修改plugin字段
flush privileges; #刷新权限
exit; #退出数据库
再次使用mysql -u root -p
即可通过密码登录数据库,无需root权限执行。
mariadb配置文件保存在多个位置:
/etc/mysql/mariadb.cnf
/etc/mysql/mariadb.conf.d/
/etc/mysql/conf.d/
mariadb常用命令:
启动mariadb: sudo systemctl start mariadb
关闭mariadb:systemctl stop mariadb
设置mariadb开机启动:sudo systemctl enable mariadb
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)