web服务之源码编译安装 LNMP
Posted 我一个月改一次名
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了web服务之源码编译安装 LNMP相关的知识,希望对你有一定的参考价值。
之前我使用过 Apache 做过 LAMP 服务器平台,也可以使用nginx来做,也就是 LNMP。
一、LNMP相关概念
LNMP就是:Linux系统下 Nginx + mysql + php 这种网站服务器架构。
- 对比 LAMP,其中不同的就是网站服务器程序 ------ Nginx(LNMP)和 Apache(LAMP)
- Nginx 是一个高性能的 HTTP 和 反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。
对比项 | Nginx | Apache |
---|---|---|
配置文件 | 简洁 | 复杂 |
依赖 | Nginx 比 Apache更节省资源 | 占用资源较多 |
一般来说,需要性能的web服务,用 Nginx ,如果不需要性能只求稳定,更考虑 Apache。
Nginx适合静态的网站,Apache适合动态交互的网站。
二、安装Nginx服务
!!!
找一台新机器,记得恢复快照后,重新分运行内存!!!
首先关闭防火墙。
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
vim /etc/sysconfig/selinux
配置本地yum 防火墙
2.1、安装依赖包
yum -y install pcre-devel zlib-devel gcc gcc-c++ make
2.2、创建 nginx 运行用户
useradd -M -s /sbin/nologin nginx
2.3、编译、安装 nginx 软件包
并且安装 Nginx 访问状态统计 status 配置
cd /opt
tar zxvf nginx-1.12.0.tar.gz -C /opt/
cd nginx-1.12.0/
./configure \\
--prefix=/usr/local/nginx \\
--user=nginx \\
--group=nginx \\
--with-http_stub_status_module
make && make install
2.4、优化路径,设置全局变量
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
2.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
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
chmod 754 /lib/systemd/system/nginx.service
systemctl daemon-reload
systemctl start nginx.service
systemctl enable nginx.service
三、安装MySQL服务
3.1 安装Mysql环境依赖包
yum -y install \\
ncurses \\
ncurses-devel \\
bison \\
cmake
3.2、创建运行用户
useradd -M -s /sbin/nologin mysql
3.3、编译安装
这次使用 mysql-boost 集合软件包进行安装
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
#原来只有mysql软件包时,需要手动指定boost的位置,集合包直接在配置中添加
make -j2 && make install
#编译安装时间较长
集合包自带 boost目录
3.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
3.5、更改mysql安装目录和配置文件的属主属组
chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf
3.6、设置路径环境变量
要么创建个软连接,要么如下,直接添加到全局变量中。
echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
source /etc/profile
3.7、初始化数据库
cd /usr/local/mysql/bin/
./mysqld \\
--initialize-insecure \\
--user=mysql \\
--basedir=/usr/local/mysql \\
--datadir=/usr/local/mysql/data
3.8 添加 mysqld 到系统服务
需要将 mysql源目录中的 mysqld.service 放到系统服务目录中
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
systemctl daemon-reload
systemctl start mysqld.service
systemctl enable mysqld
3.9 修改mysql 的登录密码
mysqladmin -u root -p password "abc123"
3.10 授权远程登录
登录到mysql 管理器中,添加命令
mysql -u root -pabc123
grant all privileges on *.* to 'root'@'%' identified by 'abc123';
#授予root用户可以在所有终端远程登录,使用的密码是abc123,并对所有数据库和所有表有操作权限
show databases; #查看当前已有的数据库
四、安装配置 PHP 解析环境
4.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
4.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
#安装时间较长
4.3、路径优化
ln -s /usr/local/php/bin/* /usr/local/bin/
ln -s /usr/local/php/sbin/* /usr/local/sbin/
4.4、调整PHP配置文件
php 有三个配置文件:
- php.ini # 主配置文件
- php-fpm.conf # 进程服务配置文件
- www.conf # fpm扩展配置文件
需要从解压包内 复制一份 配置文件
#调整主配置文件:
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 #验证安装的模块
#调整进程服务配置文件:
cd /usr/local/php/etc/
cp php-fpm.conf.default php-fpm.conf
vim php-fpm.conf
--17行--去掉";"注释
pid = run/php-fpm.pid
#调整扩展配置文件:
cd /usr/local/php/etc/php-fpm.d/
cp www.conf.default www.conf
生成 fpm 的配置文件
4.5、启动 php-fpm
/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
#-c 指定主配置文件来进行加载
netstat -anpt | grep 9000
#PHP-FPM(FastCGI Process Manager:FastCGI 进程管理器)是一个 PHPFastCGI 管理器,
由于【Nginx服务器不能处理动态页面】,需要由 Nginx 把动态请求交给 php-fpm 进程进行解析。
#将 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
手动到配置目录下启动 fpm
添加到系统服务中
4.6、配置 Nginx 支持 PHP 解析
修改 Nginx 配置文件,让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;
}
# ~ 表示正则表达式
# \\.php$ 表示过滤所有以 .php结尾的路径,进行处理转发
systemctl restart nginx.service
放开 php 注释,修改nginx 站点目录
重启nginx 服务
4.7、验证 PHP 测试页
nginx 主站点创建php文件,用来测试 Nginx 支持 PHP 解析
vim /usr/local/nginx/html/index.php
<?php
phpinfo();
?>
浏览器访问
http://192.168.31.101/index.php
nginx 中配置 php 成功
4.8、验证 mysql 数据库工作是否正常
测试 php 和 mysql 是否正常工作
创建一个数据库bbs,将 远程链接数据库的权限给 用户 bbsuser。
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.31.101','bbsuser','abc123');
if($link) echo "<h1>Success!!</h1>";
else echo "Fail!!";
?>
浏览器访问
http://192.168.31.101/index.php
五、部署 Discuz!社区论坛 Web 应用
cd /opt
unzip Discuz_X3.4_SC_UTF8.zip [-d /opt/dis 指定解压目录]
cd /opt/dis/dir_SC_UTF8/
cp -r upload/ /usr/local/nginx/html/bbs/
#调整论坛目录的权限:
cd /usr/local/nginx/html/bbs/
chown -R nginx ./config/
chown -R nginx ./data/
chown -R nginx ./uc_client/
chown -R nginx ./uc_server/
或
chmod -R 777 ./config/
chmod -R 777 ./data/
chmod -R 777 ./uc_client/
chmod -R 777 ./uc_server/
论坛页面访问
http://192.168.31.101/bbs/install/index.php
----------------------------------------------------------------------------------------------------------
数据库服务器:localhost ###本地架设就用localhost,如何不是在在本机上就要填写IP地址和端口号
数据库名字:bbs
数据库用户名:bbsuser
数据库密码:abc123
管理员账号:admin
管理员密码:abc123
----------------------------------------------------------------------------------------------------------
以上是关于web服务之源码编译安装 LNMP的主要内容,如果未能解决你的问题,请参考以下文章
企业网站应用模式之—LNMP架构的源码编译超详细步骤,有手就行!