LNMP部署及应用

本文详细介绍了LNMP(Linux + Nginx + MySQL + PHP)架构的部署,包括Nginx的高性能特性,MySQL的安装配置,以及PHP解析环境的搭建。通过LNMP,可以构建稳定、高效的动态网站服务器,支持高并发和低资源消耗。
摘要由CSDN通过智能技术生成

一、Lnmp架构部署

        1.Nginx

        2.MySQL安装配置

        3.PHP解析环境的安装

二、Nginx服务搭建

三、搭建MySQL数据库

一、LNMP架构的部署

概述:
        LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可以指Perl或Python
        LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构
        Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等
        Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器
        Mysql是一个小型关系型数据库管理系统
        PHP是一种在服务器端执行的嵌入HTML文档的脚本语言
这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统
        LNMP平台就是 Linux、 Ngnix、 My SQL、PHP的组合架构,需要 Linux服务器、MysαL数据库、PHP解析环境
        Ngnix特长:高并发,低资源,处理静态网络访问请求非常强
        Apache:静态处理和动态处理都可以做,更适合做动态处理
        Nginx将动态资源请求交给PHP当中的fpm处理动态请求
        PHP主配置文件:php.ini
        Nginx将动态资源分配给FPM或Apache


Nginx

       概述:
        Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。
        Nginx是一款轻量级的Web服务器/反向代理服务器以及电子邮件代理服务器,并在一个BSD-like协议下发行。由俄罗斯的程序设计师lgor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好。
        Nginx相较于Apache\lighttpd具有占有内存少,稳定性高等优势,并且依靠并发能力强,丰富的模块库以及友好灵活的配置而闻名。在Linux操作系统下,nginx使用epoll事件模型,得益此,nginx在Linux操作系统下效率相当高。同时Nginx在OpenBSD或FreeBSD操作统上采用类似于Epoll的高效事件模型kqueue.
        —款高性能、轻量级Web服务软件
               ■稳定性高
                ■系统资源消耗低
                ■对HTTP并发连接的处理能力高
                    单台物理服务器可支持30 000~50 000个并发请求

MySQL安装配置

  •  为了与 Nginx、PHP环境保持一致,此处选择采用源代码编译的方式安装 My SQL组件
  • MySQL部署的方法
  • 编译安装 MySQL
  • 优化调整初始化数据库
  • 启动mysq服务并设置root数据库账号的密码

PHP解析环境的安装


配置网页动静分离,解析PHP,有两种方法可以选择
■使用PHP的FPM模块
■将访问PHP页面的Web请求转交给 Apache服务器去处理
较新版本的PHP已经自带FPM模块,用来对PHP解析实例进行管理、优化解析效率
■FastCG将 Http Server和动态脚本语言分离开
■Nginx专门处理静态请求,转发动态请求
■PHP FPM专门解析PHP动态请求
■单服务器的LNMP架构通常使用FPM的方式来解析PHP

二、Nginx服务搭建

三、搭建MYSQL数据库

        1、安装MYSQL环境依赖包

 [root@localhost ~]# yum -y install \
> ncurses \      ##字符终端的包,方便终端操作##
> ncurses-devel \
> bison \                      ##MySQL的解析器,解析C++的解析器
> cmake                  ##作用和configure是一样的
[root@localhost ~]# useradd -s /sbin/nologin mysql   ##创建用户##

        2、cmake配置和编译安装

##将所需压缩包传入/opt目录下##
[root@localhost ~]# cd /opt
[root@localhost opt]# tar xf mysql-boost-5.7.20.tar.gz
[root@localhost opt]# cd mysql-5.7.20/
[root@localhost mysql-5.7.20]# cmake \
> -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \    ## 指定安装路径
> -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \  
    ##sock;通讯文件,连接数据库,通讯协议的载体##
