简介

LEMP是用来搭建动态网站的一组软件,首字母缩写分别表示Linux、Nginx(Engine-X)、MySQL和PHP。

本文将讲述如何在Ubuntu安装LEMP套件。当然,首先要安装Ubuntu18.04操作系统,接着按照以下方法完成其他组建的安装。

1.切换root用户

输入命令:

su root

回车提示输入密码,怎么输入都不对,这是你的root没有设置密码或者你当前就是root

给root用户设置密码:命令:

sudo passwd root

输入密码,并确认密码。

重新输入命令:

su root

然后输入密码:

发现可以切换到root权限了。

使用su xyx命令,切换到普通用户。

2.以下演示将通过非管理员账号进行,即通过sudo命令完成安装

如果是普通账号(非管理员)可继续往下看。 管理员可以去掉sudo直接使用命令

步骤一:安装Nginx网站服务器

$ sudo apt update
$ sudo apt install nginx

在Ubuntu上,使用以上两条命令完成nginx安装就可以通过localhost访问了,若访问失败,可能是已经安装了Apache等占用80端口的服务,或者是防火墙问题,若访问成功,应该如下图所示。

步骤二:安装MySQL数据库

$ sudo apt install mysql-server-5.7

执行该条命令安装MySQL,但仍为能使用,需要进行配置。考虑到安全问题,这里将通过一个脚本程序来完成MySQL的权限配置。

$ sudo mysql_secure_installation

执行该条命令,将会提示是否开启密码验证,如下所示,输入Y后按回车。

VALIDATE PASSWORD PLUGIN can be used to test passwords
and improve security. It checks the strength of password
and allows the users to set only those passwords which are
secure enough. Would you like to setup VALIDATE PASSWORD plugin?

Press y|Y for Yes, any other key for No:

然后,就会问设置密码的强度,可以根据提示按实际需要选择,这里选择0。

There are three levels of password validation policy:

LOW Length >= 8
MEDIUM Length >= 8, numeric, mixed case, and special characters
STRONG Length >= 8, numeric, mixed case, special characters and dictionary file

Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 1

接着,提示设置密码,连续输入两次密码后,会提示是否重新修改,输入N后回车完成密码设置。

MySQL5.7默认情况下,root用户使用的是auth_socket插件进行身份认证,所以通过账号密码的方式是无法登陆的,比如php通过root和password的方式连接数据库会失败。

为了能够使MySQL5.7的root账号能够使用密码进行登陆,可以按照以下方法修改权限。

$ sudo mysql

通过该条命令使用MySQL自带的客户端连接数据库服务器,然后输入以下命令查看root的登陆验证方式。

mysql> SELECT user,authentication_string,plugin,host FROM mysql.user;

+------------------+-------------------------------------------+-----------------------+-----------+
| user | authentication_string | plugin | host |
+------------------+-------------------------------------------+-----------------------+-----------+
| root | | auth_socket | localhost |
| mysql.session | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| mysql.sys | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| debian-sys-maint | *CC744277A401A7D25BE1CA89AFF17BF607F876FF | mysql_native_password | localhost |
+------------------+-------------------------------------------+-----------------------+-----------+
4 rows in set (0.00 sec)

可以看到,root账号使用的auto_socket登陆验证方式,需要将它改为mysql_native_password方式。

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root密码';

此时如果报1819错误,输入:

set global validate_password_policy=0;

这样,判断密码的标准就基于密码的长度了,输入足够长就可以。

注意:将root密码修改为实际密码再执行以上命令,如该密码可用于php连接数据库时使用。

mysql> FLUSH PRIVILEGES;

执行该条命令更新下配置,输入以下命令,再次查看root账号的登陆验证方式。

mysql> SELECT user,authentication_string,plugin,host FROM mysql.user;

