作为一名程序员很多时候需要Linux环境,但是由于PS等某些工具,也不能抛弃Windows,需要双系统来回切 换很是麻烦,用虚拟机又担心性能损耗,直到知道了WSL.需要到 控制面板\所有控制面板项\程序和功能 中选择 启用或者关闭Windows功能
找到 适用于Linux的Windows子系统 并勾选,然后 确定 选择 立即重新启动
在microsoft store 搜索CentOS然后安装,安装完成cmd直接输入bash进入Centos命令行模式
查看安装的CentOS版本号
cat /etc/redhat-release
这个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依赖。
yum install psmisc
yum -y install gcc automake autoconf libtool make
yum install gcc gcc-c++ pcre pcre-devel openssl openssl-devel bzip2 -y
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
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
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
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
一般为了服务器安全,会指定一个普通用户权限的账号做为Nginx的运行角色,这里使用www用户做为Nginx工作进程的用户。后续安装的PHP也以www用户作为工作进程用户。
groupadd -r www
useradd -r -g www www
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
./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库的源码路径
mkdir -p /var/tmp/nginx/client
/usr/local/nginx/sbin/nginx
ln -sf /usr/local/nginx/sbin/nginx /usr/sbin
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!”。
执行关闭命令: systemctl stop firewalld.service
再次执行查看防火墙命令:systemctl status firewalld.service
执行开机禁用防火墙自启命令 : systemctl disable firewalld.service
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
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
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
systemctl start php-fpm.service
systemctl stop php-fpm.service
systemctl restart php-fpm.service
systemctl reload php-fpm.service
修改/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文件,输入如下内容:
浏览打开网址:https://dev.mysql.com/downloads/repo/yum/
cd /usr/local/src
wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm
yum -y install mysql80-community-release-el7-3.noarch.rpm
yum -y install mysql-community-server
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'
systemctl start mysqld.service
#查看默认密码
grep "password" /var/log/mysqld.log
#更改默认密码
mysqladmin -uroot -p'默认密码' password "str0ngPa$sord"
#登录
mysql -uroot -p'str0ngPa$sord'
#查看密码策略
SHOW VARIABLES LIKE 'validate_password%';
#密码强度低
set global validate_password_policy=LOW;
#密码长度限制至少5位
set global validate_password_length=5;
在 github 的 WSL 项目 issue 中找到了解决方案在nginx.conf 的 http block 中加入
fastcgi_buffering off;
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
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;