LNMP 架构平台介绍
包含::
Linux (基于linux)
Nginx(请求转发,反向代理,处理静态资源)
Mysql (存储数据)
Php(处理动态语言)
LNMP平台用户请求流程:
静态页面请求: client --> nginx(location) --> html --> client
动态页面请求: client --> nginx(location) --> fastcgi(快速通用网关接口) --> php-fpm --> wrappe(真正执行者) --> php --> mysql --> php --> wrapper --> php-fpm --> fastcgi --> nginx --> client
MySql
安装mysql
官网: 戳这里
下载5.7.30版本mysql的源码包。
解压:
mysql的预编译是通过 cmake 进行的不同于其它的用 .configure 进行编译,效果相同。
新建mysql用来用户运行mysql:
useradd -s /sbin/nologin -M mysql
yum安装cmake.预编译:
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \ 预安装路径
-DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock \ 套接字存放目录,我们需要创建data目录
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \ 字符格式检测
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ 三个引擎
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \ 读取本地资源
-DMYSQL_USER=mysql \ 指定用户
-DMYSQL_TCP_PROT=3306 \ 端口
-DWITH_BOOST=boost/boost_1_59_0/ boost功能
make && make install 编译过程非常缓慢,建议增大内存和cpu数
中间会出现依赖性的报错,我们安装相应的软件包就行了,每次预编译出错时要删掉上一次的编译缓存(Cmakeache.txt),
gcc 、 ggc-c++ 、 ncurses-devel、 bison 这几个包是需要装的.
编译安装完成后:
就出现了指定目录。
我们建立data目录
mkdir data
chown -R root . 让mysql目录下的所有目录只有root用户有权限更改
chown -R mysql data 让刚才建立mysql用户可以向data目录中写入数据
ln -s /usr/local/lnmp/mysql/bin/* /usr/local/bin
它的配置文件在 /usr/local/lnmp/mysql/mysql-test/include/default_my.cng ,我们:
mv /etc/my.cnf /etc/my.cnf.bak 备份一下源有的mariadb数据库配置文件
cp default_my.cnf /etc/my.cnf 把mysql的配置文件复制到 /etc/ 下
启动脚本在 /usr/local/lnmp/mysql/support-files/mysql.server
cp -a mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld 由于是启动脚本,所以要给执行权限
chkconfig mysqld on 配置开机启动
也可以用systemctl的方式启动了 ,它找的启动文件就是我们刚才复制的文件.
启动mysql
初始化mysql,生成一些相关的表;
mysqld --user=mysql --initialize
执行结果会有几个warning是正常的,并且生成了一个密码。
我们启动mysqld
登陆mysql,用上面给的密码:
mysql -uroot -p
它提示我们该密码,我们可以进行安全初始化。
安全初始化:
mysql_secure_installation
更改密码并设置一些基本选项即可。
再次登陆,就可以看见内容了:
Php
在官网下载安装包,我下载的是7.4.1版本的安装包。
解压编译:
./configure --prefix=/usr/local/lnmp/php \
--with-config-file-path=/usr/local/lnmp/php/etc \
--with-mysqli=/usr/local/lnmp/mysql/bin/mysql_config \
--enable-soap \
--enable-mbstring=all \
--enable-sockets \
--with-pdo-mysql=/usr/local/lnmp/mysql \
--enable-gd \
--without-pear \
--enable-fpm
make && make install
需要的依赖性有:
yum install libxml2-devel.x86_64 -y
yum install sqlite-devel.x86_64 -y
yum install libpng-devel.x86_64 -y
yum install oniguruma-devel-5.9.5-3.el7.x86_64.rpm oniguruma-5.9.5-3.el7.x86_64.rpm -y
编译安装完成。
配置文件:
拷贝默认配置文件成为自己的配置文件
打开里面的pid进程;
进入 etc/php-fpm.d 目录,同样拷贝一份里面的配置文件:
把用户和群组改为 nginx ,因为处理的是nginx传过来的请求:
创建nginx用户:
useradd -s /sbin/nologin -M nginx
拷贝源码包中的配置文件到php的安装目录:
cp php.ini-production /usr/local/lnmp/php/etc/php.ini
然后我们只需要更改一个时区:
配置启动脚本:
在源码包中:
/root/php-7.4.1/sapi/fpm/init.d.php-fpm
复制到 /etc/init.d/ 中
cp init.d.php-fpm /etc/init.d/php-fpm
chmod +x /etc/init.d/php-fpm 添加执行权限
这时我们就可以用 执行脚本的方式启动php了
[root@server2 fpm]# /etc/init.d/php-fpm start
Starting php-fpm done
开启了3306 和9000 端口。
Nginx
nginx的更详细安装和配置请参考
https://blog.csdn.net/thermal_life/article/details/105874757
这里进行一些简单的编译安装就行了
./configure --prefix=/usr/local/lnmp/nginx \
--with-http_ssl_module \
--with-http_stub_status_module \
--user=nginx --group=nginx
make && make install
编译安装完成后的nginx 有5.8M ,是因为我们编译的时候开启的debug功能,我们可以在源码包中的 auto/cc/gcc 文件作更改:
注释掉。
而且我们可以看到当前的nginx版本,这样对企业有一定的危险性,我们可以对源码包中的 ./src/core/nginx.h 文件进行更改:
将上面的更改为:
就可以了。
重新编译安装,参数不变
此时就只有980kb了。
且已经不显示版本号了。
配置文件:
vim /usr/local/lnmp/nginx/conf/nginx.conf
我们需要修改一下它的主站,打开php功能,并让他访问php的发布页面:
访问时先访问 index.php 页面,将动态访问请求转到本地9000端口,即php-fpm开的端口
ln -s /usr/local/lnmp/nginx/sbin/nginx /usr/local/bin/
链接到环境变量方便使用。
端口打开了。
测试访问:
访问的是html/index.html目录,因为我们没有index.php 页面,我们写一个:
这是php的默认页面,会加载php的所有信息。
重新加载nginx,再次测试访问:
这就是 nginx 连接 php 页面。
那我们如何进行nginx和mysql的通信那?
我们就需要搭建一些简单的应用或博客去和数据库通信了。
请参考:
https://blog.csdn.net/thermal_life/article/details/105928346