热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Web服务群集LNMP部署及应用(LNMP架构部署,nginx,mysql,PHP编译安装,discuz论坛搭建)

文章目录前言一:LNMP架构的部署(理论)1.1:LNMP架构概述1.2:MySQL安装配置1.3࿱

文章目录

  • 前言
  • 一:LNMP架构的部署(理论)
      • 1.1:LNMP架构概述
      • 1.2:MySQL安装配置
      • 1.3:PHP解析环境的安装
      • 1.4:配置Ngnx支持PHP环境
      • 1.5:常见的PHP开源产品介绍
  • 二:LNMP应用部署(实操)
      • 2.1:Nginx安装
          • 2.1.1:编译安装步骤
          • 2.1.2:使用systemctl控制
          • 2.1.3:开启nginx,关闭防火墙
      • 2.2:mysql编译安装
          • 2.2.1:安装mysql环境依赖包
          • 2.2.2:cmake配置和make和make install
          • 2.2.3:设置/usr/local/mysql目录的权限
          • 2.2.4:编辑配置文件
          • 2.2.5:设置环境变量
          • 2.2.6:初始化数据库
          • 2.2.7:开启数据库,检查状态
          • 2.2.8:设置mysql密码
          • 2.2.9:尝试登录数据库
      • 2.3:PHP编译安装
          • 2.3.1:安装环境包
          • 2.3.2:编译安装
          • 2.2.3:配置PHP的三个配置文件
          • 2.2.4:创建软链接
          • 2.2.5:编辑,让nginx支持PHP功能
          • 2.2.6:测试数据库工作是否正常
      • 2.4:搭建Discuz论坛
          • 2.4.1:按解压论坛安装包
          • 2.4.2:设置论坛权限
          • 2.4.3:访问论坛


前言
  • 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架构的部署(理论)

1.1:LNMP架构概述


  • LNMP平台就是 Linux、 Ngnix、 My SQL、PHP的组合架构,需要 Linux服务器、MysαL数据库、PHP解析环境

  • Ngnix特长:高并发,低资源,处理静态网络访问请求非常强

    Apache:静态处理和动态处理都可以做,更适合做动态处理

    Nginx将动态资源请求交给PHP当中的fpm处理动态请求

    PHP主配置文件:php.ini

    Nginx将动态资源分配给FPM或Apache


1.2:MySQL安装配置


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

1.3:PHP解析环境的安装


  • 配置网页动静分离,解析PHP,有两种方法可以选择

    • 使用PHP的FPM模块

    • 将访问PHP页面的Web请求转交给 Apache服务器去处理

  • 较新版本的PHP已经自带FPM模块,用来对PHP解析实例进行管理、优化解析效率

    • FastCG将 Http Server和动态脚本语言分离开
    • Nginx专门处理静态请求,转发动态请求
    • PHP FPM专门解析PHP动态请求
  • 单服务器的LNMP架构通常使用FPM的方式来解析PHP

  • PHP编译安装步骤

    • 编译安装PHP
    • 编译选项时添加"- enable-fpm”以启用此模块
    • 安装后的调整,主要是配置文件的建立与相应命令工具的路径优化
    • 安装 Zend Guardloader(提高PHP解析效率),并进行加载配置
    • CGI还有跨平台的功能

