阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

CentOS7快速安装搭建LNMP环境

453次阅读
没有评论

共计 6414 个字符,预计需要花费 17 分钟才能阅读完成。

源码编译安装 LNMP 环境虽然便于自定义,但是对于小型服务器来说,漫长的编译时间让人无法等待。如果能在 10 分钟内搞定环境安装,那就很好了。

1、配置 yum 源

CentOS 7 的 默认 yum 源里的软件包版本可能不是最新的,如果要安装最新的软件包就得配置下 yum 源。

配置 yum 源可以通过直接安装 rpm (Red Hat Package Manager) 包,或者修改 Repository,本文讲解通过安装 rpm 方式。

1.1、安装 epel 源

首先需要安装 EPEL (Extra Packages for Enterprise Linux) yum 源,用以解决部分依赖包不存在的问题

[root@localhost ~]# yum -y install epel-release

1.2、安装 MySQL 源

官方安装 MySQL 源参考网址

https://dev.mysql.com/doc/mysql-repo-excerpt/5.6/en/linux-installation-yum-repo.html

安装 rpm 包前需要导入 rpm-GPG-KEY 文件,不然安装过程会出错。将 MySQL rpm-GPG-KEY 另存为 mysql_pubkey.asc 并导入

[root@localhost ~]# rpm –import mysql_pubkey.asc

导入后安装 CentOS 7 的 MySQL rpm 包

[root@localhost ~]# rpm -Uvh http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm

1.3、安装 PHP 源

PHP 最新的 rpm 官方 yum 源包地址

http://rpms.remirepo.net/

导入 PHP rpm-GPG-KEY (remi)

[root@localhost ~]# rpm –import http://rpms.remirepo.net/rpm-GPG-KEY-remi

安装 PHP rpm (remi) 包

[root@localhost ~]# rpm -Uvh http://remi.mirrors.arminco.com/enterprise/remi-release-7.rpm

1.4、安装 Nginx 源

官方安装 Nginx 源参考网址

http://nginx.org/en/linux_packages.html

导入 Nginx rpm-GPG-KEY

[root@localhost ~]# rpm –import http://nginx.org/packages/keys/nginx_signing.key

安装 Nginx rpm 包

[root@localhost ~]# rpm -Uvh http://nginx.org/packages/centos/7/noarch/rpmS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

到目前为止,yum 源已经安装好了,接着进行下一步的配置。

2、修改相关的 yum 源文件

MySQL yum 源默认是启用的 MySQL-5.6,PHP yum 源默认都没有启用,Nginx yum 源默认是启用的 Nginx-1.8。定位到 /etc/yum.repos.d/,对后缀为 .repo 的文件进行编辑,修改 enabled 为 1 以启用。

2.1、启用 PHP-7.0 的 yum 源

1、修改 /etc/yum.repos.d/remi.repo,将 [remi] 和 [remi-test] 下面的 enabled=0 改为 enabled=1;

2、修改 /etc/yum.repos.d/remi-php70.repo,将 [remi-php70] 下面的 enabled=0 改为 enabled=1;

[root@localhost ~]# sed -i “/remi\/mirror/{n;s/enabled=0/enabled=1/g}” /etc/yum.repos.d/remi.repo

[root@localhost ~]# sed -i “/test\/mirror/{n;n;s/enabled=0/enabled=1/g}” /etc/yum.repos.d/remi.repo

[root@localhost ~]# sed -i “/php70\/mirror/{n;s/enabled=0/enabled=1/g}” /etc/yum.repos.d/remi-php70.repo

到这一步 yum 配置就算完成了,清除并生成 yum 缓存使之生效:

[root@localhost ~]# yum clean all

[root@localhost ~]# yum makecache

3、安装 MySQL + PHP + Nginx + phpMyAdmin

yum 源已经配置好了,现在直接安装 MySQL + PHP + Nginx + phpMyAdmin

[root@localhost ~]# yum install -y mysql-community-server nginx php php-bcmath php-fpm php-gd php-json php-mbstring php-mcrypt php-mysqlnd php-opcache php-pdo php-pdo_dblib php-pgsql php-recode php-snmp php-soap php-xml php-pecl-zip phpMyAdmin

注:上面安装的 php-* 可以根据实际使用情况选择安装

4、修改 MySQL + PHP + Nginx + phpMyAdmin 的配置文件

安装完成后,进行下一步的环境配置。

MySQL 配置文件在 /etc/my.cnf.d/

PHP 配置文件在 /etc/php-fpm.d/

