Ubuntu18.04+Nginx+PHP7.2+Mysql5.7安装

在Linux环境下,搭建LNMP环境,本来挺容易的,但是在实际操作过程中,遇到一个个坑,真是让人心烦,所以写这篇心得,主要是分享在搭建过程中遇到的一些问题进行了整合,来给后入进行排雷。

先更新apt-get的源(定期使用该命令,确保自己的新下载的软件包是最新版本)
        apt-get update

1.Nginx的安装
        Nginx安装是属于最简单的,只需要在命令行执行
        sudo apt-get install nginx

  就能自动安装 Nginx,其中过程中需要 选择 Y/n 的选择Y就行了,当安装结束后再执行下列代码,开启Nginx服务器
        sudo service nginx start

--------------------------其他命令
        sudo service nginx stop 停止Nginx服务器
        sudo service nginx restart 重启启Nginx服务器

然后在浏览器访问 ip地址(本地为:localhost或127.0.0.1),如果出现Nginx的欢迎页面,就代码Nginx安装成功

2:PHP7.2.5安装

我直接执行如下命令:
        sudo apt-get install php7.2 php7.2-fpm php7.2-mysql 

三个命令一起执行,直接把php相关的各种软件和拓展直接安装成功。

安装成功后可输入:php -v 查看php版本,看看是否安装成功

安装常用扩展
    sudo -y apt-get install php7.2-curl php7.2-json php7.2-mbstring php7.2-xml  php7.2-intl

安装其他扩展(根据自己的需求安装即可)
sudo apt-get install php7.2-gd
sudo apt-get install php7.2-soap
sudo apt-get install php7.2-gmp   
sudo apt-get install php7.2-odbc     
sudo apt-get install php7.2-pspell   
sudo apt-get install php7.2-bcmath
sudo apt-get install php7.2-enchant   
sudo apt-get install php7.2-imap     
sudo apt-get install php7.2-ldap     
sudo apt-get install php7.2-opcache
sudo apt-get install php7.2-readline
sudo apt-get install php7.2-sqlite3   
sudo apt-get install php7.2-xmlrpc
sudo apt-get install php7.2-bz2
sudo apt-get install php7.2-interbase
sudo apt-get install php7.2-pgsql     
sudo apt-get install php7.2-recode   
sudo apt-get install php7.2-sybase   
sudo apt-get install php7.2-xsl
sudo apt-get install php7.2-cgi       
sudo apt-get install php7.2-dba
sudo apt-get install php7.2-phpdbg   
sudo apt-get install php7.2-snmp     
sudo apt-get install php7.2-tidy     
sudo apt-get install php7.2-zip


3:配置Nginx解析PHP

Nginx已经为与 PHP-FPM的整合准备好了,只需要将下面这部分改好就可以了。sock文件路径为 /run/php/php7.1-fpm.sock 。

首先修改你Nginx配置文件,执行命令:
        sudo vim /etc/nginx/sites-available/default

第44行,在index.html前面加入index.php
第56-62行,用如下内容替换:
location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        # With php7.0-cgi alone:
        # fastcgi_pass 127.0.0.1:9000;
        # With php7.2-fpm:
        fastcgi_pass unix:/run/php/php7.2-fpm.sock;
}

保存退出后,执行
    nginx -t
检查刚才配置是否出错

然后再修改 PHP-FPM的配置文件 /etc/php/7.2/fpm/pool.d,如下:
    ;  与 Nginx监听同一个 sock
    listen =/run/php/php7.1-fpm.sock
主要使PHP-FPM与 Nginx监听同一个 sock

然后执行命令,重启Nginx和php-fpm:
    sudo service nginx restart
    sudo service php7.2-fpm restart

4:MySQL的安装

由于使用的是Ubuntu18.04,如果直接不选MySQL版本的话,则自动安装最新的MySQL,所以,在此次安装中,就自动安装了MySQL5.7;

执行命令如下:
        sudo apt-get install mysql-server mysql-client

安装过程中会出现以下选项设定MySQL初始密码的的步骤,不过我在安装过程中,属实是什么都没发生

此处会依次用英文询问(深色为建议填写)
1是否重置密码,Set root password? [Y/n]
            y重置,n不重置(记得密码不必重置)
2删除匿名用户,Remove anonymous users? [Y/n]
            y删除,n不删除  (禁止匿名用户访问)
3关闭远程登陆,Disallow root login remotely? [Y/n]
            y关闭,n不关闭  (允许后可以使用远程软件管理)
删除测试数据库,Remove test database and access to it? [Y/n]
            y删除,n不删除 (不必删除)
重新加载权限表,Reload privilege tables now? [Y/n]
            y重载,n不重载 (刷新)
提示  All done!  则成功安装配置完MySQL。

由于我在安装过程中,属实是什么都没发生,就是这个,导致后面有些坑的出现。

在安装完成后,执行下面命令:
        mysql -u root -p

然后要求你输入密码,如果之前设置,则输入设置好的。

如果没设置,按回车就出现下列报错:
        ERROR1698(28000): Access deniedforuser'root'@'localhost'

这个错误,简单的说,就是密码错了,但是你没设置过,怎么会错呢,这个就是MySQL自身会设置的随机密码的问题了,解决方法就是重新设置新的root密码,但是问题在于,如果进入MySQL中去。我在这过程中有两种方法进入MySQL命令行里,

第一种如下:
        sudo mysql
        通过管理员权限,直接进入。

第二种如下:
        关闭正在运行的 MySQL :
        sudo service mysql stop
        运行命令:
        mysqld_safe--skip-grant-tables &

以上两种方法,如果执行成功,则会成功进入MySQL的命令行中,

然后就开始进行修改root密码的操作了:

mysql>usemysql;
mysql> update mysql.user set authentication_string=PASSWORD('新密码'), plugin='mysql_native_password'where user='root';
mysql>flush privileges;

这一步主要是在设置新密码的时候,顺便把用户root的plugin进行修改,修改为默认的 mysql_native_password,然后在刷新权限设置。

在执行成功后,重启MySQL,然后再执行一次上面连接数据库命令:

sudo service mysql restart 

mysql -u root -p

 我这样解决掉MySQL的使用问题的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容