LNMP架构的源码编译

目录

一、安装nginx服务

1、实验前的准备

2、安装依赖包

3、创建运行用户

4、编译安装

5、路径优化

6、添加nginx系统服务

7、验证结果

​编辑 二、搭建mysql 

1、安装mysql环境依赖包

2、创建程序用户,便于控制访问用户

3、进行编译安装

4、修改mysql配置

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

6、设置路径环境变量

7、初始数据库

8、添加mysql服务系统

9、修改mysql登录密码

10、授权远程登录

三、搭建php服务

2、编译安装

3、优化路径

4、调整php文件配置

5、启动php-fpm

6、配置Nginx支持php解析

7、验证php测试页

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

​编辑四、部署论坛

1、解压论坛压缩包

2、调整论坛目录权限

3、浏览器访问验证


一、安装nginx服务

1、实验前的准备

1、关闭防火墙并将所需的软件包安装到opt目录下
[root@mayinbin ~]#: systemctl stop firewalld.service 
[root@mayinbin ~]#: systemctl disable firewalld.service 
[root@mayinbin ~]#: setenforce 0

2、安装依赖包

[root@mayinbin opt]#: yum -y install pcre-devel zlib-devel gcc gcc-c++ make

3、创建运行用户

[root@mayinbin opt]#: useradd -M -s /sbin/nologin nginx

4、编译安装

[root@mayinbin opt]#: cd /opt/
[root@mayinbin opt]#: tar zxvf nginx-1.20.2.tar.gz 

[root@mayinbin opt]#: cd nginx-1.20.2/
[root@mayinbin nginx-1.20.2]#: ./configure \
> --prefix=/usr/local/nginx \				#指定nginx的安装路径
> --user=nginx \						#指定用户名
> --group=nginx \						#指定组名
> --with-http_stub_status_module			#启用 http_stub_status_module 模块以支持状态统计

[root@mayinbin nginx-1.20.2]#: make -j2 && make install

5、路径优化

接下来我们要让系统识别niginx操作命令
[root@mayinbin nginx-1.20.2]#: ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

6、添加nginx系统服务

[root@mayinbin nginx-1.20.2]#: 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@mayinbin nginx-1.20.2]#: chmod 754 /lib/systemd/system/nginx.service
[root@mayinbin nginx-1.20.2]#: systemctl start nginx.service
[root@mayinbin nginx-1.20.2]#: systemctl enable nginx.service

7、验证结果

在浏览器中输入你的ip地址进行访问

 二、搭建mysql 

1、安装mysql环境依赖包

[root@mayinbin nginx-1.20.2]#: yum -y install \
> ncurses \				#字符终端下图形互动功能的动态库
> ncurses-devel \			#ncurses开发包
> bison \					#语法分析器
> cmake					#mysql需要用cmake编译安装

2、创建程序用户,便于控制访问用户

[root@mayinbin nginx-1.20.2]#: useradd -M -s /sbin/nologin  mysql

3、进行编译安装

首先我们切换到opt目录下解压mysql软件包
[root@mayinbin nginx-1.20.2]#: cd /opt/
[root@mayinbin opt]#: tar zxvf mysql-boost-5.7.20.tar\(1\)\(1\).gz

然后我们切换到解压好的mysql目录下进行编译
[root@mayinbin opt]#: cd mysql-5.7.20/
[root@mayinbin 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@mayinbin mysql-5.7.20]#: make -j4 && make install

4、修改mysql配置

修改配置文件之前拷贝一份以防修改出错无法恢复
[root@mayinbin mysql-5.7.20]#: cp /etc/my.cnf /etc/my.cnf.bak
[root@mayinbin mysql-5.7.20]#: ls /etc/

修改配置文件
[root@mayinbin 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@mayinbin mysql-5.7.20]#: chown -R mysql:mysql /usr/local/mysql/
[root@mayinbin mysql-5.7.20]#: 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、初始数据库

[root@mayinbin mysql-5.7.20]#: cd /usr/local/mysql/bin/
[root@mayinbin bin]#: ./mysqld \
> --initialize-insecure \				#生成初始密码为空
> --user=mysql \					#指定管理员用户
> --basedir=/usr/local/mysql \		#指定数据库的安装目录
> --datadir=/usr/local/mysql/data		#指定数据库文件的存储路径

8、添加mysql服务系统

[root@mayinbin bin]#: cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/				#用于systemctl服务管理
[root@mayinbin bin]#: systemctl daemon-reload			#刷新识别
[root@mayinbin bin]#: systemctl start mysqld.service		#开启服务
[root@mayinbin bin]#: systemctl enable mysqld			#开机自启动
[root@mayinbin bin]#: netstat -anpt | grep 3306			#查看端口

9、修改mysql登录密码

[root@mayinbin bin]#: mysqladmin -u root -p password "123456"		#给root账号密码设置为123456,提示输入的密码为空

10、授权远程登录