1.4:配置Ngnx支持PHP环境


  • 调用本机的php-fpm进程配置方法

    • 建立FPM配置文件php- fpm. conf,修改配置选项,如:PD文件运行用户、服务进程数等

    • 启动php-pm进程

  • 在Ngnx的配置文件中的 serve}配置段配置将PHP的网页请求转给FPM模块处理

  • 在Ngnx的配置文件中的 Server{}配置段配置将PHP的网页请求转给FPM模块处理

    [root@localhost~]# vim /usr/local/nginx/conf/nginx. conf Servert{
    ...location ~\.php${root /var/www/kgc;fastcgi_pass 127.0.0.1:9000;fastcgi_index index.php;include fastcgi.conf;
    ...


1.5:常见的PHP开源产品介绍


  • Discuz!

  • 康盛创想(北京困技有限公司推出的一套通用的社区论坛软件系统,如001年6月面世以来,是全球成熟度最高、覆盖率最大的论坛软件系统之一

  • PHPWind

PHPWind(简称:PW)是一个基于PHP和 MySQL的论坛程序,是国内最受欢迎的通用型论坛程序之一。 PHPWind的前身是onstar,发布于2004年, PHPWind由杭州德天信息技术有限公司开发,软件全面开源免费

二:LNMP应用部署(实操)

2.1:Nginx安装


2.1.1:编译安装步骤

  • 1.挂载宿主机的共享文件夹,读取下载好的源码文件

    2.解压跨平台组件包和源码包
    将跨平台组件包移动到源码包目录下

    3.安装编译器和其他工具

    yum -y install gcc \
    gcc-c++ \
    make \
    pcre-devel \
    expat-devel \
    perl \
    zlib-devel \
    pcre

    4.configure配置

    ./configure \
    --prefix=/usr/local/nginx \
    --user=nginx \
    --group=nginx \
    --with-http_stub_status_module

    5.make编译和make install

    6,路径优化

    ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin '//nginx命令执行路径优化'
    useradd -M -s /sbin/nologin nginx


2.1.2:使用systemctl控制

vim /lib/systemd/system/nginx.service '//添加使用systemctl工具进行管理'
[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.targetchmod 754 /lib/systemd/system/nginx.service

2.1.3:开启nginx,关闭防火墙

[root@localhost system]# chmod +754 nginx.service
[root@localhost system]# systemctl start nginx.service
[root@localhost system]# netstat -ntap |grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 5396/nginx: master
tcp 0 0 192.168.197.192:56680 192.168.100.3:445 ESTABLISHED -
[root@localhost system]# systemctl stop firewalld.service
[root@localhost system]# setenforce 0

2.2:mysql编译安装


2.2.1:安装mysql环境依赖包

yum -y install \
ncurses \ '//字符终端的包,方便终端操作'
ncurses-devel \
bison \ '//函数库'
cmake '//没有configure,使用cmake'创建用户
useradd -s /usr/sbin/nologin mysql

2.2.2:cmake配置和make和make install

解压mysql-boost-5.7.20.tar.gz到opt目录下 '//boost是5.7版本的特性'
进入mysql1-57.20目录cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ '//sock;通讯文件,连接数据库,通讯协议的载体'
-DSYSCONFDIR=/etc \ '//配置目录指向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 \ '//指定boost位置'
-DWITH_SYSTEMD=1 '//守护进程'

make & make install

2.2.3:设置/usr/local/mysql目录的权限

chown -R mysql.mysql /usr/local/mysql

2.2.4:编辑配置文件

cd /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 = 1sql_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

2.2.5:设置环境变量

echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
echo 'export PATH' >> /etc/profile
source /etc/profile

2.2.6:初始化数据库

cd /usr/local/mysql/
执行
bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/

2.2.7:开启数据库,检查状态

systemctl enable mysqld
systemctl start mysqld
systemctl stop mysqld
systemctl status mysqld
netstat -ntap |grep mysqld '//应该查出来3306端口'

2.2.8:设置mysql密码

mysqladmin -u root -p password '//刚开始没密码是空的直接回车,然后输入密码abe123,再次确认密码'

2.2.9:尝试登录数据库

mysql -u root -p '//这个命令敲下,提示要输入密码,这个就是刚才设置的密码abc123'

2.3:PHP编译安装


2.3.1:安装环境包

yum -y install \
libjpeg \
libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 \
libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel

2.3.2:编译安装

cd /opt
tar xjvf php-7.1.10.tar.bz2 '//将下载的软件包解压到/opt'
cd 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 \
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \
--with-openssl \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zipmake && make install

2.2.3:配置PHP的三个配置文件

'//php有三个配置文件 php.ini核心配置文件 php-fpm.conf进程服务配置文件www.conf 扩展配置文件'cp php.ini-development /usr/local/php/lib/php.ini
vi /usr/local/php/lib/php.ini
'//找到以下两行的位置,修改这两行'
mysql.default_socket = /usr/local/mysql/mysql.sock
date.timezone = Asia/Shanghai '//找到后,前方的;注释要去掉'/usr/local/php/bin/php -m/验证安装的模块

2.2.4:创建软链接

/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
[root@localhost etc]# netstat -natp |grep 9000
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 32236/php-fpm: mast
ln -s /usr/local/php/bin/* /usr/local/bin/ps aux | grep -c "php-fpm”//结果
[root@localhost etc]# ln -s /usr/local/php/bin/* /usr/local/bin/
[root@localhost etc]# ps aux |grep -c "php-fpm"
4

2.2.5:编辑,让nginx支持PHP功能

vi /usr/local/nginx/conf/nginx.conf //找到下面字段
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;
}
'//用/usr/local/nginx/html替换原来的路径
vi /usr/local/nginx/html/index.php
phpinfo();
?>
systemctl restart nginx在网页测试http://192.168.197.190/index.php

2.2.6:测试数据库工作是否正常

mysq1 -u root -p ##输入abc123密码CREATE DATABASE bbs;
GRANT all ON bbs.* To 'bbsuser'@'%' IDENTIFIED BY 'admin123';
GRANT all ON bbs.* To 'bbsuser'@'localhost' IDENTIFIED BY 'admin123';
flush privileges;vi /usr/local/nginx/html/index.php ###原来的测试页内容更改如下
$link=mysqli_connect('192.168.197.192','bbsuser','admin123');
if($link) echo"

Success!!

";
else echo "Fail!!";
?>
systemctl restart nginx在网页测试http://192.168.197.192/index.php

2.4:搭建Discuz论坛


2.4.1:按解压论坛安装包

cd/opt
unzip Discuz_X3.4_SC_UTF8.zip -d /tmp
cd /tmp/dir_SC_UTF8/

2.4.2:设置论坛权限

cp -r upload /usr/local/nginx/html/bbs
cd /usr/local/nginx/html/bbs/chown -R root:nginx ./config/
chown -R root:nginx ./data/
chown -R root:nginx ./uc_client/
chown -R root:nginx ./uc_server/chmod -R 777 ./config/
chmod -R 777 ./data/
chmod -R 777 ./uc_client/
chmod -R 777 ./uc_server/

2.4.3:访问论坛

http://ip/bbs/install/index.php数据库服务器:localhost #本地架设就用 localhost,如果不是在本机上就要填写IP地址和端口
数据库名字户名:bbsuser
管理员账号:admin
密码:admin123http://IP/bbs/admin.php//管理后台
账户:admin
密码:admin123访问论坛 http://192.168.32.21/bbs/index.php


推荐阅读
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • Linux下安装免费杀毒软件ClamAV及使用方法
    本文介绍了在Linux系统下安装免费杀毒软件ClamAV的方法,并提供了使用该软件更新病毒库和进行病毒扫描的指令参数。同时还提供了官方安装文档和下载地址。 ... [详细]
  • 本文介绍了在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一,尤其是在大规模系统中,数据库集群已经成为必备的配置之一。文章详细介绍了主从数据库架构的好处和实验环境的搭建方法,包括主数据库的配置文件修改和设置需要同步的数据库等内容。MySQL的主从复制功能在国内外大型网站架构体系中被广泛采用,本文总结了作者在实际的Web项目中的实践经验。 ... [详细]
  • 【重识云原生】第四章云网络4.8.3.2节——Open vSwitch工作原理详解
    2OpenvSwitch架构2.1OVS整体架构ovs-vswitchd:守护程序,实现交换功能,和Linux内核兼容模块一起,实现基于流的交换flow-basedswitchin ... [详细]
  • Linux下ODBC安装配置
    Linux下ODBC安装配置ODBC原理ODBC是 ... [详细]
  • 如何在mysqlshell命令中执行sql命令行本文介绍MySQL8.0shell子模块Util的两个导入特性importTableimport_table(JS和python版本 ... [详细]
  • 为了区别于传统的CS模式,才特意将其称为BS模式。认识到这些结构的特征,对于系统的选型而言是很关键的。1、系统的性能在系统的性能方面, ... [详细]
  • shell脚本实战 pdf_Shell 脚本操作数据库实战
    安装mariadb数据库(默认没有密码,直接mysql即可进入数据库管理控制台)yuminstallmariadbmariadb-serv ... [详细]
  • Linux环境中使用Mysql数据库
    Linux下Mysql数据库MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典MySQLAB公司,目前属于Oracle公司,MySQL被广泛地应用在I ... [详细]
  • 本文是搭建的mariadb-10.0.17版本的下载地址:https:downloads.mariadb.orginterstitialmariadb-10.0.17sourcemariadb-10.0.17.tar.gzfromhtt ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • MySQL数据库查询注意事项及查询命令详解
    本文介绍了在进行MySQL数据库查询时需要注意的地方,包括启动informix数据库的命令oninit,查询状态的命令onstat,以及相关的网址链接。同时还详细解释了oninit命令的用法和参数,包括初始化磁盘空间和共享内存、保留在线模式等。对于需要进行MySQL数据库查询的读者,本文提供了实用的查询命令和相关注意事项,帮助读者更好地进行数据库查询。 ... [详细]
  • Centos7安装MySql5.6
    如何在CentO ... [详细]
  • 阿里云主机实战应用之centos7上的防火墙设置
    最近公司又上了一台服务器,以前都是用centos6系统,这次选择使用了centos7系统的安装镜像,因为现在程序版本在centos7上一般php默认就是5.4以上的,mysql也 ... [详细]
author-avatar
我无眼泪1221
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有