Ubuntu LNMPR环境搭建(Ubuntu 20.04 + Nginx1.8 + PHP 7.3 + Mysql8.0 + Redis5.0)

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: Ubuntu LNMPR环境搭建(Ubuntu 20.04 + Nginx1.8 + PHP 7.3 + Mysql8.0 + Redis5.0)
本文环境 Windows10,Ubuntu 20.04,Nginx1.8,PHP 7.3,Mysql8.0,Redis5.0\
不懂的可以评论或联系我邮箱:[email protected]\
著作权归OwenZhang所有。商业转载请联系OwenZhang获得授权,非商业转载请注明出处。

本文是Windows10下的Ubuntu下已实践,放心使用,不懂联系我

image.png

2022 年什么会火?Ubuntu LNMPR环境!

一、Ubuntu 20.04 SSH配置

先用命令查看ubuntu 是否安装ssh-server

ps -e|grep ssh

如果没有显示sshd,说明未安装ssh-server

安装ssh-server

sudo apt-get install openssh-server

启动ssh-server

/etc/init.d/ssh start

image.png

二、安装Nginx

先更新资源列表

sudo apt-get update

下面开始安装

sudo apt-get install nginx

查看nginx版本

nginx -v

输出:

nginx version: nginx/1.18.0 (Ubuntu)

补充说明:

Nginx 网站目录是 /var/www/html\
将项目代码放在这个文件夹下(类似apache/htdocs)\
Nginx 网站配置文件位置是 /etc/nginx/sites-available/default

启动Nginx服务

sudo service nginx start 启动
sudo service nginx status 启动状态
sudo service nginx enable 开机自动启动
sudo service nginx disable 禁止开机自动启动
sudo service nginx stop 停止
sudo service nginx restart 重启

用命令查看状态

sudo lsof -i:80

也可以在虚拟机上的浏览器输入127.0.0.1可以看见Nginx页面\
输入 ifconfig 查看ip 在虚拟机外访问也能看到

image.png

image.png

二、安装PHP7.3 和 PHP扩展

安装命令

sudo apt-add-repository ppa:ondrej/php
sudo apt-get update
sudo apt-get install php7.3 php7.3-fpm

如果提示:

add-apt-repository: command not found

则运行下面命令即可:

sudo apt-get install software-properties-common python-software-properties

查看php版本

php -v

输出:

owenunix@DESKTOP-CC1MK5I:~$ php -v
PHP 7.3.33-1+ubuntu20.04.1+deb.sury.org+1 (cli) (built: Nov 19 2021 06:25:05) ( NTS )
Copyright (c) 1997-2018 The PHP Group
Zend Engine v3.3.33, Copyright (c) 1998-2018 Zend Technologies
    with Zend OPcache v7.3.33-1+ubuntu20.04.1+deb.sury.org+1, Copyright (c) 1999-2018, by Zend Technologies

image.png

三、配置Nginx和PHP-FPM

PHP-FPM 与 Nginx 通信方式有两种:\
一种是基于TCP的 Internet domain socket 方式,\
一种是 UNIX domain socket 方式。\
UNIX domain socket 可以使同一台操作系统上的两个或多个进程进行数据通信。\
UNIX domain socket 的接口和 Internet domain socket 很像,但它不使用网络底层协议来通信。

服务器压力不大的情况下,这两种方式性能差别不大,但在压力比较满的时候,用UNIX domain socket方式,效果确实比较好。

先配置Nginx

cd /etc/nginx/sites-available
sudo cp default default.bak
sudo vim /etc/nginx/sites-available/default

修改文件中的注释和7.4改成7.3和路径,如下图所示

image.png

php7.3-fpm启动失败

注意:
我们安装的是php7.3,但nginx里缺省值是php7.4-fpm.sock.如果它们不一致,则不能解析php页面,nginx 出现502 bad gateway 错误提示,nginx log日志出现错误

sudo cat /var/log/nginx/access.log

192.168.10.85 - - [07/Jan/2022:11:08:24 +0800] "GET /test.php HTTP/1.1" 502 568 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36 Edg/96.0.1054.62"

