当前位置:首页 > 技术文章 > 正文内容

Centos7学习笔记(十九)- lnmp组合的安装与集成

ivker_lee4年前 (2021-10-12)技术文章341

一、安装

学习环境下,nginx采用官方安装

sudo yum install yum-utils

vi /etc/yum.repos.d/nginx.repo

编辑以下内容进去:

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

其中,$releasever填写RHEL/Centos的系统版本

sudo yum install nginx


安装PHP7.1版本

yum install epel-release -y
rpm -ivh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum install php71w php71w-fpm php71w-cli php71w-common php71w-devel php71w-gd php71w-pdo php71w-mysqlnd php71w-mbstring php71w-bcmath php71w-pecl-memcached php71w-pecl-mongodb php71w-pecl-redis php71w-opcache php71w-mcrypt php71w-xml php71w-embbedded

  

二、nginx与php的集成

主要涉及3个指令:fastcgi_pass、fastcgi_index、fastcgi_param。以下是示例来说明用法:

location ~ .*\.php(\/.*)*$ {                      《==========location匹配.php结尾的文件名并匹配其后续参数
             fastcgi_pass unix:/run/php-fpm/www.sock;        《==========fastcg_pass指令指示nginx把php交由谁来处理,这里是交给本地unix类型文件处理。也可以写作127.0.0.1:9000(IP地址加php-fpm运行的端口)            
             fastcgi_index   index.php;                    《==========php程序文件的索引文件是什么
             fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;      《===========这里写法固定。SCRIPT_FILENAME是固定的变量,$document_root$fastcgi_script_name表示把前面定义的root下的php文件名传递出去
             include fastcgi_params;                        《=================这里其实是用include包括了一个文件进来,是/etc/nginx下的factcgi_params文件。
     }

打开/etc/nginx/fastcgi_params文件,可以看到

fastcgi_param  QUERY_STRING       $query_string;

fastcgi_param  REQUEST_METHOD     $request_method;

fastcgi_param  CONTENT_TYPE       $content_type;

fastcgi_param  CONTENT_LENGTH     $content_length;


fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;

fastcgi_param  REQUEST_URI        $request_uri;

fastcgi_param  DOCUMENT_URI       $document_uri;

fastcgi_param  DOCUMENT_ROOT      $document_root;

fastcgi_param  SERVER_PROTOCOL    $server_protocol;

fastcgi_param  REQUEST_SCHEME     $scheme;

fastcgi_param  HTTPS              $https if_not_empty;


fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;

fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;


fastcgi_param  REMOTE_ADDR        $remote_addr;

fastcgi_param  REMOTE_PORT        $remote_port;

fastcgi_param  SERVER_ADDR        $server_addr;

fastcgi_param  SERVER_PORT        $server_port;

fastcgi_param  SERVER_NAME        $server_name;


# PHP only, required if PHP was built with --enable-force-cgi-redirect

fastcgi_param  REDIRECT_STATUS    200;

其实这里用fast_param指令定义了一堆的变量。


三、附件上传大小限制


nginx有一个

client_max_body_size=200m


PHP有2个

php.ini文件中,

post_max_size =200M

upload_max_filesiz =200M

四、集成时的用户与权限


1、ningx进程的用户

默认在/etc/nginx/nginx.conf文件中,

user nginx;

2、php-fpm进程的用户

默认在/etc/php-fpm.d/www.conf文件中

user = apache

group = apache

3、统一新建一个www的用户

sudo groupadd -r -g 49 www

sudo useradd -r -u 49 -g 49 -c "www user" -d /usr/share/www -s /sbin/nologin www

4、给/www/html目录授权

sudo chown -R www:www /www/html/

5、更改上述1、2中的用户后,重启nginx和php-fpm

sudo systemctl restart nginx

sudo systemctl restart php-fpm


以上做的好处:

可以将nfs上的共享目录,rsync的nfs备份目录,都统一授权给www(提前在对应服务器上建立好www账户),解决权限、用户容易混乱的问题。

五、nginx、php和mysql分离


1、需要在新mysql服务器上,授权一个用户远程登录。

grant all privileges on *.* to www@"%" identified by 'Langrenqingge123';

分享给朋友:

相关文章

 Centos7学习笔记(十三)- 一个解压用脚本的详细说明

Centos7学习笔记(十三)- 一个解压用脚本的详细说明

#!/bin/bash cd /home/tar #ls出该目录下的文件,并导出所需文件名到file.log文件中 ls *.tar.gz >file.log ls *.tgz >>file.log 2>/dev/null ls *.tar.bz2 >>file.log 2>/dev/null #统计file.log到底有多少文件 num=$(cat&...

正则表达式超全速查手册

正则表达式超全速查手册

一、校验数字的表达式数字:^[0-9]*$n位的数字:^\d{n}$至少n位的数字:^\d{n,}$m-n位的数字:^\d{m,n}$零和非零开头的数字:^(0|[1-9][0-9]*)$非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})?$正数、负数、和小数:^(\-|\+)?\d+(\.\d+)?$有两位小数的正实数:^[0-9]+(.[0-9]{2})?$有1~3位小数的正实数:^...

Linux学习——Shell

Linux学习——Shell

1、bash解释器csh\ksh\bash都是shell的解释器。2、关于bash的启动和配置环境按上图的理解,正常我们需要把脚本放在开机启动,需要写入的是/etc/bashrc文件或者~/.bashrc文件。另外,关于su  username和su - username的区别(bash的交互式非登录和交互式登录式)。可以参考下图...

Centos7学习笔记(六)——shell编程初步

Centos7学习笔记(六)——shell编程初步

1、shell编程的一些基础a)shell编程有两类变量,                             全局变量(环境变量)——  一般指系统内置的变量,或者手动用export、declare等方式宣称,写入/etc/profile(~./bash_profile、~/bashrc、/etc/bashrc)的全局变量 ...

Centos7学习笔记(四)——grep、sed、awk

Centos7学习笔记(四)——grep、sed、awk

1、grep——print lines matching a pattern打印匹配内容的行(多行)命令格式:grep [参数] 过滤匹配内容 [文件名]或者grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]常用参数:-v 取反过滤 ◆◆-i 忽略大小写  ◆◆(find 命令可以用-iname)-n 对过滤后的内容,显示源文件行号  ◆◆-w 按单词为单位过滤。◆◆-o只输出匹配的内容。◆◆-E使用扩展规则-r...

Centos7学习笔记(二十三)- nginx的keepalived高可用

Centos7学习笔记(二十三)- nginx的keepalived高可用

一、什么是keepalivedkeepalived最初是为LVS设计的,用于管理并监控LVS集群中各个服务节点的状态,后来又加入了可用实现高可用的VRRP协议支持。VRRP是Virtual Router RedundancyProtocol(虚拟路由器冗余协议)的缩写,VRRP出现的目的就是为了解决静态路由单点故障问题的,它能够保证当个别节点宕机时,整个网络可以不间断地运行。这里的VRRP协议,就是纯粹的网络中使用的VRRP协议。二、keepalived工作原理这里说“keepalived工作原...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。