LNMP部署及应用理论及实操

LNMP部署及应用

LNMP架构解读

LNMP平台就是Linux、Ngnix、 MySQL、 PHP的组合架
构,需要Linux服务器、MySQL 数据库、PHP解析环境

MySQL安装配置

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

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

PHP编译安装步骤

编译安装PHP
编译选项时添加"--enable-fpm" 以启用此模块
安装后的调整,主要是配置文件的建立与相应命令工具的路径优化,安装ZendGuardLoader (提高PHP解析效率),并进行加载配置
调用本机的php-fpm进程配置方法
建立FPM配置文件php-fpm.conf,修改配置选项,如: PID文件运行用户、服务进程数等
启动php-fpm进程
在Nginx的配置文件中的server{ }配置段配置将PHP的网页请求转给FPM模块处理
在Nginx的配置文件中的Server{ }配置段配置将PHP的网页请求转给FPM模块处理
[[email protected] ~ ]# vim /usr/local/nginx/conf/nginx.conf
Server{

......
location ~ .php$ {
root
/var/www/kgc;
fastcgi pass 127.0.0.1:9000; //fpm端口号:9000
fastcgi index index.php;
include
fastcgi.conf;
......

Discuz
康盛创想(北京)科技有限公司推出的一套通用的社区论坛软件系
统,2001年6月面世以来,是全球成熟度最高、覆盖率最大的论
坛软件系统之-
PHPWind
PHPWind (简称: PW)是一-个基于PHP和MySQL的论坛程序
是国内最受欢迎的通用型论坛程序之一。PHPWind的前身是
ofstar,发布于2004年,PHPWind由杭州德天信息技术有限公
司开发,软件全面开源免费

WordPress
一种使用PHP语言开发的博客平台,用户可以在支持PHP和
MySQL数据库的服务器上架设自己的网志。也可以把
WordPress当作一个内容管理系统(CMS)来使用。
WordPress是一一个免费的开源项目,在GNU通用公共许可证下
授权发布
SKYUC
由天空网络历经多年开发的一个VOD视频点播系统,完美支持
QVOD、Webplayer9等流媒体软件

LNMP架构实战

一、远程挂载LNMP所需压缩软件包到本地

[[email protected] ~]# mkdir /abc //创建挂载点
[[email protected] ~]# mount.cifs //192.168.100.10/LAMP-C7 /mnt //将所需软件包远程挂载到本地/mnt目录下

二、编译安装Nginx

1、解压源码包到/opt目录下

[[email protected] ~]# cd /mnt //切换到挂载点目录
[[email protected] mnt]# ls
Discuz_X3.4_SC_UTF8.zip nginx-1.12.2.tar.gz
mysql-boost-5.7.20.tar.gz php-7.1.20.tar.gz
[[email protected] mnt]# tar zxvf nginx-1.12.2.tar.gz -C /opt //解压Nginx源码包到/opt下
[[email protected] mnt]# cd /opt/ //切换到解压的目录下
[[email protected] opt]# ls
nginx-1.12.2 rh

2、安装编译Nginx需要的环境组件包

[[email protected] opt]# yum -y install \
gcc \ //c语言
gcc-c++ \ //c++语言
pcre-devel \ //pcre语言工具
zlib-devel //数据压缩用的函式库

3、创建程序用户nginx并编译Nginx
[[email protected] opt]# useradd -M -s /sbin/nologin nginx //创建程序用户,安全不可登陆状态
[[email protected] opt]# id nginx
uid=1001(nginx) gid=1001(nginx) 组=1001(nginx)
[[email protected] opt]# cd nginx-1.12.0/ //切换到nginx目录下
[[email protected] nginx-1.12.0]# ./configure \ //配置nginx

--prefix=/usr/local/nginx \ //安装路径
--user=nginx \ //用户名
--group=nginx \ //用户组
--with-http_stub_status_module //状态统计模块

4、编译和安装

[[email protected] nginx-1.12.2]#make && make install

5、路径优化

[[email protected] nginx]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
//创建软连接让系统识别nginx启动脚本
[[email protected] nginx]# nginx -t //检查配置文件的语法问题
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[[email protected] nginx]# nginx //开启ngnix
[[email protected] nginx]# netstat -ntap | grep 80 //查看端口,nginx已经开启
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 39620/nginx: master
[[email protected] nginx]# systemctl stop firewalld.service //关闭防火墙
[[email protected] nginx]# setenforce 0
[[email protected] nginx]# nginx //开启nginx 服务

[[email protected] nginx]# cd /etc/init.d/   //切换到启动配置文件目录
[[email protected] init.d]# ls
functions  netconsole  network  README
[[email protected] init.d]# vim nginx         //编辑启动脚本文件

    #!/bin/bash
    # chkconfig: - 99 20                                    //注释信息
    # description: Nginx Service Control Script
    PROG="/usr/local/nginx/sbin/nginx"           //设置变量为nginx命令文件
    PIDF="/usr/local/nginx/logs/nginx.pid"       //设置变量PID文件 进程号为5346
    case "$1" in
        start)
            $PROG                                              //开启服务
            ;;
        stop)
            kill -s QUIT $(cat $PIDF)                    //关闭服务
            ;;
        restart)                                                  //重启服务
            $0 stop
            $0 start
            ;;
        reload)                                                  //重载服务
            kill -s HUP $(cat $PIDF)
            ;;
        *)                                                           //错误输入提示
                    echo "Usage: $0 {start|stop|restart|reload}"
                    exit 1
    esac
    exit 0
