微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

LNMP架构的安装

LNMP架构的安装

目录

一、LNMP架构的编译安装

1. 安装Nginx服务

(1)关闭防火墙

[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# systemctl disable firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@localhost ~]# setenforce 0
setenforce: SELinux is disabled

(2)安装依赖包

[root@localhost ~]# yum -y install pcre-devel zlib-devel gcc gcc-c++ make

(3)创建运行用户

[root@localhost ~]# useradd -M -s /sbin/nologin Nginx

(4)编译安装

[root@localhost ~]# cd /opt
[root@localhost opt]# tar zxvf Nginx-1.12.0.tar.gz -C /opt
[root@localhost opt]# cd Nginx-1.12.0/
[root@localhost Nginx-1.12.0]# ./configure \
> --prefix=/usr/local/Nginx \
> --user=Nginx \
> --group=Nginx \
> --with-http_stub_status_module
[root@localhost Nginx-1.12.0]# make -j 2 && make install

(5)优化路径

[root@localhost Nginx-1.12.0]# ln -s /usr/local/Nginx/sbin/Nginx /usr/local/sbin/

(6)添加Nginx系统服务

[root@localhost Nginx-1.12.0]# vim /lib/systemd/system/Nginx.service

[Unit]
Description=Nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/Nginx/logs/Nginx.pid
ExecStart=/usr/local/Nginx/sbin/Nginx
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target

[root@localhost Nginx-1.12.0]# chmod 754 /lib/systemd/system/Nginx.service
[root@localhost Nginx-1.12.0]# systemctl start Nginx.service
[root@localhost Nginx-1.12.0]# systemctl enable Nginx.service
Created symlink from /etc/systemd/system/multi-user.target.wants/Nginx.service to /usr/lib/systemd/system/Nginx.service.

2. 安装MysqL服务

(1)安装MysqL环境依赖包

[root@localhost Nginx-1.12.0]# yum -y install \
> ncurses \
> ncurses-devel \
> bison \
> cmake

(2)创建运行用户

[root@localhost Nginx-1.12.0]# useradd -M -s /sbin/nologin MysqL

(3)编译安装

[root@localhost Nginx-1.12.0]# cd /opt
[root@localhost opt]# tar zxvf MysqL-boost-5.7.20.tar.gz
[root@localhost opt]# cd /opt/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 \
> -DSYSconfdIR=/etc \
> -DSYstemD_PID_DIR=/usr/local/MysqL \
> -DDEFAULT_CHARSET=utf8  \
> -DDEFAULT_COLLATION=utf8_general_ci \
> -DWITH_EXTRA_CHARSETS=all \
> -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
[root@localhost MysqL-5.7.20]# make -j 2 && make install

(4)修改MysqL配置文件

[root@localhost MysqL-5.7.20]# vim /etc/my.cnf
#删除全部内容后编辑
[client]
port = 3306
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
bind-address = 0.0.0.0
skip-name-resolve
max_connections=2048
default-storage-engine=INNODB
max_allowed_packet=16M
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)更改MysqL安装目录和配置文件的属主数组

[root@localhost MysqL-5.7.20]# chown -R MysqL:MysqL /usr/local/MysqL/
[root@localhost MysqL-5.7.20]# chown MysqL:MysqL /etc/my.cnf

(6)设置路径环境变量

[root@localhost MysqL-5.7.20]# echo 'export PATH=/usr/local/MysqL/bin:/usr/local/MysqL/lib:$PATH' >> /etc/profile
[root@localhost MysqL-5.7.20]# source /etc/profile

(7)初始化数据库

[root@localhost MysqL-5.7.20]# cd /usr/local/MysqL/bin/
[root@localhost bin]# ./MysqLd \
> --initialize-insecure \
> --user=MysqL \
> --basedir=/usr/local/MysqL \
> --datadir=/usr/local/MysqL/data

(8)添加MysqLd系统服务

[root@localhost bin]# cp /usr/local/MysqL/usr/lib/systemd/system/MysqLd.service /usr/lib/systemd/system/
[root@localhost bin]# systemctl daemon-reload
[root@localhost bin]# systemctl start MysqLd.service
[root@localhost bin]# systemctl enable MysqLd
Created symlink from /etc/systemd/system/multi-user.target.wants/MysqLd.service to /usr/lib/systemd/system/MysqLd.service.

(9)修改MysqL登录密码

[root@localhost bin]# MysqLadmin -u root -p password "abc123"
Enter password: 
MysqLadmin: [Warning] Using a password on the command line interface can be insecure.
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.

(10)授权远程登录

[root@localhost bin]# MysqL -u root -p
Enter password: 
Welcome to the MysqL monitor.  Commands end with ; or \g.
Your MysqL connection id is 5
Server version: 5.7.20 Source distribution

copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered Trademark of Oracle Corporation and/or its
affiliates. Other names may be Trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MysqL> grant all privileges on *.* to 'root'@'%' identified by 'abc123';
Query OK, 0 rows affected, 1 warning (0.00 sec)

3. 安装配置PHP解析环境

(1)安装环境依赖包

[root@localhost bin]# yum -y install gd \
> libjpeg libjpeg-devel \
> libpng libpng-devel \
> freetype freetype-devel \
> libxml2 libxml2-devel \
> zlib zlib-devel \
> curl curl-devel \
> openssl openssl-devel

