配置安装LNMP

LNMP

准备

#首先关闭防火墙
#准备的压缩包
#移动到/opt目录下
[root@localhost ~]# cd /opt
[root@localhost opt]# ls
rh
[root@localhost opt]# rm -rf *
[root@localhost opt]# ls

链接:https://pan.baidu.com/s/1f-avHcpF2rhoM1XKOL9mLA
提取码:1109

image-20211109105730130

编译安装NGINX

#导入
[root@localhost opt]# rz -E
rz waiting to receive.
[root@localhost opt]# ls
Discuz_X3.4_SC_UTF8.zip    nginx-1.12.0.tar.gz
mysql-boost-5.7.20.tar.gz  php-7.1.10.tar.bz2
#解压
[root@localhost opt]# tar zxf nginx-1.12.0.tar.gz 
[root@localhost opt]# ls
Discuz_X3.4_SC_UTF8.zip    nginx-1.12.0         php-7.1.10.tar.bz2
mysql-boost-5.7.20.tar.gz  nginx-1.12.0.tar.gz
[root@localhost opt]# cd nginx-1.12.0/
[root@localhost nginx-1.12.0]# ls
auto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src
#编译安装
[root@localhost nginx-1.12.0]# yum -y install pcre-devel zlib-devel gcc gcc-c++ make

[root@localhost nginx-1.12.0]# ./configure \
 --prefix=/usr/local/nginx \		
 --user=nginx \					
 --group=nginx \					
 --with-http_stub_status_module	

##################解释#################
./configure \					
> --prefix=/usr/local/nginx \	#安装路径
> --user=nginx \				#指定用户名
> --group=nginx \				#指定用户组	
> --with-http_stub_status_module#启用此模块支持状态统计
#######################################

[root@localhost nginx-1.12.0]# make && make install