[[email protected] init.d]# chmod +x /etc/init.d/nginx    //授予启动脚本执行权限
[[email protected] init.d]# chkconfig --add nginx          //添加到service管理器
[[email protected] init.d]# service nginx stop                //使用service停止nginx服务
[[email protected] init.d]# service nginx start                //使用service启动nginx服务
[[email protected] ~]# vim /lib/systemd/system/nginx.service      //创建配置文件

[Unit]
Description=nginx                                            //描述
After=network.target                                        //描述服务类型
[Service]
Type=forking                                                    //后台运行形式
PIDFile=/usr/local/nginx/logs/nginx.pid            //PID文件位置
ExecStart=/usr/local/nginx/sbin/nginx              //启动服务
ExecReload=/usr/bin/kill -s HUP $MAINPID    //根据PID重载配置
ExecStop=/usr/bin/kill -s QUIT $MAINPID       //根据PID终止进程
PrivateTmp=true
[Install]
WantedBy=multi-user.target

[[email protected] ~]# chmod 754 /lib/systemd/system/nginx.service     //设置执行权限
[[email protected] ~]# systemctl stop nginx.service       //关闭nginx
[[email protected] ~]# systemctl start nginx.service       //开启nginx

三、安装MySQL

1、安装环境组件
[[email protected] ~]# yum install -y \ //安装环境组件

ncurses \
ncurese-devel \ //控制终端屏幕显示的库
bison \ //语法分析工具
cmake //cmake工具
[[email protected] ~]# useradd -s /sbin/nologin mysql //创建程序用户

2、解压源码包到/opt目录下

[[email protected] ~]# cd /mnt
[[email protected] mnt]# tar zxvf mysql-boost-5.7.20.tar.gz -C /opt   ##解压源码包到/opt
[[email protected] mnt]# cd /opt
[[email protected] opt]# ls
mysql-5.7.20  nginx-1.12.2  rh

3、cmake配置

[[email protected] opt]# cd mysql-5.7.20/       //切换到MySQL目录下
[[email protected] mysql-5.7.20]# cmake \     //cmake配置
-DCMAKE_INSTALL_PREFIX=/usr/localmysql \            //安装路径
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ //定义sock文件连接数据库文件
-DSYSCONFDIR=/etc \                                                   //配置文件目录
-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 \                                               //底层运行库
-DWITH_SYSTEMD=1                                                   //主从参数

4、编译及安装

[[email protected] mysql-5.7.20]#make && make install

5、修改Mysql的配置文件

[[email protected] mysql-5.7.20]# chown -R mysql:mysql /usr/local/mysql/
//数据库目录进行权限调整
[[email protected] mysql-5.7.20]# vim /etc/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      //设置mysql的安装目录
    datadir = /usr/local/mysql/data    //设置mysql数据库的数据的存放目录
    port = 3306                    //设置3306端口
    character_set_server=utf8            //中文字符集
    pid-file = /usr/local/mysql/mysqld.pid     //pid文件路径
    socket = /usr/local/mysql/mysql.sock     //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
//支持模块

[[email protected] mysql-5.7.20]# echo ‘PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH‘ >> /etc/profile
    //将MySQL命令写到本地主机环境配置中
[[email protected] mysql-5.7.20]# echo ‘export PATH‘ >> /etc/profile
     //设置全局环境配置