> -DSYSCONFDIR=/etc \     ##放的mysql的配置文件
> -DSYSTEMD_PID_DIR=/usr/local/mysql \  ## pid文件指定目录
> -DDEFAULT_CHARSET=utf8  \    ##此行和下一行为字符集相关##
> -DDEFAULT_COLLATION=utf8_general_ci \
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \  ##此行和下三行为存储引擎
> -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
> -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
> -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
> -DMYSQL_DATADIR=/usr/local/mysql/data \   ##指定数据存放位置
> -DWITH_BOOST=boost \       ##底层要支持c++运行库
> -DWITH_SYSTEMD=1       ##ID序列号
[root@localhost mysql-5.7.20]# make -j6  ##-j6指定处理的核心数,最大不能超过本身核心数##
[root@localhost mysql-5.7.20]# make install

        3、设置/usr/local/mysql目录的权限

[root@localhost mysql-5.7.20]# chown -R mysql:mysql /usr/local/mysql

        4、编辑配置文件 

##设置/usr/local/mysql目录的权限##
[root@localhost mysql-5.7.20]# cd /etc
[root@localhost etc]# vim my.cnf
##将原文删除,添加以下内容##
[client]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysql]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

           5、设置环境变量 

方法1、
[root@localhost ~]# echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile 
[root@localhost ~]# echo 'export PATH' >> /etc/profile [root@localhost ~]# source /etc/profile

方法2、
[root@localhost ~]# vim  /etc/profile
去下面添加如下代码
PATH=/usr/local/mysql/bin:/usr/local/mysql/bin:$PATH
==>> wq 保存退出
[root@localhost ~]# source /etc/profile

6.初始化数据库

[root@localhost ~]# cd /usr/local/mysql/
bin/mysqld \                    ## mysqld 是数据库初始化启动脚本
--initialize-insecure \         ## bin/mysql里的初始化的命令
--user=mysql \                  ## 指定用户
--basedir=/usr/local/mysql \    ## 指定工作目录
--datadir=/usr/local/mysql/data ## 指定数据存放位置

为了让systemctl进行管理,systemctl管理/usr/lib/systemd/system/下的程序
[root@localhost mysql]# cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/

            7、开启数据库并检查状态

[root@localhost mysql]# systemctl enable mysqld   ## 数据库开机自启
Created symlink from /etc/systemd/system/multi-user.target.wants/mysqld.service to /usr/lib/systemd/system/mysqld.service.
[root@localhost mysql]# systemctl start mysqld    ## 开启数据库
[root@localhost mysql]# systemctl status mysqld   ## 查看数据库状态
[root@localhost mysql]# netstat -anpt | grep 3306 ## 查看数据库端口状态
tcp6       0      0 :::3306                 :::*                    LISTEN      92257/mysqld     

        8、设置mysql密码并登录数据库 

[root@localhost mysql]# mysqladmin -u root -p password  ##刚开始没密码是空的直接回车,然后输入密码12345,再次确认密码##
Enter password: 
New password: 
Confirm new password: 
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.   ##密码设置成功##
[root@localhost mysql]# mysql -u root -p   ##输入密码,即可登录到数据库##
. . . . . . . . . . . . . . 
mysql> exit

 四、PHP编译安装

目录

​编辑

一、Lnmp架构部署

        1.Nginx

        2.MySQL安装配置

        3.PHP解析环境的安装

二、Nginx服务搭建

三、搭建MySQL数据库

一、LNMP架构的部署

概述:        LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可以指Perl或Python        LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构        Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等        Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器        Mysql是一个小型关系型数据库管理系统        PHP是一种在服务器端执行的嵌入HTML文档的脚本语言这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统

        LNMP平台就是 Linux、 Ngnix、 My SQL、PHP的组合架构,需要 Linux服务器、MysαL数据库、PHP解析环境        Ngnix特长:高并发,低资源,处理静态网络访问请求非常强        Apache:静态处理和动态处理都可以做,更适合做动态处理        Nginx将动态资源请求交给PHP当中的fpm处理动态请求        PHP主配置文件:php.ini        Nginx将动态资源分配给FPM或Apache

Nginx

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值