Windows子系统搭建lnmp环境
ubuntu18.04+nginx1.14+php7.0-fpm+mysql
1.更新Ubuntu软件源
sudo apt-get update
2.安装nginx
sudo apt-get install nginx
3.安装mysql
sudo apt install mysql-server mysql-client
待安装完成后,执行 mysql -u 你的用户名 -p
你自己设置的密码,如果进入则表明mysql安装好了
遇到的问题
1.mysql -u root -p 出现问题,mysql数据库连接不上
报 ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
(参考的链接:https://blog.csdn.net/Homewm/article/details/81628116)
解决方法:
进入 /etc/mysql/mysql.conf.d
vim mysqld.cnf
添加
[mysql] protocol = tcp
重启mysql服务器。service mysql restart
2.执行mysql -u root -p root,报 ERROR 2003 (HY000): Can’t connect to MySQL server on ‘localhost’ (111)
解决方法:
进入 /etc/mysql/mysql.conf.d
vim mysqld.cnf
将bind-address:127.0.0.1注释
执行service mysql restart
3.执行mysql -u root -p root,报 ERROR 1698 (28000): Access denied for user ‘root’@‘localhost’
解决方法:
(参考的链接:https://www.cnblogs.com/cpl9412290130/p/9583868.html)
1)修改mysqld.cnf配置文件
vim /etc/mysql/mysql.conf.d/mysqld.cnf,进入到这个配置文件,然后在这个配置文件中的[mysqld]这一块中加入skip-grant-tables
2)设置root密码
mysql -u root -p,遇见输入密码的提示直接回车即可,进入mysql后,分别执行下面三句话:
1 use mysql; 然后敲回车
2 update user set authentication_string=password(“你的密码”) where user=“root”; 然后敲回车
3 flush privileges; 然后敲回车
3)注释掉skip-grant-tables
4.再次执行mysql -u root -p root,报 ERROR 1524 (HY000): Plugin ‘auth_socket’ is not loaded
解决方法:(参考的链接:https://blog.csdn.net/qq_36761831/article/details/87111190)
原因可能是因为修改了MySQL属性没有及时进行更新导致的。
解决方法:在终端上输入以下命令重启MySQL:
/etc/init.d/mysql stop
/etc/init.d/mysql start
4.安装php
sudo apt-add-repository ppa:ondrej/php
使用 PPA ppa:ondrej/php
sudo apt update
更新软件库
sudo apt install php7.0 php7.0-fpm php7.0-cgi php7.0-common php7.0-curl php7.0-mysql php7.0-mcrypt php7.0-mbstring
备注:若要安装其他版本php,则类似改版本号就行
重启php-fpm
/etc/init.d/php-fpm7.0 restart
或者
service php7.0-fpm restart
5.nginx配置
sudo vim /etc/php/7.0/fpm/pool.d/www.conf
在www.conf文件中修改listen = 127.0.0.1:9000为
listen = /run/php/php7.0-fpm.sock
可以用如下方式检查下配置文件是否有错误
sudo php-fpm7.0 -t
修改重启下 php-fpm7.0 :
sudo service php7.0-fpm restart
修改nginx配置文件
sudo vim /etc/nginx/sites-enabled/default
例如:
一.
root /var/www;
# Add index.php to the list if you are using PHP
index index.php index.html index.htm index.nginx-debian.html;
找到 location ~ \.php$ { 修改里面
#socket 方式 必须和上面socket的listen路径一样
fastcgi_pass unix:/run/php/php7.0-fpm.sock;
#TCP方式
#fastcgi_pass 127.0.0.1:9000;
#不管用那种方式,通信方式一定要对应。
或者
二.
在/etc/nginx/sites-enabled/下创建软连接,链接到
/etc/nginx/sites-available/test(某个文件)
然后编辑链接到的文件
在location ~.php${}中添加
include /etc/nginx/snippets/fastcgi-php.conf;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_index index.php
include fastcgi.conf;
遇到的问题
解析不了php代码
日志报错
2020/01/31 12:01:50 [error] 14432#14432: *2 upstream timed out (110: Connection timed out) while reading upstream, client: 127.0.0.1, server: test.com, request: “GET /index.php HTTP/1.1”, upstream: “fastcgi://unix:/var/run/php/php7.0-fpm.sock:”, host: “127.0.0.1:9090”
解决办法
在location ~.php${}中添加
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
或者在/etc/nginx/fastcgi_params文件最后中添加
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
然后在在location ~.php${}中添加
include fastcgi_params
修改重启下
nginx sudo service nginx restart
nginx 检查配置文件命令是 sudo nginx -t
遇到的问题(可能只在Windows下的子系统会出现这种问题)
只能访问phpinfo,解析不了其他php代码,问题归结为wsl搭建php环境请求超时的问题
解决办法:
(参考的链接:https://blog.csdn.net/weixin_33762130/article/details/92031905)
在nginx.conf中添加
fastcgi_buffering off;