看好吧,如何部署安装LNMP架构!一口气全告诉你!

该博客详细介绍了如何在Linux系统中从源码编译安装Nginx、MySQL和PHP,包括依赖包的安装、用户创建、配置文件修改、服务添加等步骤,并演示了如何配置Nginx支持PHP解析以及验证PHP和数据库的正常工作。最后,部署了Discuz!社区论坛web应用。


安装Nginx服务

安装依赖包

yum -y install pcre-devel zlib-devel gcc gcc-c++ make

创建运行用户

useradd -M -s /sbin/nologin nginx

编译安装

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

优化路径

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

添加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 start nginx.service
systemctl enable nginx.service

安装MySQL服务

安装Mysql环境依赖包

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

创建运行用户

useradd —M -s /sbin/nologin mysql

编译安装

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

修改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
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

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

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

设置路径环境变量

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

初始化数据库

cd /usr/local/mysql/bin/
./mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data

添加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

修改mysql的登录密码

mysqladmin -u root -p password "123456"

授权远程登录

mysql -u root -p

安装配置 PHP解析环境

安装环境依赖包

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

编译安装

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

路径优化

ln -s /usr/local/php/bin/* /usr/local/bin/

调整PHP配置文件

php有三个配置文件:

php.ini 主配置文件
php-fpm.conf 进程服务配置文件
www.conf 扩展配置文件

调整主配置文件:

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

启动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进程进行解析。

配置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

验证PHP 测试页

vim /usr/local/nginx/html/index.php
<?php
phpinfo ();
?>

浏览器访问

http ://192.168.101.15/index.php

验证数据库工作是否正常

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.101.15','bbsuser','admin123');
if($link) echo "<h1>success!!</h1>";
else echo "Fail!!";
?>

浏览器访问

http://192.168.101.15/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 root:nginx ./config/
chown -R root:nginx ./data/
chown -R root:nginx ./uc_client/
chown -R root:nginx ./uc_server/

chmod -R 777 ./config/
chmod -R 777 ./data/
chmod -R 777 ./uc_client/
chmod -R 777 ./uc_server/

论坛页面访问

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

数据库服务器:localhost 本地架设就用localhost,如果不是在在本机上就要填写IP地址和端口号
数据库名字: bbs
数据库用户名:bbsuser

<think> 我们之前已经使用Docker Compose部署LNMP架构,现在需要添加NFS服务器以实现容器间的数据共享(特别是网站文件和数据库数据的共享)。 目标:在Docker Swarm集群中,使用NFS作为共享存储,实现LNMP各容器(NginxPHPMySQL)的数据持久化和共享。 步骤: 1. 搭建NFS服务器(在宿主机上或专用服务器) 2. 配置NFS共享目录(包括网站文件目录、MySQL数据目录、Nginx配置文件目录等) 3. 在Docker节点(运行LNMP服务的宿主机)上安装NFS客户端并挂载共享目录 4. 修改Docker Compose文件,将容器内的数据卷指向挂载的NFS目录 注意:如果使用Docker Swarm,则每个节点都需要能够访问NFS服务器。 详细步骤: ### **1. 搭建NFS服务器** 假设我们在IP为192.168.1.100的服务器上搭建NFS服务。 ```bash # 安装NFS服务端 sudo apt-get install nfs-kernel-server -y # 创建共享目录 sudo mkdir -p /nfs/data/lnmp/{www,mysql,nginx} # 设置目录权限(根据实际需求) sudo chown nobody:nogroup /nfs/data/lnmp -R sudo chmod 777 /nfs/data/lnmp -R # 配置NFS导出目录 echo "/nfs/data/lnmp *(rw,sync,no_root_squash,no_subtree_check)" | sudo tee -a /etc/exports # 使配置生效 sudo exportfs -a sudo systemctl restart nfs-kernel-server ``` ### **2. 在Docker节点上安装NFS客户端并挂载** 在每个运行Docker服务的节点(包括Swarm集群中的节点)上执行: ```bash # 安装NFS客户端 sudo apt-get install nfs-common -y # 创建本地挂载点 sudo mkdir -p /mnt/nfs/lnmp/{www,mysql,nginx} # 挂载NFS共享目录 sudo mount -t nfs 192.168.1.100:/nfs/data/lnmp/www /mnt/nfs/lnmp/www sudo mount -t nfs 192.168.1.100:/nfs/data/lnmp/mysql /mnt/nfs/lnmp/mysql sudo mount -t nfs 192.168.1.100:/nfs/data/lnmp/nginx /mnt/nfs/lnmp/nginx # 设置开机自动挂载 echo "192.168.1.100:/nfs/data/lnmp/www /mnt/nfs/lnmp/www nfs defaults 0 0" | sudo tee -a /etc/fstab echo "192.168.1.100:/nfs/data/lnmp/mysql /mnt/nfs/lnmp/mysql nfs defaults 0 0" | sudo tee -a /etc/fstab echo "192.168.1.100:/nfs/data/lnmp/nginx /mnt/nfs/lnmp/nginx nfs defaults 0 0" | sudo tee -a /etc/fstab ``` ### **3. 修改Docker Compose文件** 将原来的本地卷改为使用NFS挂载点: ```yaml version: '3.8' services: nginx: image: nginx:alpine ports: - "80:80" volumes: - /mnt/nfs/lnmp/www:/var/www/html # 使用NFS挂载的目录 - /mnt/nfs/lnmp/nginx/conf.d:/etc/nginx/conf.d # NFS共享的nginx配置 depends_on: - php networks: - lnmp-net php: build: ./php volumes: - /mnt/nfs/lnmp/www:/var/www/html # 与nginx共享网站文件 networks: - lnmp-net mysql: image: mysql:8.0 environment: MYSQL_ROOT_PASSWORD: rootpass MYSQL_DATABASE: app_db MYSQL_USER: app_user MYSQL_PASSWORD: userpass volumes: - /mnt/nfs/lnmp/mysql:/var/lib/mysql # NFS共享的MySQL数据目录 networks: - lnmp-net networks: lnmp-net: driver: bridge ``` ### **4. 启动服务** 在Docker Swarm集群中,使用stack部署: ```bash docker stack deploy -c docker-compose.yml lnmp ``` 或者在单机模式下使用docker-compose: ```bash docker-compose up -d ``` ### **5. 验证NFS共享** 验证方法: - 在NFS服务器上查看共享目录中是否有数据生成(如MySQL数据文件、网站文件等) - 在多个Docker节点上,如果服务被调度到不同节点,它们应该能够通过NFS共享访问相同的数据 注意事项: 1. **权限问题**:确保NFS共享目录的权限允许容器内的用户(如mysql容器中的mysql用户,nginx容器中的nginx用户)读写。在NFS服务器上设置`no_root_squash`可以避免root用户被映射为nobody,但需注意安风险。 2. **网络延迟**:NFS共享可能带来网络延迟,对于数据库(如MySQL)在高并发场景下可能会有性能影响,建议对数据库使用本地SSD存储或专用存储方案。 3. **高可用**:NFS服务器可能成为单点故障,建议使用高可用NFS(如DRBD+Heartbeat)或分布式文件系统(如GlusterFS, Ceph)替代。 ### **相关问题** 1. 如何优化Docker容器使用NFS的性能? 2. 在Docker Swarm集群中如何确保NFS挂载的高可用? 3. 除了NFS,还有哪些共享存储方案适合Docker容器? 4. 如何解决NFS共享中的文件权限问题? </think> ### 为 Docker LNMP 架构部署 NFS 服务器实现数据共享 #### **1. NFS 服务器部署** ```bash # 在 NFS 服务器执行(假设 IP: 192.168.1.100) sudo apt install nfs-kernel-server -y # 创建共享目录 sudo mkdir -p /nfs/lnmp/{www,mysql,nginx} sudo chown nobody:nogroup /nfs/lnmp -R sudo chmod 777 /nfs/lnmp -R # 配置共享目录权限 echo "/nfs/lnmp *(rw,sync,no_subtree_check,no_root_squash)" | sudo tee -a /etc/exports # 重启服务 sudo exportfs -a sudo systemctl restart nfs-kernel-server ``` #### **2. Docker 节点挂载 NFS** ```bash # 在所有 Docker 节点执行 sudo apt install nfs-common -y # 创建本地挂载点 sudo mkdir -p /mnt/nfs/{www,mysql,nginx} # 配置开机自动挂载 echo "192.168.1.100:/nfs/lnmp/www /mnt/nfs/www nfs defaults 0 0" | sudo tee -a /etc/fstab echo "192.168.1.100:/nfs/lnmp/mysql /mnt/nfs/mysql nfs defaults 0 0" | sudo tee -a /etc/fstab echo "192.168.1.100:/nfs/lnmp/nginx /mnt/nfs/nginx nfs defaults 0 0" | sudo tee -a /etc/fstab # 立即挂载 sudo mount -a ``` #### **3. 修改 Docker Compose 配置** ```yaml version: '3.8' services: nginx: volumes: - /mnt/nfs/www:/var/www/html # 网站文件 - /mnt/nfs/nginx:/etc/nginx/conf.d # Nginx配置 php: volumes: - /mnt/nfs/www:/var/www/html # 共享网站文件 mysql: volumes: - /mnt/nfs/mysql:/var/lib/mysql # 数据库数据 ``` #### **4. 验证 NFS 共享** ```bash # 在 NFS 服务器创建测试文件 echo "NFS TEST" | sudo tee /nfs/lnmp/www/test.txt # 在任意 Docker 节点验证 cat /mnt/nfs/www/test.txt # 应显示 "NFS TEST" # 在容器内验证 docker exec -it lnmp_nginx_1 cat /var/www/html/test.txt ``` #### **5. 安加固建议** 1. 限制 NFS 访问 IP: ```bash # /etc/exports 修改为 /nfs/lnmp 192.168.1.0/24(rw,sync,no_root_squash) ``` 2. 启用防火墙: ```bash sudo ufw allow from 192.168.1.0/24 to any port nfs ``` ### **关键说明** - **数据一致性**:NFS 的 `sync` 参数确保数据实时写入磁盘[^1] - **性能优化**:对数据库等高 IO 应用,建议额外添加 `async` 和 `no_wdelay` 参数 - **权限控制**:`no_root_squash` 允许容器以 root 身份操作文件,生产环境建议用用户映射替代 ### **相关问题** 1. 如何解决 NFS 挂载时出现的 "Permission Denied" 错误? 2. NFS 与 GlusterFS 在容器存储中的性能对比有何差异? 3. 如何监控 Docker 容器的 NFS 存储使用情况? 4. 在 Kubernetes 集群中如何实现类似的共享存储方案? 5. NFS 共享如何配置 Kerberos 身份验证提升安性? [^1]: 参考 Linux NFS 官方文档:数据同步机制与性能优化建议。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值