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

LNMP的搭建

一、安装 Nginx 服务

1、关闭防火墙,将安装nginx所需软件包传到/opt目录下

2、安装依赖包

3、创建运行用户、组

4、编译安装nginx

5、添加 Nginx 系统服务

6、浏览器测试

二、安装 MySQL 服务

1、安装Mysql环境依赖包

2、创建运行用户

3、编译安装

4、修改mysql 配置文件

5、更改mysql安装目录和配置文件的属主属组

6、设置路径环境变量

7、初始化数据库

8、添加mysqld系统服务

9、修改mysql 的登录密码

10、授权远程登录

三、编译安装PHP

1、安装环境依赖包

2、编译安装

3、路径优化

4、调整PHP配置文件

5、启动php-fpm

6、配置Nginx支持PHP解析

7、测试访问页

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

 

一、安装 Nginx 服务

1、关闭防火墙,将安装Nginx所需软件包传到/opt目录下

systemctl stop firewalld
systemctl  disable firewalld
setenforce 0

 

 

2、安装依赖包

yum install -y pcre-devel zlib-devel gcc gcc-c++ make    
#Nginx的配置及运行需要pcre、zlib等软件包的支持,因此需要安装这些安装的开发包,以便提供相应的库和头文件   

3、创建运行用户、组

useradd -M -s /sbin/nologin Nginx       
#Nginx服务程序认以nobody身份运行,建议为其创建专门的用户账号,以便更准确地控制其访问权限

4、编译安装Nginx

cd /opt
tar zxvf Nginx-1.12.0.tar.gz

cd Nginx-1.12.0/
./configure \
> --prefix=/usr/local/Nginx \      #指定Nginx安装路径
> --user=Nginx \                   #指定用户名
> --group=Nginx \                  #指定组名
> --with-http_stub_status_module   #启用 http_stub_status_module模块以变持状态线计
 
make && make install
 
ln -s /usr/local/Nginx/sbin/Nginx /usr/local/sbin/  #让系统识别Nginx的操作命令

 

 

 

 

 

 

5、添加 Nginx 系统服务

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
ExecrReload=/bin/kill -s HUP SMAINPID
ExecrStop=/bin/kill-s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
 
chmod 754 /lib/systemd/ system/Nginx.service
systemctl start Nginx.service
systemctl enable Nginx.service 

 

 

 

6、浏览器测试

 

二、安装 MysqL 服务

1、安装MysqL环境依赖包

yum -y install \
ncurses \
ncurses-devel \
bison \
cmake

 

 

2、创建运行用户

useradd -M -s /sbin/nologin  MysqL

  

 

3、编译安装

cd /opt
tar zxvf MysqL-boost-5.7.20.tar.gz

cd /opt/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

make && make install

 

 

 

 

 

 

 

 

4、修改MysqL 配置文件

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安装目录和配置文件的属主属组

chown -R MysqL:MysqL /usr/local/MysqL/
chown MysqL:MysqL /etc/my.cnf

  

 

6、设置路径环境变量

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

7、初始化数据库

cd /usr/local/MysqL/bin/
./MysqLd \
--initialize-insecure \
--user=MysqL \
--basedir=/usr/local/MysqL \
--datadir=/usr/local/MysqL/data

 

8、添加MysqLd系统服务

cp /usr/local/MysqL/usr/lib/systemd/system/MysqLd.service /usr/lib/systemd/system/

systemctl daemon-reload
systemctl start MysqLd.service
systemctl enable MysqLd

 

9、修改MysqL登录密码

MysqLadmin -u root -p password "112233"

 

10、授权远程登录

MysqL -u root -p
grant all privileges on *.* to 'root'@'%' identified by '112233';
#授予root用户可以在所有终端远程登录,使用的密码是112233,并对所有数据库和所有表有操作权限

show databases;			#查看当前已有的数据库

三、编译安装PHP

1、安装环境依赖包

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、编译安装

cd /opt
tar jxvf PHP-7.1.10.tar.bz2

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-zip

make && make install

 

 

 

 

 

 

 

3、路径优化

ln -s /usr/local/PHP/sbin/* /usr/local/sbin/

 

 

4、调整PHP配置文件

(1)PHP.ini主配置文件

#调整主配置文件:
cp /opt/PHP-7.1.10/PHP.ini-development /usr/local/PHP/lib/PHP.ini	
vim /usr/local/PHP/lib/PHP.ini
--1170行--修改
MysqLi.default_socket = /usr/local/MysqL/MysqL.sock
--939行--取消注释,修改
date.timezone = Asia/Shanghai

PHP -m 					#验证安装的模块

 

 

 

 

 

(2)PHP-fpm.conf进程服务配置文件

#调整进程服务配置文件:
cd /usr/local/PHP/etc/
cp  PHP-fpm.conf.default PHP-fpm.conf
vim PHP-fpm.conf
--17行--去掉";"注释
pid = run/PHP-fpm.pid

(3)www.conf扩展配置文件

#调整扩展配置文件:
cd /usr/local/PHP/etc/PHP-fpm.d/
cp www.conf.default www.conf  

5、启动PHP-fpm

/usr/local/PHP/sbin/PHP-fpm -c /usr/local/PHP/lib/PHP.ini
netstat -anpt | grep 9000

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

cd /opt/PHP-7.1.10/sapi/fpm
cp PHP-fpm.service /usr/lib/systemd/system/PHP-fpm.service
systemctl restart PHP-fpm.service  

6、配置Nginx支持PHP解析

vim /usr/local/Nginx/conf/Nginx.conf
--65行--取消注释,修改
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;	#将 /scripts 修改Nginx的工作目录
include        fastcgi_params;
}

systemctl restart Nginx.service

 

 

7、测试访问页

vim /usr/local/Nginx/html/index.PHP
<?PHP
PHPinfo();
?>

浏览器访问
http://192.168.142.4/index.PHP

 

 

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

MysqL -u root -p
CREATE DATABASE bbs;  #创建bbs数据库
GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY '112233'; #指定可以使用的用户
GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY '112233';
flush privileges; #刷新数据库

vim /usr/local/Nginx/html/index.PHP   	#替换原来的测试页内容
<?PHP
$link=MysqLi_connect('192.168.142.4','bbsuser','admin123');
if($link) echo "<h1>Success!!</h1>";
else echo "Fail!!";
?>

浏览器访问
http://192.168.142.4/index.PHP

 

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

相关推荐