接着查看PHP-FPM php.ini文件

sudo cat /etc/php/7.3/fpm/pool.d/www.conf

image.png

最后分别启动Nginx和PHP-FPM

sudo /etc/init.d/nginx restart
sudo /etc/init.d/php7.3-fpm start
sudo /etc/init.d/php7.3-fpm restart

测试一下:

进入 /var/www/html 目录下 创建文件test.php

cd /var/www/html
sudo vim test.php

<?php phpinfo(); ?>

保存后退出在浏览器中访问 127.0.0.1/test.php
或者在虚拟机外访问 http://192.168.10.85/test.php (192.168.10.85 为虚拟机ip,输入 ifconfig 查看ip)

image.png

image.png

四、安装MySQL8.0

命令

sudo apt-get install mysql-server mysql-client

查看Mysql版本

owenunix@DESKTOP-CC1MK5I:/var/www/html$ mysql -V
mysql  Ver 8.0.27-0ubuntu0.20.04.1 for Linux on x86_64 ((Ubuntu))

启动Mysql服务

如果有安装别的版本,需要先停止别的版本服务,再重启该8.0版本服务

sudo service mysql start 启动
sudo service mysql status 启动状态
sudo service mysql enable 开机自动启动
sudo service mysql disable 禁止开机自动启动
sudo service mysql stop 停止
sudo service mysql restart 重启

启动Mysql失败问题解决

owenunix@DESKTOP-CC1MK5I:/var/www/html$ sudo service mysql status
 * MySQL is stopped.
owenunix@DESKTOP-CC1MK5I:/var/www/html$ sudo service mysql restart
 * Stopping MySQL database server mysqld                                                       
 [ OK ]
 * Starting MySQL database server mysqld 
 su: warning: cannot change directory to /nonexistent: No such file or directory
[fail]

su: warning: cannot change directory to /nonexistent: No such file or directory

解决办法如下:

sudo service mysql stop
sudo usermod -d /var/lib/mysql/ mysql
sudo service mysql start
sudo service mysql restart

运行命令来测试mysql是否能成功运行。

mysql -uroot -p您的密码

首次安装密码应该是空的

修改root密码123456

//开启无密码登录skip-grant-tables
sudo service mysql stop
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
skip-grant-tables
sudo service mysql restart

//设置登录密码123456
mysql -uroot -p
use mysql;
flush privileges;
update mysql.user set authentication_string='', plugin='mysql_native_password' where user='root';
alter user 'root'@'localhost' identified by 'root'; 
set password for root@localhost = '123456';
flush privileges;
quit;
sudo service mysql restart

//注释无密码skip-grant-tables
sudo service mysql stop
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
#skip-grant-tables
sudo service mysql restart

修改外网可以连接Mysql

sudo service mysql stop
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
注销掉  #bind-address           = 127.0.0.1
sudo service mysql restart

image.png

查看mysql日志

sudo cat /var/log/mysql/error.log

1130 host is not allowed to connect to this mysql server

五、安装PHPmysql 扩展用来连接数据库

命令

sudo apt-get install php7.3-mysql

写个程序测试一下,在刚才写的test.php后面加上一段数据库连接代码(可以用mysqli或者PDO但是不要用mysql,因为PHP7不支持mysql)

image.png

Mysql的PHP扩展测试

cd /var/www/html
sudo vim test.php


<?php             

echo "Mysql连接测试: \n";
$mysql = new mysqli('127.0.0.1', 'root', '123456');
if ($mysql->connect_error) {
    echo "连接Mysql失败: " . $mysql->connect_error ;
}else{
    echo "连接Mysql成功";
}

?>

image.png

六、安装Redis5.0

命令

sudo apt-get update
sudo apt-get install redis-server

查看Redis版本

owenunix@DESKTOP-CC1MK5I:~$ redis-server -v
Redis server v=5.0.7 sha=00000000:0 malloc=jemalloc-5.2.1 bits=64 build=636cde3b5c7a3923