[[email protected] mysql-5.7.20]# source /etc/profile
    //重启配置文件

6、初始化数据库
[[email protected] mysql-5.7.20]# cd /usr/local/mysql/
[[email protected] mysql]# bin/mysqld \

--initialize-insecure \ ##初始化
--user=mysql \ ##用户
--basedir=/usr/local/mysql \ ##安装目录
--datadir=/usr/local/mysql/data ##数据库数据文件目录

7、将MySQL服务配置文件复制到/usr/lib/systemd/system/下便于使用systemctl管理

[[email protected] mysql]# cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
//便于systemctl管理
[[email protected] mysql]# systemctl enable mysqld   //开机自启动
[[email protected] mysql]# systemctl start mysqld.service     //开启数据库
[[email protected] mysql]# netstat -ntap | grep 3306              //查看MySQL端口号开启情况
tcp6  0  0 :::3306    :::*       LISTEN   59464/mysqld   

8、设置mysql密码

[[email protected] mysql]# mysqladmin -u root -p password
Enter password:
New password:                 //新密码
Confirm new password:     //确认密码

四、编译安装PHP

1、安装环境依赖包

[[email protected] mysql]# yum install -y > libjpeg \                              //jpeg图片格式和开发包
> libjpeg-devel > libpng libpng-devel \           //png图片和开发包
> freetype freetype-devel \    //字体库
> libxml2 \                              //xml文件库
> libxml2-devel > zlib zlib-devel \                    //压缩库
> curl curl-devel \                   //支持数据文件下载工具
> openssl openssl-devel        //安全访问连接

2、解压源码包到/opt目录下

[[email protected] mysql]# cd /abc
[[email protected] abc]# tar jxvf php-7.1.10.tar.bz2 -C /opt
[[email protected] abc]# cd /opt
[[email protected] opt]# ls
mysql-5.7.20  nginx-1.12.2  php-7.1.10  rh

3、配置php参数

[[email protected] opt]# cd php-7.1.10/
[[email protected] php-7.1.10]# ./configure
--prefix=/usr/local/php                        //安装路径
--with-mysql-sock=/usr/local/mysql/mysql.sock   ##连接文件建立通信桥梁
--with-mysqli                                    //客户端支持库
--with-zlib                                         //压缩
--with-curl                                        //支持上传下载功能
--with-gd                                          //gd图像支持图片处理库
--with-jpeg-dir                                  //jpeg
--with-png-dir                                   //png
--with-freetype-dir                            //字体
--with-openssl                                  //安全访问连接
--enable-fpm                                    //fpm支持动态请求模块
--enable-mbstring                            //支持多字节的字符串
--enable-xml                                    //xml文件
--enable-session                             //session支持会话
--enable-ftp                                     //ftp服务
--enable-pdo                                   //驱动连接管理
--enable-tokenizer                          //PHP自带函数
--enable-zip                                    //zip压缩包

4、编译及安装

[[email protected] php-7.1.10]# make && make install

5、配置核心配置文件
(php.ini核心配置文件,php-fpm.conf进程服务配置文件,www. conf 扩展配置文件 )

[[email protected] php-7.1.10]# cp php.ini-development /usr/local/php/lib/php.ini       //复制到安装目录lib库中
[[email protected] php-7.1.10]# vim /usr/local/php/lib/php.ini   //配置核心配置文件

mysqli.default_socket = /usr/local/mysql/mysql.sock     //默认连接文件
date.timezone = Asia/Shanghai                                      //时间

[[email protected] php-7.1.10]# /usr/local/php/bin/php -m   //验证安装的模块

6、配置及优化FPM模块

[[email protected] php-7.1.10]# cd /usr/local/php/etc/
[[email protected] etc]# cp php-fpm.conf.default php-fpm.conf   //优化复制默认进程服务配置文件
[[email protected] etc]# cd /usr/local/php/etc/php-fpm.d/
[[email protected] php-fpm.d]# cp www.conf.default www.conf   //优化复制扩展配置文件
[[email protected] php-fpm.d]# cd /usr/local/php/etc/
[[email protected] etc]# vim php-fpm.conf      //开启fpm.pid进程
pid = run/php-fpm.pid
[[email protected] etc]# /usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini
[[email protected] etc]# netstat -ntap | grep 9000     //查看端口信息
tcp   0 0 127.0.0.1:9000   0.0.0.0:*    LISTEN   69104/php-fpm: mast
[[email protected] etc]# ln -s /usr/local/php/bin/* /usr/local/bin/   //创建软连接便于系统识别
[[email protected] etc]# ps aux | grep -c "php-fpm"
4

