linux7安装lnmp,CentOS7快速安装LNMP环境

CentOS7快速安装LNMP环境

源码编译安装 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-*/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)

start启动

stop停止

list列出

add添加

edit编辑

del删除

exit什么都不做

:配置名称,例如:domain

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

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

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

:是否支持子目录绑定,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)

start添加

list列出

del删除

示例:

添加一个新的备份

[root@localhost ~]# service vbackup start

列出备份文件

[root@localhost ~]# service vbackup list

删除一个备份

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

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值