(2)编译安装

[root@localhost bin]# cd /opt
[root@localhost opt]# tar jxvf PHP-7.1.10.tar.bz2
[root@localhost opt]# cd PHP-7.1.10
[root@localhost 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-zip
[root@localhost PHP-7.1.10]# make -j 2 && make install

(3)路径优化

[root@localhost PHP-7.1.10]# ln -s /usr/local/PHP/bin/* /usr/local/bin/
[root@localhost PHP-7.1.10]# ln -s /usr/local/PHP/sbin/* /usr/local/sbin/

(4)调整PHP配置文件

PHP有三个配置文件,分别是:
配置文件PHP.ini
进程服务配置文件PHP-fpm.conf
扩展配置文件www.conf

  1. 调整主配置文件
[root@localhost PHP-7.1.10]# vim /usr/local/PHP/lib/PHP.ini

#1170行,修改
MysqLi.default_socket = /usr/local/MysqL/MysqL.sock
#939行,取消注释,修改
date.timezone = Asia/Shanghai

[root@localhost PHP-7.1.10]# PHP -m   #验证安装的模块
[PHP Modules]
Core
ctype
curl
date
dom
fileinfo
filter
ftp
gd
hash
iconv
json
libxml
mbstring
MysqLi
MysqLnd
openssl
pcre
PDO
pdo_sqlite
Phar
posix
Reflection
session
SimpleXML
SPL
sqlite3
standard
tokenizer
xml
xmlreader
xmlwriter
zip
zlib

[Zend Modules]
  1. 调整进程服务配置文件
[root@localhost PHP-7.1.10]# cd /usr/local/PHP/etc/
[root@localhost etc]# cp PHP-fpm.conf.default PHP-fpm.conf
[root@localhost etc]# vim PHP-fpm.conf

#17行,删除注释符号“;”
pid = run/PHP-fpm.pid
  1. 调整扩展配置文件
[root@localhost etc]# cd /usr/local/PHP/etc/PHP-fpm.d/
[root@localhost PHP-fpm.d]# cp www.conf.default www.conf

(5)启动PHP-fpm

PHP-FPM(FastCGI Process Manager:FastCGI 进程管理器)是一个 PHPFastCGI 管理器, 由于Nginx服务器不能处理动态页面,需要由 Nginx 把动态请求交给 PHP-fpm 进程进行解析。

[root@localhost PHP-fpm.d]# /usr/local/PHP/sbin/PHP-fpm -c /usr/local/PHP/lib/PHP.ini
[root@localhost PHP-fpm.d]# netstat -anpt | grep 9000
tcp        0      0 127.0.0.1:9000          0.0.0.0:*               LISTEN      33883/PHP-fpm: mast 
[root@localhost PHP-fpm.d]# cd /opt/PHP-7.1.10/sapi/fpm
[root@localhost fpm]# cp PHP-fpm.service /usr/lib/systemd/system/PHP-fpm.service
[root@localhost fpm]# systemctl restart PHP-fpm.service

(6)配置Nginx支持PHP解析

[root@localhost fpm]# vim /usr/local/Nginx/conf/Nginx.conf

#65行-71行,取消注释,修改第69行,将/scripts 修改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;
        }

[root@localhost fpm]# systemctl restart Nginx.service

(7)验证PHP测试页

[root@localhost fpm]# vim /usr/local/Nginx/html/index.PHP

<?PHP
PHPinfo();
?>

(8)验证数据库工作是否正常

[root@localhost fpm]# MysqL -u root -p
Enter password: 
Welcome to the MysqL monitor.  Commands end with ; or \g.
Your MysqL connection id is 6
Server version: 5.7.20 Source distribution

copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered Trademark of Oracle Corporation and/or its
affiliates. Other names may be Trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MysqL> CREATE DATABASE bbs;
Query OK, 1 row affected (0.00 sec)

MysqL> GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';
Query OK, 0 rows affected, 1 warning (0.00 sec)

MysqL> flush privileges;
Query OK, 0 rows affected (0.03 sec)

MysqL> quit
Bye
[root@localhost fpm]# vim /usr/local/Nginx/html/index.PHP

<?PHP
$link=MysqLi_connect('192.168.122.10','bbsuser','admin123');
if($link) echo "<h1>Success!!</h1>";
else echo "Fail!!";
?>

4.部署discuz!社区论坛web应用

(1)解压论坛软件

[root@localhost fpm]# cd /opt
[root@localhost opt]# unzip discuz_X3.4_SC_UTF8.zip  -d /opt/dis

(2)新建web目录

[root@localhost opt]# cd /opt/dis/dir_SC_UTF8/
[root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/Nginx/html/bbs/

(3)调整论坛目录的权限

[root@localhost dir_SC_UTF8]# cd /usr/local/Nginx/html/bbs/
[root@localhost bbs]# chmod -R 777 ./{config,data,uc_server,uc_client}

(4)安装bbs





(5)访问

用户访问页面http://IP地址/bbs/index.php


管理访问页面http://IP地址/bbs/admin.php


二、LNMP架构的yum安装

编辑中...

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