7、配置Nginx支持PHP功能

[[email protected] etc]# vim /usr/local/nginx/conf/nginx.conf    ##配置nginx配置文件
    location ~ \.php$ {
        root           html;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;     //站点路径
        include        fastcgi_params;
    }
[[email protected] etc]# vim /usr/local/nginx/html/index.php               //测试php网页
<?php
phpinfo();
?>

[[email protected] etc]# nginx -s stop           //停止nginx服务
[[email protected] etc]# nginx                      //启动nginx服务

8、使用测试机测试网页
在浏览器输入http://192.168.35.134/index.php

9、进入数据库创建bbs数据库并设置管理员和密码

[[email protected] etc]# mysql -u root -p
Enter password:      //进入数据库,密码为之前设定的abc23
mysql> CREATE DATABASE BBS;   //创建bbs数据库
Query OK, 1 row affected (0.00 sec)

mysql> GRANT all ON bbs.* TO ‘bbsusers‘@‘%‘ IDENTIFIED BY ‘admin123‘;
//提权数据库用户bbsuser为管理员并设定密码
Query OK, 0 rows affected, 1 warning (0.00 sec)       

mysql> GRANT all ON bbs.* TO ‘bbsusers‘@‘localhost‘ IDENTIFIED BY ‘admin123‘;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> flush privileges;         //刷新数据库
Query OK, 0 rows affected (0.00 sec)

mysql> quit       //退出

[[email protected] etc]# vim /usr/local/nginx/html/index.php   //测试数据库连接状态
<?php
$link=mysqli_connect(‘192.168.131.129‘,‘bbsusers‘,‘admin123‘);
if($link) echo "<h1>Success!</h1>";
else echo "Fail!!";
?>
[[email protected] etc]# systemctl restart nginx.service     //重启服务

五、安装Discuz论坛

1、解压缩论坛包到/opt目录下,并将目录内容复制到bbs站点中

