WSL(Windows Subsystem for Linux) 适用于Linux的Windows子系统

作为一名程序员很多时候需要Linux环境,但是由于PS等某些工具,也不能抛弃Windows,需要双系统来回切 换很是麻烦,用虚拟机又担心性能损耗,直到知道了WSL.需要到 控制面板\所有控制面板项\程序和功能 中选择 启用或者关闭Windows功能


找到 适用于Linux的Windows子系统 并勾选,然后 确定 选择 立即重新启动

在microsoft store 搜索CentOS然后安装,安装完成cmd直接输入bash进入Centos命令行模式

查看安装的CentOS版本号

cat /etc/redhat-release

linux子系统并迁移到非系统盘

这个Linux子系统其实是在C盘上的,如果你要在上面配置一些环境可能会大量占用C盘空间,未来保证系统盘空间充足,我们还要将其迁移到非系统盘(下面以D盘为例)。

C:\Users\%USERNAME%\AppData\Local\Packages\CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs

这个就是 Ubuntu WSL版的根目录,C盘目录是/mnt/c。首先下载一个WSL的管理工具叫LxRunOffline做迁移,github地址是这里。下载后在其目录下,shift+鼠标右键开启powershell,之后可以通过

.\LxRunOffline.exe list   查看可用的子系统
wsl --shutdown   wsl关机
.\LxRunOffline.exe move -n Ubuntu -d D:\WSL

.\LxRunOffline.exe get-dir -n Ubuntu 查询系统目录,验证迁移成功

一、准备

安装之前,需要准备编译环境和nginx依赖。

1.0 安装killall命令

yum install psmisc

1.1 安装make

yum -y install gcc automake autoconf libtool make

1.2 安装g++

yum install gcc gcc-c++ pcre pcre-devel openssl openssl-devel bzip2 -y

1.3 安装PCRE库

cd /usr/local/src
wget https://ftp.pcre.org/pub/pcre/pcre-8.43.tar.gz
tar -zxvf pcre-8.43.tar.gz
cd pcre-8.43/
./configure
make && make install

1.4 安装zlib库

cd /usr/local/src
wget http://zlib.net/zlib-1.2.11.tar.gz
tar -zxvf zlib-1.2.11.tar.gz
cd zlib-1.2.11/
./configure
make && make install

1.5 安装OpenSSL库

cd /usr/local/src
wget http://www.openssl.org/source/openssl-1.1.1c.tar.gz
tar -zxvf openssl-1.1.1c.tar.gz
cd openssl-1.1.1c/
./config
sudo make && sudo make install


#查看版本号
openssl version -a

1.6 编译安装libsodium

cd /usr/local/src
wget https://github.com/jedisct1/libsodium/releases/download/1.0.17/libsodium-1.0.17.tar.gz
tar xf libsodium-1.0.17.tar.gz
cd libsodium-1.0.17
./configure
make
make install

1.7创建用户及用户组

一般为了服务器安全,会指定一个普通用户权限的账号做为Nginx的运行角色,这里使用www用户做为Nginx工作进程的用户。后续安装的PHP也以www用户作为工作进程用户。

groupadd -r www
useradd -r -g www www

二、安装Nginx

2.1 下载

cd /usr/local/src
wget http://nginx.org/download/nginx-1.14.0.tar.gz
tar -zxvf nginx-1.14.0.tar.gz
cd nginx-1.14.0

2.2 配置

./configure \
--prefix=/usr/local/nginx \
--sbin-path=/usr/local/nginx/sbin/nginx \
--conf-path=/usr/local/nginx/nginx.conf \
--pid-path=/usr/local/nginx/nginx.pid \
--user=www \
--group=www \
--with-http_ssl_module \
--with-http_flv_module \
--with-http_mp4_module  \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/tmp/nginx/client/ \
--http-proxy-temp-path=/var/tmp/nginx/proxy/ \
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \
--http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \
--http-scgi-temp-path=/var/tmp/nginx/scgi \
--with-pcre=/usr/local/src/pcre-8.43 \
--with-zlib=/usr/local/src/zlib-1.2.11 \
--with-openssl=/usr/local/src/openssl-1.1.1c

make && make install

nginx编译选项说明:

–prefix表示nginx要安装到哪个路径下,这里指定刚才新建好的/alidata/server目录下的nginx-1.12.2;

–sbin-path表示nginx的可执行文件存放路径

–conf-path表示nginx的主配置文件存放路径,nginx允许使用不同的配置文件启动,通过命令行中的-c选项

–pid-path表示nginx.pid文件的存放路径,将存储的主进程的进程号。安装完成后,可以随时改变的文件名 , 在nginx.conf配置文件中使用 PID指令。默认情况下,文件名 为prefix/logs/nginx.pid

–error-log-path表示nginx的主错误、警告、和诊断文件存放路径

–http-log-path表示nginx的主请求的HTTP服务器的日志文件的存放路径

–user表示nginx工作进程的用户

–group表示nginx工作进程的用户组

–with-select_module或–without-select_module表示启用或禁用构建一个模块来允许服务器使用select()方法

–with-poll_module或–without-poll_module表示启用或禁用构建一个模块来允许服务器使用poll()方法

–with-http_ssl_module表示使用https协议模块。默认情况下,该模块没有被构建。建立并运行此模块的OpenSSL库是必需的