Output
+------------------+-------------------------------------------+-----------------------+-----------+
| user | authentication_string | plugin | host |
+------------------+-------------------------------------------+-----------------------+-----------+
| root | *3636DACC8616D997782ADD0839F92C1571D6D78F | mysql_native_password | localhost |
| mysql.session | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| mysql.sys | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| debian-sys-maint | *CC744277A401A7D25BE1CA89AFF17BF607F876FF | mysql_native_password | localhost |
+------------------+-------------------------------------------+-----------------------+-----------+
4 rows in set (0.00 sec)

可以看到,root的登陆验证方式已经从auto_socket变成mysql_native_password了。

mysql> exit

退出MySQL客户端,届时,完成了MySQL安装和配置。

步骤三:安装PHP和配置Nginx使用PHP处理器

通过以上操作,完成Nginx和MySQL的安装,而动态网页则是PHP的工作。
Nginx不想其他网站服务器自带PHP处理器,需要自己安装php-fpm,即fastCGI process manager,然后配置Nginx将客户端PHP请求传给它进行处理。

$ sudo apt install php-fpm php-mysql

此时,LEMP全部所需的软件都安装好了,接着就是配置的工作了。

首先配置Nginx服务器区块的等级(服务器区块类似Apache服务器的虚拟站点)。服务器区块配置文件在/etc/nginx/sites-available目录下,这里新建的服务器区块的配置文件名为localhost,如下命令,创建localhost文件并进行编辑。

$ sudo nano /etc/nginx/sites-available/localhost
server {
listen 80;
root /var/www/html;
index index.php index.html index.htm index.nginx-debian.html;
server_name localhost; location / {
try_files $uri $uri/ =404;
} location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
} location ~ /\.ht {
deny all;
}
}

上述配置大概意思是:

listen —— 网站监听端口,这里设置为80,即浏览器默认的HTTP端口号。
root —— 网站根目录。
index —— 默认访问页。
server_name —— 网站访问域名,若是其他域名访问时,则不会响应,这里设置为localhost用于本地调试。
location / —— 该区块有一个try_files命令,当客户端请求找不到对应文件时,将会返回404页面。
location ~\.php$ —— 该区块匹配.php后缀的文件并传给php-fpm进行处理。
location ~ /\.ht —— 该区块禁止.htaccess的访问。
保存以上配置后,通过创建软连接的方式,使配置文件能够被Nginx加载。

$ sudo ln -s /etc/nginx/sites-available/localhost /etc/nginx/sites-enabled/

然后测试配置文件是否正常。

$ sudo nginx -t

配置正常的话,就可以重新启动nginx使配置生效了。

$ sudo systemctl reload nginx

步骤四:创建PHP文件和访问测试
在配置nginx时定义了网站根目录为/var/www/html/,可以在此目录创建PHP网页供访问测试。

$ sudo nano /var/www/html/info.php
<?php
phpinfo();
?>

保存后,打开浏览器输入http://localhost/info.php,访问成功的话,可以看到如下截图的类似界面。