启动Redis服务器

redis-server 

image.png

启动Redis客户端

Redis 服务器已启动,因此您可以启动 redis 客户端以在它们之间进行通信。

redis-cli

image.png

七、安装PHPredis 扩展用来连接Redis数据库

命令

sudo apt-get install php7.3-redis

查看安装php相关软件包

dpkg -l | grep 'php'

image.png

php.ini添加扩展文件

sudo vim /etc/php/7.3/cli/php.ini

extension=redis.so

image.png

查看php已安装扩展

php -m
php -m | grep redis
redis
root@DESKTOP-CC1MK5I:/home/owenunix#

重启php服务

sudo /etc/init.d/nginx restart
sudo /etc/init.d/php7.3-fpm start
sudo /etc/init.d/php7.3-fpm restart

image.png

Redis的PHP扩展测试

cd /var/www/html
sudo vim test.php


<?php             

echo "Mysql连接测试: \n";
$mysql = new mysqli('127.0.0.1', 'root', '123456');
if ($mysql->connect_error) {
    echo "连接Mysql失败: " . $mysql->connect_error ;
}else{
    echo "连接Mysql成功";
}

echo "-------------------------------\n";

echo "Redis连接测试: \n";
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis->set('owenkey2','owenzhang',60);
echo $redis->get('owenkey1');

echo "-------------------------------\n";
echo $redis->get('owenkey2');

echo "-------------------------------\n";

phpinfo();

?>

image.png

Buy me a cup of coffee :)

觉得对你有帮助,就给我打赏吧,谢谢!

2538d4.jpg

目录
相关文章
|
3月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
307 18
|
3月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
389 17
|
3月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
472 7
|
3月前
|
关系型数据库 MySQL PHP
PHP和Mysql前后端交互效果实现
本文介绍了使用PHP连接MySQL数据库的基本函数及其实现案例。内容涵盖数据库连接、选择数据库、执行查询、获取结果等常用操作,并通过用户登录和修改密码的功能实例,展示了PHP与MySQL的交互过程及代码实现。
332 0
PHP和Mysql前后端交互效果实现
|
7月前
|
Ubuntu 网络协议 应用服务中间件
在 Ubuntu 上安装 Nginx
在 Ubuntu 上安装和配置 Nginx 非常简单。首先更新系统包,然后通过 `apt` 安装 Nginx,检查服务状态并配置防火墙规则。访问服务器 IP 测试是否成功显示默认页面。还可管理服务、创建虚拟主机及排查常见问题,适合新手快速上手部署高性能 Web 服务。
884 0
|
8月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu 22.04上配置和安装MySQL
以上就是在Ubuntu 22.04上配置和安装MySQL的步骤。这个过程可能看起来有点复杂,但只要按照步骤一步步来,你会发现其实并不难。记住,任何时候都不要急于求成,耐心是解决问题的关键。
948 30
|
8月前
|
Ubuntu PHP
Ubuntu下使用apt为Apache2编译PHP7.1
以上就是在Ubuntu系统下,使用apt为Apache2编译PHP7.1的过程。希望这个过程对你有所帮助,如果你在执行过程中遇到任何问题,都可以在网上找到相关的解决方案。
197 25
|
8月前
|
Ubuntu PHP Apache
在Ubuntu系统中为apt的apache2编译PHP 7.1的方法
以上就是在Ubuntu系统中为apt的apache2编译PHP 7.1的方法。希望这个指南能帮助你成功编译PHP 7.1,并在你的Apache服务器上运行PHP应用。
223 28
|
8月前
|
关系型数据库 MySQL Linux
查看Linux、Apache、MySQL、PHP版本的技巧
以上就是查看Linux、Apache、MySQL、PHP版本信息的方法。希望这些信息能帮助你更好地理解和使用你的LAMP技术栈。
429 17
|
8月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu系统的Docker上安装MySQL的方法
以上的步骤就是在Ubuntu系统的Docker上安装MySQL的详细方法,希望对你有所帮助!
947 12