–with-pcre表示pcre的源码路径,因为解压后的pcre是放在root目录下的,所以是/root/pcre-8.41;

–with-zlib表示zlib的源码路径,这里因为解压后的zlib是放在root目录下的,所以是/root/zlib-1.2.11

–with-openssl表示openssl库的源码路径

2.3 启动

mkdir -p /var/tmp/nginx/client
/usr/local/nginx/sbin/nginx

2.4 设置软连接

ln -sf /usr/local/nginx/sbin/nginx /usr/sbin

2.5 检查

nginx -t

结果:

nginx: the configuration file /usr/local/nginx/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/nginx.conf test is successful 

使用另外一台机器访问该服务器,就会出现“Welcome to nginx!”。

2.6 关闭防火墙

执行关闭命令: systemctl stop firewalld.service
再次执行查看防火墙命令:systemctl status firewalld.service
执行开机禁用防火墙自启命令  : systemctl disable firewalld.service

三、YUM安装PHP

3.1 安装epel、remi源

yum install epel-release -y
rpm --import http://rpms.famillecollet.com/RPM-GPG-KEY-remi
rpm -ivh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm

#下面出现新增的源
ls /etc/yum.repos.d

3.2 安装php7.2及扩展 

yum install yum-utils
#查看可以安装的PHP版本
yum repolist all | grep php
#设置默认安装的版本
yum-config-manager --enable remi-php72

#可以安装的PHP扩展
yum search php72-php
#安装PHP扩展(不用加php72-) 
yum install -y php-amqp php-devel php-common php-fpm php-opcache php-cli php-pear php-pdo php-mysqlnd php-mysql php-pecl-mongodb php-pecl-memcached php-pecl-xlswriter \
php-gd php-mbstring php-mcrypt php-xml php-openssl php-intl php-zmq php-bcmath php-redis php-zip 

#查看安装的php
rpm -qa | grep php

 安装缺失包处理去https://pkgs.org/下载 ,注意匹配操作系统和32/64

 执行

rpm -Uvh https://download-ib01.fedoraproject.org/pub/epel/7/x86_64/Packages/l/libargon2-20161029-3.el7.x86_64.rpm

3.3 配置php

cp -rf /etc/opt/remi/php72/php.ini /etc/
cp -rf /etc/opt/remi/php72/php-fpm.conf /etc/
cp -rf /etc/opt/remi/php72/php-fpm.d/www.conf /etc/php-fpm.d/

find /opt/remi/ -name php-config
find /opt/remi/ -name phpize

3.4 操作php

systemctl start php-fpm.service
systemctl stop php-fpm.service
systemctl restart php-fpm.service
systemctl reload php-fpm.service

3.5 配置PHP与Nginx

修改/usr/local/nginx/nginx.conf:
添加红色文字内容
location / {
    root   html;
    # 添加index.php
    index  index.php index.html index.htm;
}
去掉注释、修改inclue
location ~ \.php$ {
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
    fastcgi_index  index.php;
    include        fastcgi_params;
}

重新载入nginx的配置文件
nginx -s reload

在/usr/local/nginx/html下创建index.php文件,输入如下内容:
<?php
    phpinfo();
    
浏览器访问该地址:{IP}/index.php

四、安装MySQL

4.1 下载MySQL

浏览打开网址:https://dev.mysql.com/downloads/repo/yum/

cd /usr/local/src
wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm

4.2 安装MySQL

yum -y install mysql80-community-release-el7-3.noarch.rpm
yum -y install mysql-community-server

4.3 添加用户和用户组

groupadd mysql
useradd -r -g www mysql

#ERROR 2002 (HY000): Can't connect to local MySQL server through socket 
mkdir /var/lib/mysqld
chown mysql.mysql /var/lib/mysqld
#vim /etc/my.cnf
pid-file=/var/lib/mysqld/mysqld.pid

设置utf8mb4 

SHOW VARIABLES LIKE 'character_set%';
SHOW VARIABLES LIKE 'collation%'; 

[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
default-time-zone = '+8:00'

character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'

4.4 启动MySQL

systemctl start mysqld.service

4.5 修改root密码

#查看默认密码
grep "password" /var/log/mysqld.log
#更改默认密码
mysqladmin -uroot -p'默认密码' password "str0ngPa$sord"
#登录
mysql -uroot -p'str0ngPa$sord'

4.6 调整密码验证规则:

#查看密码策略
SHOW VARIABLES LIKE 'validate_password%';

#密码强度低
set global validate_password_policy=LOW;
#密码长度限制至少5位
set global validate_password_length=5; 

wsl搭建php环境请求超时的问题解决方案

在 github 的 WSL 项目 issue 中找到了解决方案在nginx.conf 的 http block 中加入

 fastcgi_buffering off;

wsl systemctl报错Failed to get D-Bus connection: Operation not permitted解决

mv /usr/bin/systemctl /usr/bin/systemctl.old
curl https://raw.githubusercontent.com/gdraheim/docker-systemctl-replacement/master/files/docker/systemctl.py > /usr/bin/systemctl
chmod +x /usr/bin/systemctl

wsl netstat无法返回结果bug,使用window cmd netstat命令

netstat -ano|findstr 5672

Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT) for operation '='

ALTER TABLE a CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; 
ALTER TABLE b CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; 

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