Nginx 配置文件在 /etc/nginx/

phpMyAdmin 的配置文件在 /etc/phpMyAdmin/

4.1、配置 MySQL

MySQL 配置文件保持默认,运行一次安全配置即可。

4.1.1、启动 MySQL

[root@localhost ~]# systemctl start mysqld.service

4.1.2、安全配置 MySQL

设置 root 密码、删除匿名用户、禁止 root 远程登录、删除 test 数据库、重新加载权限表,一路 Y 下去

[root@localhost ~]# mysql_secure_installation

4.2、配置 PHP

PHP 默认配置文件使用的是监听 9000 端口进行通信,针对小型单一、没有做负载均衡的服务器,可以使用 unix sock 方式通信。使用 unix sock 方式需要修改 PHP 配置文件。

# 更换监听方式

listen = /dev/shm/php-fpm-default.sock

# 监听队列最大长度为不限

listen.backlog = -1

# 指定监听用户和用户组(需存在)

listen.owner = www

listen.group = www

启动 PHP-FPM:

[root@localhost ~]# systemctl start php-fpm.service

4.3、配置 Nginx

让服务器默认访问显示为 400 提示页。

新建名为 nginx-default.conf 的配置文件

[root@localhost ~]# touch /etc/nginx/conf.d/nginx-default.conf

编辑配置文件

[root@localhost ~]# vim /etc/nginx/conf.d/nginx-default.conf

# 将以下信息输入到 nginx-default.conf

server

{

    listen 80 default;

    return 400;

}

防火墙放行 HTTP 端口访问:

firewall-cmd –permanent –zone=public –add-service=http

firewall-cmd –reload

启动 Nginx

[root@localhost ~]# systemctl start nginx.service

这时,在浏览器地址栏输入当前服务器 IP 就会看到一个 400 的提示页面了。

4.4、绑定域名 + 站点目录 + 保存日志 + 运行 PHP 的配置文件

server

{

    #监听 80 端口

listen 80;

# 绑定域名 default.com 和 www.default.com

server_name default.com www.default.com;

# 设置首页文件,越前优先级越高

index index.html index.htm index.php;

# 设置网页编码

charset utf-8;

# 设置站点根目录

    root  /home/wwwroot/default;

    #运行 PHP

    location ~ .*\.php$

    {

        #默认使用 9000 端口和 PHP 通信

fastcgi_pass  127.0.0.1:9000

        #使用 unix sock 和 PHP 通信

#fastcgi_pass  unix:/dev/shm/php-fpm-default.sock;

        fastcgi_index index.php;

        #PHP 文档根目录

  fastcgi_param DOCUMENT_ROOT  /home/wwwroot/default;

        #PHP 脚本目录

fastcgi_param SCRIPT_FILENAME  /home/wwwroot/default$fastcgi_script_name;

        include fastcgi_params;

        try_files $uri = 404;

    }

    #设置文件过期时间

    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|mp3|wma)$

    {

        expires      30d;

    }

    #设置文件过期时间

    location ~ .*\.(js|css)$

    {

        expires      12h;

    }

    #设置文件访问权限

    location ~* /templates(/.*)\.(bak|html|htm|ini|old|php|tpl)$ {

        allow 127.0.0.1;

        deny all;

    }

    #设置文件访问权限

    location ~* \.(ftpquota|htaccess|htpasswd|asp|aspx|jsp|asa|mdb)?$ {

        deny all;

    }

    #保存日志

    access_log /var/log/nginx/default-access.log main;

    error_log /var/log/nginx/default-error.log crit;

}

4.5、配置 phpMyAdmin

[root@localhost ~]# vi etc/phpMyAdmin/config.inc.php

修改以下内容:

$cfg[‘Servers’][$i][‘host’] = ‘localhost’;

$cfg[‘Servers’][$i][‘port’] = ‘3306’;

$cfg[‘Servers’][$i][‘socket’] = ‘/var/lib/mysql/mysql.sock’;

$cfg[‘Servers’][$i][‘connect_type’] = ‘socket’;

$cfg[‘Servers’][$i][‘extension’] = ‘mysqli’;

$cfg[‘Servers’][$i][‘auth_type’] = ‘cookie’;

$cfg[‘UploadDir’] = ‘/tmp’;

$cfg[‘SaveDir’] = ‘/tmp’;

如果 Nginx 使用的是上面的进阶代码,那么把 phpMyAdmin 的目录 复制到 /home/wwwroot/default/phpMyAdmin/ 下面,就可通过 http://default.com/phpMyAdmin 访问了

