在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不关闭 (允许后可以使用远程软件管理)
4 删除测试数据库,Remove test database and access to it? [Y/n]
y删除,n不删除 (不必删除)
5 重新加载权限表,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的使用问题的。