#做个软链接,使我们可以全系统内使用它,如果不打,只能输入绝对路径来使用它
[root@localhost nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/
[root@localhost nginx-1.12.0]# ls /usr/local/nginx/sbin/nginx
/usr/local/nginx/sbin/nginx

[root@localhost nginx-1.12.0]# cd /lib/systemd/system
[root@localhost system]# vim 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=/usr/bin/kill -s HUP $MAINPID        
ExecStop=/usr/bin/kill -s QUIT $MAINPID         
PrivateTmp=true
[Install]
WantedBy=multi-user.target

############解释###################
[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
#################################

#创建用户后启动服务,测试一下
[root@localhost system]# useradd -M -s /sbin/nologin nginx
[root@localhost system]# systemctl start nginx.service 
[root@localhost system]# ss -ntap |grep 80
LISTEN     0      128          *:80                       *:*                   users:(("nginx",pid=57878,fd=6),("nginx",pid=57877,fd=6))

#关闭服务
[root@localhost system]# systemctl stop nginx.service 
[root@localhost system]# ss -ntap |grep 80
[root@localhost system]# 

编译安装mysql

[root@localhost system]# cd /opt
[root@localhost opt]# ls
Discuz_X3.4_SC_UTF8.zip    nginx-1.12.0         php-7.1.10.tar.bz2
mysql-boost-5.7.20.tar.gz  nginx-1.12.0.tar.gz
[root@localhost opt]# tar zxf mysql-boost-5.7.20.tar.gz 

[root@localhost opt]# cd mysql-5.7.20/
[root@localhost mysql-5.7.20]# ls
boost            dbug                 libmysql     rapid          testclients
BUILD            Docs                 libmysqld    README         unittest
client           Doxyfile-perfschema  libservices  regex          VERSION
cmake            extra                man          scripts        vio
CMakeLists.txt   include              mysql-test   sql            win
cmd-line-utils   INSTALL              mysys        sql-common     zlib
config.h.cmake   libbinlogevents      mysys_ssl    storage
configure.cmake  libbinlogstandalone  packaging    strings
COPYING          libevent             plugin       support-files

#安装mysql环境依赖包
[root@localhost mysql-5.7.20]# yum -y install \
ncurses \
ncurses-devel \
bison \
cmake

#创建运行用户
[root@localhost mysql-5.7.20]# useradd -s /sbin/nologin mysql
[root@localhost mysql-5.7.20]# id mysql
uid=1002(mysql) gid=1002(mysql)=1002(mysql)

#编译安装
[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_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]# cmake \
> -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \			
#指定mysql的安装路径
> -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \	
#指定mysql进程监听套接字文件(数据库连接文件)的存储路径
> -DSYSCONFDIR=/etc \								
#指定配置文件的存储路径
> -DSYSTEMD_PID_DIR=/usr/local/mysql \				
#指定进程文件的存储路径
> -DDEFAULT_CHARSET=utf8  \							
#指定默认使用的字符集编码,如utf8
> -DDEFAULT_COLLATION=utf8_general_ci \				
#指定默认使用的字符集校对规则
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \				
#安装INNOBASE存储引擎
> -DWITH_ARCHIVE_STORAGE_ENGINE=1 \					
#安装ARCHIVE存储引擎
> -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \				
#安装BLACKHOLE存储引擎
> -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \				
#安装FEDERATED存储引擎
> -DMYSQL_DATADIR=/usr/local/mysql/data \			
#指定数据库文件的存储路径
> -DWITH_BOOST=boost \								
#指定boost的路径
> -DWITH_SYSTEMD=1									
#生成便于systemctl管理的文件
#######################################

[root@localhost mysql-5.7.20]# make -j2
#等待安装完成

#数据库目录进行权限调整
[root@localhost mysql-5.7.20]# chown -R mysql:mysql /usr/local/mysql/
chown: 无法访问"/usr/local/mysql/": 没有那个文件或目录
[root@localhost mysql-5.7.20]# cd /usr/local/
[root@localhost local]# 
[root@localhost local]# ls
bin  etc  games  include  lib  lib64  libexec  nginx  sbin  share  src
[root@localhost local]# cd -
/opt/mysql-5.7.20
[root@localhost mysql-5.7.20]# make install
[root@localhost mysql-5.7.20]# chown -R mysql:mysql /usr/local/mysql/

#调整配置文件,删除里面的内容后贴上以下内容
[root@localhost 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
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

NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
STRICT_TRANS_TABLES
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_AUTO_CREATE_USER
禁止:GRANT创建密码为空的用户
NO_AUTO_VALUE_ON_ZERO
mysql中的自增长列可以从o开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错
NO_ZERO_IN_DATE
mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
ERROR_FOR_DIVISION_BY_ZERO
在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MysQL返回NULL
IPES_AS_CONCAT
将"||"视为字符串的连接操作符而非或运算符,这和oracle数据库是一样的,
ANSI QUOTES
启用ANSI QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

#改变属主 属组
[root@localhost mysql-5.7.20]# chown mysql:mysql /etc/my.cnf

#设置环境变量
[root@localhost mysql-5.7.20]# echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
[root@localhost mysql-5.7.20]# echo 'export PATH' >> /etc/profile
[root@localhost mysql-5.7.20]# source /etc/profile
#查看一下
[root@localhost mysql-5.7.20]# echo $PATH 
/usr/local/mysql/bin:/usr/local/mysql/lib:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

#初始化数据库
[root@localhost mysql-5.7.20]# cd /usr/local/mysql/
[root@localhost mysql]# ls
bin      COPYING-test  include  man         README       share          usr
COPYING  docs          lib      mysql-test  README-test  support-files

[root@localhost mysql-5.7.20]# bin/mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data

[root@localhost mysql-5.7.20]# cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/

[root@localhost mysql]# systemctl enable mysqld.service 
Created symlink from /etc/systemd/system/multi-user.target.wants/mysqld.service to /usr/lib/systemd/system/mysqld.service.

#数据库开启
[root@localhost mysql]# netstat -anpt | grep 3306
[root@localhost mysql]# systemctl start mysqld
[root@localhost mysql]# netstat -anpt | grep 3306
tcp6       0      0 :::3306                 :::*                    LISTEN      77941/mysqld        

#登陆数据库
#设置mysql密码
[root@localhost mysql]# mysqladmin -u root -p password
[root@localhost mysql]# mysql -u root -p
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)

安装配置php文件

#安装环境依赖包
 [root@localhost mysql]# yum -y install \
libjpeg \
libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 \
libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel

#编译安装
[root@localhost mysql]# cd /opt/

[root@localhost opt]# ls
Discuz_X3.4_SC_UTF8.zip  mysql-boost-5.7.20.tar.gz  nginx-1.12.0.tar.gz
mysql-5.7.20             nginx-1.12.0               php-7.1.10.tar.bz2
[root@localhost opt]# tar jxf php-7.1.10.tar.bz2 
[root@localhost opt]# ls
Discuz_X3.4_SC_UTF8.zip    nginx-1.12.0         php-7.1.10.tar.bz2
mysql-5.7.20               nginx-1.12.0.tar.gz
mysql-boost-5.7.20.tar.gz  php-7.1.10
[root@localhost opt]# cd php-7.1.10/

[root@localhost opt]# ./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 -j2 && make install

//php有三个配置文件  
php.ini 核心配置文件  
php-fpm.conf 进程服务配置文件 
www.conf  扩展配置文件

[root@localhost php-7.1.10]# cp php.ini-development /usr/local/php/lib/php.ini

[root@localhost php-7.1.10]# cd /usr/local/php/lib/
[root@localhost lib]# ls
php  php.ini
[root@localhost lib]# vim php.ini 

1170 mysqli.default_socket = /usr/local/mysql/mysql.sock
939 date.timezone = Asia/Shanghai


#配置及优化FPM模块
[root@localhost lib]# 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


[root@localhost etc]# cd /usr/local/php/etc/php-fpm.d/
[root@localhost php-fpm.d]# cp www.conf.default www.conf

#开启服务
[root@localhost php-fpm.d]# /usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini

[root@localhost php-fpm.d]# ss -ntap |grep 9000
LISTEN     0      128    127.0.0.1:9000                     *:*                   users:(("php-fpm",pid=83569,fd=0),("php-fpm",pid=83568,fd=0),("php-fpm",pid=83567,fd=7))

[root@localhost php-fpm.d]# ln -s /usr/local/php/bin/* /usr/local/bin/

让nginx支持PHP功能

[root@localhost php-fpm.d]# vim /usr/local/nginx/conf/nginx.conf
#删除这几行前的注释符后,更改第69行
 65         location ~ \.php$ {
 66             root           html;
 67             fastcgi_pass   127.0.0.1:9000;
 68             fastcgi_index  index.php;
 69             fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name; 
 70             include        fastcgi_params;
 71         }
[root@localhost php-fpm.d]# 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

[root@localhost php-fpm.d]# cd /usr/local/nginx/html/
[root@localhost html]# ls
50x.html  index.html

[root@localhost html]# vim index.php 
<?php
phpinfo();
?>

[root@localhost html]# systemctl restart nginx

在网页上测试:http://192.168.254.10/index.php
看到如下图片则成功

image-20211109144848362

测试数据库工作是否正常

[root@localhost html]# mysql -u root -p

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.01 sec)

mysql> GRANT all ON bbs.* TO 'bbsuser'@'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> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| bbs                |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)
mysql> quit
Bye

[root@localhost html]# cd /opt
[root@localhost opt]# ls
Discuz_X3.4_SC_UTF8.zip    nginx-1.12.0         php-7.1.10.tar.bz2
mysql-5.7.20               nginx-1.12.0.tar.gz
mysql-boost-5.7.20.tar.gz  php-7.1.10

[root@localhost opt]# unzip Discuz_X3.4_SC_UTF8.zip 
[root@localhost opt]# ls
dir_SC_UTF8              mysql-boost-5.7.20.tar.gz  php-7.1.10
Discuz_X3.4_SC_UTF8.zip  nginx-1.12.0               php-7.1.10.tar.bz2
mysql-5.7.20             nginx-1.12.0.tar.gz        说明.htm

[root@localhost opt]# cd dir_SC_UTF8/
[root@localhost dir_SC_UTF8]# ls
readme  upload  utility
[root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs/

[root@localhost dir_SC_UTF8]# cd /usr/local/nginx/html/bbs/

#加上权限
[root@localhost bbs]# chown -R root:nginx ./config/
[root@localhost bbs]# chown -R root:nginx ./data/
[root@localhost bbs]# chown -R root:nginx ./uc_client/
[root@localhost bbs]# chown -R root:nginx ./uc_server/
[root@localhost bbs]# 
[root@localhost bbs]# chmod -R 777 ./config/
[root@localhost bbs]# chmod -R 777 ./data/
[root@localhost bbs]# chmod -R 777 ./uc_client/
[root@localhost bbs]# chmod -R 777 ./uc_server/

在网页上输入:http://192.168.254.10/bbs/install/index.php


image-20211109150325468

image-20211109150512179

image-20211109150533945

在网页上输入:http://192.168.254.10/bbs/index.php

image-20211109150721500

全部配置已经完成

.end

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值