复制 phpMyAdmin 目录

[root@localhost ~]# cp -a /usr/share/phpMyAdmin /home/wwwroot/default/

替换连接形式为目录

[root@localhost ~]# rm -rf /home/wwwroot/default/phpMyAdmin/doc/html

[root@localhost ~]# cp -a /usr/share/doc/phpMyAdmin-<span>*</span>/html /home/wwwroot/default/phpMyAdmin/doc/

5、一键脚本

上面已经讲解了如何配置和安装,但是不能每次都这么一步一步来吧?为了节省时间,写了一个一键安装管理脚本,可选择安装 Nginx 1.8/1.9、MySQL 5.5/5.6/5.7 和 PHP 5.5/5.6/7.0

安装

[root@localhost ~]# yum install -y unzip

[root@localhost ~]# wget https://github.com/maicong/LNMP/archive/master.zip

[root@localhost ~]# unzip master.zip

[root@localhost ~]# cd LNMP-master

[root@localhost ~]# bash lnmp.sh

输出到指定文件

[root@localhost ~]# bash lnmp.sh 2>&1 | tee lnmp.log

管理站点

[root@localhost ~]# service vhost (start,stop,list,add,edit,del,exit) <domain> <server_name> <index_name> <rewrite_file> <host_subdirectory>

start 启动

stop 停止

list 列出

add 添加

edit 编辑

del 删除

exit 什么都不做

<domain>: 配置名称,例如:domain

<server_name>: 域名列表,例如:domain.com,www.domain.com

<index_name>: 首页文件,例如:index.html,index.htm,index.php

<rewrite_file>: 伪静态规则文件,保存在 /etc/nginx/rewrite/ 例如:nomal.conf

<host_subdirectory>: 是否支持子目录绑定,on 或者 off

示例:

添加一个标识为 domain 的站点

[root@localhost ~]# service vhost add domain domain.com,www.domain.com index.html,index.htm,index.php nomal.conf on

启动标识为 domain 的站点

[root@localhost ~]# service vhost start domain

停止标识为 domain 的站点

[root@localhost ~]# service vhost stop domain

编辑标识为 domain 的站点

[root@localhost ~]# service vhost edit domain

删除标识为 domain 的站点

[root@localhost ~]# service vhost del domain

列出所有站点

[root@localhost ~]# service vhost list

备份数据

[root@localhost ~]# service vbackup (start,list,del) <delete name.tar.gz>

start 添加

list 列出

del 删除

示例:

添加一个新的备份

[root@localhost ~]# service vbackup start

列出备份文件

[root@localhost ~]# service vbackup list

删除一个备份

[root@localhost ~]# service vbackup del name.tar.gz

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计6414字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7982219
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
【1024程序员】我劝你赶紧去免费领一个AWS、华为云等的主机

【1024程序员】我劝你赶紧去免费领一个AWS、华为云等的主机

【1024 程序员】我劝你赶紧去免费领一个 AWS、华为云等的主机 每年 10 月 24 日,程序员们都会迎来...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
飞牛NAS玩转Frpc并且配置,随时随地直连你的私有云

飞牛NAS玩转Frpc并且配置,随时随地直连你的私有云

飞牛 NAS 玩转 Frpc 并且配置,随时随地直连你的私有云 大家好,我是星哥,最近在玩飞牛 NAS。 在数...
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛 NAS-12:开源笔记的进化之路,效率玩家的新选择 前言 如何高效管理知识与笔记,已经成为技术...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛 NAS 硬件 03:五盘位 +N5105+ 双网口的成品 NAS 值得入手吗 前言 大家好,我...
你的云服务器到底有多强?宝塔跑分告诉你

你的云服务器到底有多强?宝塔跑分告诉你

你的云服务器到底有多强?宝塔跑分告诉你 为什么要用宝塔跑分? 宝塔跑分其实就是对 CPU、内存、磁盘、IO 做...
免费无广告!这款跨平台AI RSS阅读器,拯救你的信息焦虑

免费无广告!这款跨平台AI RSS阅读器,拯救你的信息焦虑

  免费无广告!这款跨平台 AI RSS 阅读器,拯救你的信息焦虑 在算法推荐主导信息流的时代,我们...
星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定! 前言 作为 NAS 玩家,你是否总被这些...
自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个 AI 智能体 — 跟创业大佬对话 前言 智能体(Agent)已经成为创业者和技术人绕...