LEMP--如何在Ubuntu上安装Linux、Nginx、MySQL和PHP的更多相关文章

  1. (转)如何在Windows上安装多个MySQL

    原文:http://www.blogjava.net/hongjunli/archive/2009/03/01/257216.html 如何在Windows上安装多个MySQL 本文以免安装版的mys ...

  2. 【转载】如何在Ubuntu上安装LAMP服务器系统?

    转载自:http://os.51cto.com/art/201307/405333.htm [2013年7月25日 51CTO外电头条]为何应该在Ubuntu上安装LAMP服务器?从事Web开发工作时 ...

  3. [转载]如何在Ubuntu上安装LAMP服务器系统

    [2013年7月25日 51CTO外电头条]为何应该在Ubuntu上安装LAMP服务器?从事Web开发工作时,我更偏爱在不受干扰的情况下,在我那台计算机上的开发环境下进行开发.我宁愿所犯的错误大部分是 ...

  4. 【Ubuntu QQ】记如何在Ubuntu上安装QQ(附下载)

    什么困扰着一批批的ubuntu桌面用户?是麻花藤.哦不,是QQ,怎么在ubuntu上安装完美无瑕的QQ. 最佳解决方案在“三”部分,当然前两个也不失为解决方案 一.尝试的开始 配置: 双系统:Wind ...

  5. 如何在 Ubuntu 上安装 MongoDB

    MongoDB 是一个越来越流行的自由开源的 NoSQL 数据库,它将数据存储在类似 JSON 的灵活文档集中,这与 SQL 数据库中常见的表格形式形成对比. 你很可能发现在现代 Web 应用中使用 ...

  6. 如何在 Ubuntu 上安装 pip

    1.为 Python 2 安装 pip 首先,确保已经安装了 Python 2. 在 Ubuntu 上,可以使用以下命令进行验证 python2 --version 如果没有错误并且显示了 Pytho ...

  7. 如何在ubuntu上安装 搜狗输入法(已经成功)

    转自:https://blog.csdn.net/qq_37589838/article/details/81208409 本文链接:https://blog.csdn.net/qq_37589838 ...

  8. [译]How to Setup Sync Gateway on Ubuntu如何在ubuntu上安装sync-gateway

    参考文章https://hidekiitakura.com/2015/03/21/how-to-setup-sync-gateway-on-ubuntudigitalocean/ 在此对作者表示感谢 ...

  9. 如何在Ubuntu上安装LAMP服务器系统?

    在Ubuntu上安装LAMP Ubuntu的开发人员让人们很容易安装和配置LAMP软件包,只要借助一个终端命令.所以,打开终端窗口,让我们开始入手吧. sudo apt-get install lam ...

随机推荐

  1. Django项目:CRM(客户关系管理系统)--16--08PerfectCRM实现King_admin显示注册表的字段表头

    # king_urls.py # ————————02PerfectCRM创建ADMIN页面———————— from django.conf.urls import url from king_ad ...

  2. leetcode 198-234 easy

    198. House Robber 相邻不能打劫,取利益最大化. 思想:当前值和前一个和的总数   与  前一个和    做大小比较,取最大值,重复该步骤. class Solution { publ ...

  3. QT_获取运行进程所在目录路径_2

    QString getProcessFullPath(const quint64 &processId) { #ifdef Q_OS_WIN // access process path WC ...

  4. HR招聘_(四)_招聘方法论(简历筛选)

    .主动投递 筛选时需要看学历背景,公司平台,所在时间,岗位职责,项目经验几个部分,根据对岗位需求和企业文化选择合适的候选人. 筛选简历建议分岗位筛选,切记误操作或大意淘汰优秀候选人. .搜索下载 互联 ...

  5. Phpstrom 配置php版本语法支持

  6. Hibernate:**not found while looking for property: id https://blog.csdn.net/weixin_43827144/article/details/88935334

    https://blog.csdn.net/weixin_43827144/article/details/88935334 在程序执行时可能会报找不到属性的错误:例如:class Student n ...

  7. em grid control网格控制

    网格控制 必须管理许多的数据库.应用服务器.web服务器和其他构件的企业可以采用em grid control Em grid control是一个基于web的用户界面,它与oracle企业内所有构件 ...

  8. SDUT-3402_数据结构实验之排序五:归并求逆序数

    数据结构实验之排序五:归并求逆序数 Time Limit: 50 ms Memory Limit: 65536 KiB Problem Description 对于数列a1,a2,a3-中的任意两个数 ...

  9. golang的变量

    (1)只声明:var 变量名字 类型              var a int             var a, b, c,d int      只有类型,如果初始化表达式被省略,那么将用零值 ...

  10. 【CF Manthan, Codefest 17 B】Marvolo Gaunt's Ring

    [链接]h在这里写链接 [题意] 给你n个数字; 让你在其中找出三个数字i,j,k(i<=j<=k); 使得p*a[i]+q*a[j]+r*a[k]最大; [题解] /*     有一个要 ...