[root@mayinbin bin]#: mysql -u root -p
mysql> grant all privileges on *.* to 'root'@'%' identified by 'qwe123';	#授予root用户可以在所有终端远程登录,使用的密码是qwe123,并对所有数据库和所有表有操作权限
mysql> show databases;			#查看自己的数据库

三、搭建php服务

安装配置 PHP 解析环境,安装环境依赖包
[root@mayinbin bin]#: cd /opt/
[root@mayinbin opt]#: 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、编译安装

切换到opt目录下解压php软件包
[root@mayinbin opt]#: cd /opt/
[root@mayinbin opt]#: tar zxvf php-7.1.24.tar.gz 

切换到解压好的php目录下进行编译
[root@mayinbin opt]#: cd php-7.1.24/
[root@mayinbin php-7.1.24]#: ./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@mayinbin php-7.1.24]#: make -j4 && make install

3、优化路径

[root@mayinbin php-7.1.24]#: ln -s /usr/local/php/bin/* /usr/local/bin/
[root@mayinbin php-7.1.24]#: ln -s /usr/local/php/sbin/* /usr/local/sbin/

4、调整php文件配置

php有三个配置文件: 
php.ini			主配置文件  
php-fpm.conf	进程服务配置文件 
www.conf		扩展配置文件
4.1 调配主配置文件
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 					#验证安装的模块
[root@mayinbin php-7.1.24]#: cp /opt/php-7.1.24/php.ini-development /usr/local/php/lib/php.ini
[root@mayinbin php-7.1.24]#: vim /usr/local/php/lib/php.ini

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

[root@mayinbin php-7.1.24]#: cd /usr/local/php/etc/
[root@mayinbin etc]#: cp  php-fpm.conf.default php-fpm.conf
[root@mayinbin etc]#: vim php-fpm.conf

调整扩展配置文件
cd /usr/local/php/etc/php-fpm.d/
cp www.conf.default www.conf
[root@mayinbin etc]#: cd /usr/local/php/etc/php-fpm.d/
[root@mayinbin php-fpm.d]#: cp www.conf.default www.conf

5、启动php-fpm

[root@mayinbin php-fpm.d]#: /usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
[root@mayinbin php-fpm.d]#: netstat -anpt | grep 9000
tcp        0      0 127.0.0.1:9000          0.0.0.0:*               LISTEN      42545/php-fpm: mast 

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

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的工作目录
   #fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;  #$document_root 代表当前请求在root指令中指定的值
	include        fastcgi_params;
}

systemctl restart nginx.service

[root@mayinbin php-fpm.d]#: vim /usr/local/nginx/conf/nginx.conf

[root@mayinbin php-fpm.d]#: systemctl restart nginx.service

7、验证php测试页

[root@mayinbin php-fpm.d]#: vim /usr/local/nginx/html/index.php

<?php
phpinfo();
?>

使用浏览器访问http://192.168.63.20/index.php

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

mysql -u root -p
CREATE DATABASE bbs;
GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';
GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'admin123';
flush privileges;

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

浏览器访问

http://192.168.63.20/index.php

替换原来的测试页内容
[root@mayinbin php-fpm.d]#: vim /usr/local/nginx/html/index.php

<?php
$link=mysqli_connect('192.168.63.20','bbsuser','admin123');
if($link) echo "<h1>Success!!</h1>";
else echo "Fail!!";
?>

再次访问http://192.168.63.20/index.php

四、部署论坛

1、解压论坛压缩包

cd /opt
unzip /opt/Discuz_X3.4_SC_UTF8.zip -d /opt/dis
#上传站点更新包
cd /opt/dis/dir_SC_UTF8/
cp -r upload/ /usr/local/nginx/html/bbs

[root@mayinbin opt]#: unzip Discuz_X3.4_SC_UTF8.zip  -d /opt/dis
[root@mayinbin opt]#: cd /opt/dis/dir_SC_UTF8/
[root@mayinbin dir_SC_UTF8]#: cp -r upload/ /usr/local/nginx/html/bbs/

2、调整论坛目录权限

[root@mayinbin dir_SC_UTF8]#: cd /usr/local/nginx/html/bbs/
[root@mayinbin bbs]#: chmod -R 777 ./config/
[root@mayinbin bbs]#: chmod -R 777 ./data/
[root@mayinbin bbs]#: chmod -R 777 ./uc_client/
[root@mayinbin bbs]#: chmod -R 777 ./uc_server/

3、浏览器访问验证

http://192.168.63.20/bbs/install/index.php 

数据库服务器:localhost     ###本地架设就用localhost,如何不是在在本机上就要填写IP地址和端口号
数据库名字:bbs
数据库用户名:bbsuser
数据库密码:admin123
管理员账号:admin
管理员密码:admin123

#论坛内部页面
http://192.168.63.20/bbs/index.php
#论坛后台管理员页面
http://192.168.63.20/bbs/admin.php

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值