LNMP

1.LNMP原理

LNMP 是一套技术组合,L=Linx、N=Nginx、M=MySQL、P=PHP


image.png

首先Nginx服务是不能处理动态请求,那么当用户发起动态请求时,Nginx是如何处理?
当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx通过fastcgi协议交给后端的PHP程序处理

2.安装部署

  • 创建www统一用户
groupadd www -g 666
useradd www -s /sbin/nologin -M -u 666 -g 666
id www
uid=666(www) gid=666(www) groups=666(www)
  • 使用官方仓库源安装nginx或local本地仓库
#官方源
[root@web01 ~]# cat /etc/yum.repos.d/nginx.repo 
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key

[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key

[root@web01 ~]# yum install nginx -y

#本地仓库local源
cat >/etc/yum.repos.d/local.repo <<EOF
[local]
name=local
enable=1
gpgcheck=0
baseurl=http://10.0.0.61
#2.客户端测试安装
yum makecache        # 更新下源
yum search nginx     # 查找某个软件,是否走的YUM仓库
yum install nginx    # 安装
  • 启动Nginx并加入开机自启动
systemctl start nginx
systemctl enable nginx
  • 使用第三方拓展源安装PHP7.1或(本地yum仓库)
yum remove php-mysql-5.4 php php-fpm php-common      #清除就环境
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum -y install php71w php71w-fpm php71w-mbstring php71w-common php71w-gd php71w-mcrypt php71w-mysql php71w-xml php71w-cli php71w-devel php71w-pecl-memcached php71w-pecl-redis php71w-opcache
  • 配置php-fpm用户与nginx用户保持一致
sed -i '/^user/c user = www' /etc/php-fpm.d/www.conf
sed -i '/^group/c group = www' /etc/php-fpm.d/www.conf
  • 启动php-fpm并加入开机自启动
systemctl start php-fpm
systemctl enable php-fpm

3.调通Nginx和php的连接

  • nginx子配置文件并重启服务
[root@db02 /etc/nginx/conf.d]# vim php.conf 
server {
    server_name www.a123.com;          # 域名自定义
    listen 80;                         # 暴露端口
    root /code;                        # 代码目录
    index index.php index.html;            # 静态页面

    location ~ \.php$ {                            # 匹配到以.php请求页面
        root /code;                                     # 代码目录
        fastcgi_pass 127.0.0.1:9000;        # 9000端口php-fpm进程
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;    # 函数固定写法
        include fastcgi_params;
    }
}

[root@db02 /etc/nginx/conf.d]# systemctl restart nginx
  • 调用php配置测试
[root@web01 ~]# mkdir /code
[root@web01 ~]# chown -R www:www /code/
[root@web01 ~]# cat /code/info.php
<?php
    phpinfo();
?>
# 为安全考虑,测试完成后需删除此页面
  • 浏览器查看Nginx和php是否连接成功(需配置本地hosts文件)


    image.png

4.将nginx、PHP、MySQL全部调通

  • 安装mysql
#安装依赖
yum install -y cmake openssl-devel gcc gcc-c++ glibc ncurses-devel autoconf libaio-devel

#上传按包并解压
tar xf mysql-5.6.46-linux-glibc2.12-x86_64.tar.gz

#创建存放mysql目录
mkdir /application
mv mysql-5.6.46-linux-glibc2.12-x86_64 /application/mysql-5.6.46

#复制配置文件并覆盖
cd /application/mysql-5.6.46/support-files/
cp my-default.cnf /etc/my.cnf    y
cp mysql.server /etc/init.d/mysqld

#创建mysql用户和软连接。修改目录文件属主,属组
useradd mysql -s /sbin/nologin -M
cd /application/
ln -s mysql-5.6.46 mysql
chown -R mysql:mysql /application/mysql*

#初始化mysql
cd /application/mysql/scripts/
./mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data/

#添加环境变量
vim /etc/profile.d/mysql.sh
export PATH="/application/mysql/bin:$PATH"
source /etc/profile

#修改mysql文件路径并启动
sed -i 's#/usr/local#/application#g' /etc/init.d/mysqld
service mysqld start

#mysql密码设置和初始化
密码设置方法1
mysqladmin password 123

密码设置的同时优化用户安全,清理test库(密码需设置,其他可默认回车)
mysql_secure_installation

#登录测试
mysql
  • 创建测试PHP连通mysql的代码
[root@db02 /code]# cat /code/mysql.php 
<?php
    $servername = "127.0.0.1";            #这里如果写localhost:mysql会去找socket文件
    $username = "root";
    $password = "123";

    // 创建连接
    $conn = mysqli_connect($servername, $username, $password);

    // // 检测连接
    if (!$conn) {
        die("Connection failed: " . mysqli_connect_error());
    }
    echo "php 连接 MySQL 数据库成功";
?>
image.png

5.搭建wordpress博客

#删除/code 目录下无用文件
[root@db02 /code]# rm -rf info.php mysql.php 

#解压wordpress
tar xf wordpress-5.4.1-zh_CN.tar.gz

#修改权限
[root@db02 /code]# chown -R www:www /code/

#添加nginx配置文件并重启
[root@db02 /etc/nginx/conf.d]# vim bk.conf 
  
server {
    server_name www.bk.com;
    listen 80;
    root /code/wordpress;          #博客代码目录
    index index.php index.html;

    location ~ \.php$ {
        root /code/wordpress;      #博客代码目录
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}

systemctl restart nginx

#在windows配置hosts
  • 创建博客数据库
[root@db02 /etc/nginx/conf.d]# mysql -uroot -p123
mysql> create database wordpress;
Query OK, 1 row affected (0.00 sec)
  • WEB页面登录


    image.png

    image.png

    image.png

    image.png

    image.png

    image.png

    image.png

6.将数据库拆分出来

#1.将mysql数据库单独部署一台机
#2.创建一个远程登录的用户,和wordpress库
mysql> grant all on wordpress.* to dev@'10.0.0.%' identified by '123';
mysql> create database wordpress;
#3.使用创建用户登录测试
mysql -udev -p123 -h 10.0.0.55
#4.更改wordpress代码配置文件
[root@web01 /code/wordpress]# vim wp-config-sample.php 
/** MySQL数据库用户名 */
define( 'DB_USER', 'dev' );

/** MySQL数据库密码 */
define( 'DB_PASSWORD', '123' );

/** MySQL主机 */
define( 'DB_HOST', '10.0.0.55' );

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
禁止转载,如需转载请通过简信或评论联系作者。

相关阅读更多精彩内容

友情链接更多精彩内容