[[email protected] etc]# cd /mnt
[[email protected] mnt]# unzip  Discuz_X3.4_SC_UTF8.zip -d /opt    //解压到/opt下
[[email protected] mnt]# cd /opt
[[email protected] opt]# ls
dir_SC_UTF8  mysql-5.7.20  nginx-1.12.2  php-7.1.10  rh  说明.htm
[[email protected] opt]# cd dir_SC_UTF8/          //进入论坛目录
[[email protected] dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs/
//复制/opt目录里的内容到html站点的bbs目录中

2、进入站点并给程序用户提权

[[email protected] dir_SC_UTF8]# cd /usr/local/nginx/html/bbs/          //切入bbs站点目录
[[email protected] bbs]# chown -R root:nginx ./config/                   //提权程序用户提权
[[email protected] bbs]# chown -R root:nginx ./data/                     //修改nginx属组
[[email protected] bbs]# chown -R root:nginx ./uc_client/
[[email protected] bbs]# chown -R root:nginx ./uc_server/
[[email protected] bbs]# chmod -R 777 ./config/                            //修改所有权限
[[email protected] bbs]# chmod -R 777 ./data/
[[email protected] bbs]# chmod -R 777 ./uc_client/
[[email protected] bbs]# chmod -R 777 ./uc_server/

3、浏览器中输入192.168.131.129/bbs/install/index.php站点,进入Discuz论坛安装向导

4、运行环境为全新安装

5、安装数据库

6、创建成功并访问论坛

原文地址:https://blog.51cto.com/14449528/2449548

时间: 2024-11-09 05:08:35

LNMP部署及应用理论及实操的相关文章

搭建部署Docker容器详解实操

Docker 容器 :    容器是Docker又一核心的概念,简单来说,容器是独立运行的一个或一组应用,以及它们的运行态环境.对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用. 接下来具体介绍如何管理一个容器,包括创建.启动和停止等. 启动容器有两种方式:          (1.) 第一种是基于镜像新建一个容器并启动.   所需要的命令主要为docker run    实例:            -t:让docker分配一个为终端(pase

华为HCIE理论与实操笔记【6-设备接口与网络接入】

挖坑待填 接口与接入 二层.三层端口 端口二层功能的关闭(启用其三层功能) 端口组 自协商与非自协商 端口复用 serial接口 E1接入 3G接入 POS接入 CPOS接入 ADSL接入 PON接入 FTTH接入

华为HCIE理论与实操笔记【5-ftp_sftp文件管理】

名词解释: [FTP] FTP即File Transfer Protocol(文件传输协议),首先它是一个协议,规定了两台设备间如何进行文件传输,在不同的操作系统会有不同的实现方法,但只要遵循这个协议的标准,就可以在互联网上互相传递文件.同时它也是应用程序的名称,提供FTP服务的端称为FTP Server,网络另一端进行文件上传或下载的称为FTP Client. [SFTP] SFTP即Secure File Transfer Protocol(安全文件传输协议),严格来讲SFTP与FTP除了名

华为HCIE理论与实操笔记【2-VRP BootRom】

名词解释: [VRP] VRP--Versatile Routing Platform 即通用路由平台,是华为交换机.路由器等设备的操作系统,可类比于PC机的Windows.与PC机类似,VRP系统也包含一个类似于BIOS的BootRom程序.华为设备上电后先启动BootRom程序而后才启动操作系统. [BootRom] Boot即引导的意思,Rom是只读存储.BootRom即一个保存在只读存储器上的程序,用以引导设备启动.在实际设备中一般是一块只读的芯片,在设备上电后这块芯片先进入工作,根据芯

华为HCIE理论与实操笔记【3-telnet管理】

名词解释: [console口] console即控制台.在计算机出现的早期,人们通过数量繁多的按钮和大量的指示灯与计算机进行交互,这就是早期的"并行通讯"简称"并口".这种方式占用了大量的芯片端口且设备间的传输速度非常慢,于是一种快速的通信方式"串行通讯"简称"串口"就出现了.早期人们使用键盘和显示器通过串口的方式与计算机进行交互,这种方式发展到现在就成为一种设备间通用的通讯机制,即"控制台".控制台被用

华为HCIE理论与实操笔记【4-ssh管理】

名词解释: [ssh]ssh即Secure Shell 的缩写,是一种与telnet相似的协议,不同的是ssh在信息传输过程中对数据进行了加密. [密钥]密钥是数据传递时进行加密的一种方式,分为对称密钥和非对称密钥,对称密钥其加密过程和解密过程使用的是同一段密文,非对称密钥分为公钥(加密)和私钥(解密)两段密文. [对称密钥]最常见的对称密钥就是电视里常用的"书本加密法",即A和B同时持有一本书,A将要传递的字用书的页码.行数.列数等数字表示,B得到这些数字后,使用同一本书就能将这些信

OSPF高级配置实操——大型公司环境部署

一.路由重分发概念 定义:即将一种路由协议中的路由条目转换为另一种路由协议的路由条目,达到多路由环境下的网络互通理解路由重分发1.一个单一IP路由协议是管理网络中IP路由的首选方案 2.Cisco ISO能执行多个路由协议,每一个路由协议和该路由协议所服务的网络属于同一个自治系统 3.Cisco ISO使用路由重分发特性以交换不同协议创建的路由信息路由重分发的考虑1.度量值 2.管理距离重分发到OSPF域中路由的路径类型1.类型1的外部路径(type1 external path,E1) 2.类

理论+实操:LVM与磁盘配额

[TOC] 前言: LVM是逻辑卷管理的简称,它是Linux环境下对磁盘分区管理的一种机制,实现文件系统跨越不同磁盘和分区,工作原理是将若干个磁盘分区连接成一个整块卷组,在卷组上随意创建逻辑卷组,最后在逻辑卷组上创建文件系统,管理员可以动态调整逻辑卷的大小,不会丢失现有的数据,通过创建LVM可以对磁盘进行动态管理. 一:LVM(逻辑卷)概述 1.1 Logical Volume Manager,逻辑卷管理 动态调整磁盘容量,从而提高磁盘管理的灵活性 /boot(系统内核)分区用于存放引导文件,不

理论+实操:深入理解Linux文件系统与日志分析

前言: inode(文件节点)与block(数据块) 硬链接与软连接 恢复误删除的文件 (即rm-rf 的操作,可以先进行备份的操作,然后可以进行恢复ext4和xfs文件系统皆可) 日志文件的分类 用户日志与程序日志 一 :inode和block概述 1.1 概述 文件数据包括元信息与实际数据 文件存储在硬盘上,硬盘最小存储单位是"扇区",每个扇区储存512字节 block(块) 连续的八个扇区组成一个block,一个block单位是4k 是文件存取的最小单位 inode(索引节点)