LNMP搭建

一、预备环境

关闭防火墙,关闭安全机制

[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# iptables -F
[root@localhost ~]# setenforce 0

二、搭建Nginx服务

1、支持的软件包pcre-devel、zlib-devel、openssl-devel(支持加密)、gcc、gcc-c++、make

devel包主要是供开发用,包含普通包,devel包中包含头文件和链接库,如果是需要动态链接库的话,两种包都需要有。

[root@localhost ~]# yum -y install pcre-devel zlib-devel openssl-devel

2、创建nginx用户和组

[root@localhost ~]# useradd -M -s /sbin/nologin nginx

3、解压安装包并指定位置

[root@localhost ~]# tar -xf nginx-1.16.0.tar.gz -C /usr/src/

4、编译安装

[root@localhost ~]# cd /usr/src/nginx-1.16.0/ 
[root@localhost nginx-1.16.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module --with-http_ssl_module --with-http_flv_module --with-http_gzip_static_module && make && make install
--prefix //设定nginx的安装目录
--user和--group //指定nginx运行用户和组
--with-http_stub_status_module //启用模块支持状态统计
--with-http_ssl_module //启用ssl模块
--with-http_flv_module //提供寻求内存使用基于时间的偏移量文件

5、为主程序nginx创建链接文件

[root@localhost ~]# ls /usr/local/nginx/
  logs        sbin       conf              html          
[root@localhost ~]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
[root@localhost ~]# ll /usr/local/sbin/nginx

6、nginx的运行控制

nginx -t    检测配置文件的语法

[root@localhost ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@localhost ~]# nginx
[root@localhost ~]# netstat -anpt | grep :80
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      13134/nginx: master

重启服务

[root@localhost ~]# killall -HUP nginx

三、nginx配置文件(nginx.conf)分析

在nginx服务器的主配置文件nginx.conf中,包括全局配置、I/O时间配置、HTTP配置三大内容

配置格式:关键字 值;    //末尾以分号表示结束,以#开始的部分表示注释

1、全局配置

常用配置项:

user nginx [nginx];    //nginx的程序用户及程序组,若编译时未指定则默认为nobody

worker_processes 2;     //指定nginx要指定的进程数量,每个进程要耗费10M-20M内存,一般与CPU核心数相等

worker_cpu_affinity 01 10;   //双核CPU(0001 0010 0100 1000;四核) CPU的分配问题

worker_rlimit_nofile 102400;    //一个进程可以打开的最多文件数目,数值与ulimit -n(系统最多打开的文件数量)保持一致就好

error_log logs/error.log;    //错误日志的记录级别

pid logs/nginx.pid;      //指定PID文件的位置

2、I/O事件配置

使用"events{ }"界定标记,指定nginx进程的I/O响应模式,每个进程的连接数等

events {

      use  epoll;      //用来设定nginx的工作模式
      worker_connections 4096//用于定义nginx的最大连接数,默认1024

}

3、HTTP配置

用"http{ }"界定,设置访问日志、HTTP端口、网页目录、默认字符集、连接保持、虚拟web主机、PHP解析,server{ }配置段设置特定网络

http {
    include       mime.types;
default_type  application/octet-stream;

log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

access_log  logs/access.log  main;     //客户端访问日志记录位置
sendfile        on;                    //支持文件发送(上传下载)
keepalive_timeout  65;                 //连接保持的时间

    server {                                //web服务的监听配置
        listen       80;                    //定义虚拟主机的服务器接口(192.168.200.111:80)
server_name  www.crushlinux.com;            //网站名称(FQDN)
        charset utf-8;                       //网页的默认字符集

        location / {                        //跟目录配置
            root   html;                    //网站根目录的位置安装位置的html中
            index  index.html index.htm;    //默认首页(索引页)
        }

error_page   500 502 503 504  /50x.html;    //内部错误的反馈页面
        location = /50x.html {               //错误页面配置
            root   html;
        }
    }
}

4、状态统计模块

[root@nginx~]# vim /usr/local/nginx/conf/nginx.conf
//在http中写
location ~ /status {
stub_status on;        //打开状态统计功能
access_log off;        //关闭此位置的日志记录
}
[root@nginxconf]#killall -HUP nginx     //重启nginx服务

四、创建mysql数据库

1、查看所需的软件

 rpm -q mysql mysql-server mariadb mairadb-server \如果有 rpm -e 卸载 无法卸载 --nodeps(不验证依赖关系)
[root@localhost ~]# rpm -q ncurses-devel   //检测安装包

2、若没有安装

[root@localhost ~]# yum -y install ncurses-devel  //用yum安装软件包

3、新建一个mysql用户和组

[root@localhost ~]# useradd -M -s /sbin/nologin mysql    //创建一个用户组

4、安装cmake

[root@localhost ~]# yum -y install cmake    //安装编译命令

5、编译安装mysql数据库

[root@localhost ~]# tar -xf mysql-5.7.24.tar.gz -C /usr/src/    //解压Msyql软件包并指定解压位置
[root@localhost ~]# cd /usr/src/mysql-5.7.24/      //进入解压后路径内
//编译安装
[root@localhost mysql-5.7.24]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc && make && make install

  -DCMAKE_INSTALL_PREFIX=/usr/local/mysql //数据库程序安装目录

  -DDEFAULT_CHARSET=utf8 //指定字符集编码

  -DDEFAULT_COLLATION=utf8_general_ci //默认的字符集校对规则,utf8_general_ci适用于utf-8字符集的通用规则

  -DWITH_EXTRA_CHARSETS=all //指定额外支持的字符集编码

  -DSYSCONFDIR=/etc //指定配置文件存放目录

报错处理:

------------------------------------------------------------------------------

CMake Error at cmake/boost.cmake:81 (MESSAGE):

You can download it with -DDOWNLOAD_BOOST=1 -DWITH_BOOST=<directory>

This CMake script will look for boost in <directory>. If it is not there,

it will download and unpack it (in that directory) for you.

 If you are inside a firewall, you may need to use an http proxy:

 export http_proxy=http://example.com:80

 Call Stack (most recent call first):

cmake/boost.cmake:238 (COULD_NOT_FIND_BOOST)

CMakeLists.txt:507 (INCLUDE)

 -- Configuring incomplete, errors occurred!

See also "/usr/src/mysql-5.7.24/CMakeFiles/CMakeOutput.log".

See also "/usr/src/mysql-5.7.24/CMakeFiles/CMakeError.log".

------------------------------------------------------------------------------

在执行时如果报一个boost软件的错误,进行如下操作

[root@localhost ~]# mkdir /usr/local/boost/       //创建一个文件夹boost
[root@localhost ~]# cd /usr/local/boost/            //进入文件夹
[root@localhost boost]# tar -xf boost_1_59_0.tar.gz         //在当前位置解压boost软件包
[root@localhost boost]# cd /usr/src/mysql-5.7.24/          //回到Mysql安装路径
[root@localhost mysql-5.7.24]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc -DWITH_BOOST=/usr/local/boost/ && make && make install

6、修改用户和组

[root@localhost mysql-5.7.24]# chown -R mysql:mysql /usr/local/mysql/  

7、建立配置文件

[root@localhost ~]# vim /etc/my.cnf           //修改Mysql主配置文件
[mysqld]
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock

[mysqld_safe]
log-error=/usr/local/mysql/data/mysql.log
pid-file=/usr/local/mysql/data/mysql.pid

8、初始化数据库

[root@localhost ~]# /usr/local/mysql/bin/mysqld --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data --initialize   //初始化并留下密码(后面会用密码要记住)     

2019-09-10T16:36:34.384265Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2019-09-10T16:36:34.631107Z 0 [Warning] InnoDB: New log files created, LSN=45790
2019-09-10T16:36:34.673027Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
2019-09-10T16:36:34.733541Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 270a4236-d3e9-11e9-96bf-000c299b5cf0.
2019-09-10T16:36:34.734738Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.
2019-09-10T16:36:34.735658Z 1 [Note] A temporary password is generated for root@localhost: yR1jAfi)xCd%

 --basedir=/usr/local/mysql/ //指定安装目录(产品目录)

  --datadir=/usr/local/mysql/data //指定数据目录

  --user=mysql //指定用户身份

9、修改文件、添加变量

[root@localhost ~]# vim /etc/profile      //开机启动加载文件
PATH=$PATH:/usr/local/mysql/bin         //设置变量

[root@localhost ~]# source /etc/profile    //重新加载文件

10、复制服务脚本

[root@localhost ~]# cp /usr/src/mysql-5.7.24/support-files/mysql.server /etc/init.d/mysqld 

11、加权限,开启数据库

[root@localhost ~]# chmod +x /etc/init.d/mysqld      //给脚本执行权限
[root@localhost ~]# /etc/init.d/mysqld start          //开启数据库

[root@localhost ~]# /etc/init.d/mysqld restart        //重新启动服务

12、为数据库修改密码

[root@localhost ~]# mysql -u root -p'yR1jAfi)xCd%'     //使用原始密码进入数据库
[root@localhost ~]# mysqladmin -u root -p'yR1jAfi)xCd%' password '123123'   //更改数据库密码
[root@localhost ~]# mysql -uroot -p123123            //用新密码进入数据库

五、PHP安装

较新版本(如5.6)的PHP已经自带FPM(fastCGI process manager,FastCGI进程管理器)模块,用来对PHP解析实例进行管理,优化解析效率,因此在配置PHP编译选项时应添加"--enable-fpm"以启用此模块。

 为了提高PHP解析效率,建议将相应版本的ZendGuardLander也装上。

1、安装支持软件

[root@localhost ~]# yum -y install gd libxml2-devel libjpeg-devel libpng-devel 

2、编译安装PHP

[root@localhost ~]# tar -xf php-5.6.39.tar.gz -C /usr/src/      //解压软件包
[root@localhost ~]# cd /usr/src/php-5.6.39/      //进入解压后路径
[root@localhost php-5.6.39]# ./configure --prefix=/usr/local/php5 --with-gd --with-zlib --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-config-file-path=/usr/local/php5 --enable-mbstring --enable-fpm --with-jpeg-dir=/usr/lib && make && make install  //编译安装

3、安装后优化

[root@localhost php-5.6.39]# cp /usr/src/php-5.6.39/php.ini-production /usr/local/php5/php.ini   //复制配置文件
[root@localhost php-5.6.39]# ln -s /usr/local/php5/sbin/* /usr/local/sbin/          //链接命令文件
[root@localhost php-5.6.39]# ln -s /usr/local/php5/bin/* /usr/local/sbin/           //链接命令文件

4、安装ZendGuardLoader(注意:若是64位系统,该软件得到其官网下载64位的相应软件包,若用32位的就会报错。下载地址:http://www.zend.com/en/products/guard/downloads)

[root@localhost ~]# tar -xf zend-loader-php5.6-linux-x86_64_update1.tar.gz -C /usr/src/      //安装优化软件包
[root@localhost ~]# cd /usr/src/zend-loader-php5.6-linux-x86_64/          //进入优化软件包路径
[root@localhost zend-loader-php5.6-linux-x86_64]# cp ZendGuardLoader.so /usr/local/php5/lib/php/      //复制文件
[root@localhost ~]# echo -e "zend_extension=/usr/local/php5/lib/php/ZendGuardLoader.so
zend_loader.enable=1" >> /usr/local/php5/php.ini   //在文件最后添加内容
[root@localhost ~]# tail -2 /usr/local/php5/php.ini   //查看添加内容详情
zend_extension=/usr/local/php5/lib/php/ZendGuardLoader.so
zend_loader.enable=1

5、启用php-fpm进程

[root@localhost ~]# useradd -M -s /sbin/nologin php     //创建一个所属用户组
[root@localhost ~]# cd /usr/local/php5/etc/                     
[root@localhost etc]# cp php-fpm.conf.default php-fpm.conf   //修改文件名
[root@localhost etc]# vim php-fpm.conf      //修改主配置文件
25 pid = run/php-fpm.pid
149 user = php
150 group = php
241 pm.max_children = 50
246 pm.start_servers = 20
251 pm.min_spare_servers = 5
256 pm.max_spare_servers = 35
[root@localhost etc]# /usr/local/sbin/php-fpm        //启动优化服务
[root@localhost etc]# netstat -anpt | grep php-fpm   //查看服务是否开启

[root@nginxetc]# vim /etc/init.d/nginx 
#!/bin/bash
# chkconfig: 2345 99 20
# description: Nginx Server Control Script
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
PROG_FPM="/usr/local/sbin/php-fpm"
PIDF_FPM="/usr/local/php5/var/run/php-fpm.pid"
case "$1" in
start)
    $PROG 
    $PROG_FPM
;;
stop)
    kill -s QUIT $(cat $PIDF)
    kill -s QUIT $(cat $PIDF_FPM)
;;
restart)
    $0 stop
    $0 start
;;
reload)
    kill -s HUP $(cat $PIDF)
;;
*)
    echo "Usage: $0 (start|stop|restart|reload)"
    exit 1
esac
exit 0

在php-fpm.conf文件中,pid配置行指出了PID信息的存放位置,对应的实际路径为/usr/local/php5/var/run/php-fpm.pid,根据上述信息,可以修改Nginx服务脚本,以便在启动/停止Nginx服务器时将php-fpm进程也自动启动/停止。

6、配置nginx支持PHP解析

[root@ns1 ~]# cat /usr/local/nginx/conf/nginx.conf      //修改nginx主配置文件

user  nginx nginx;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
error_log  logs/error.log  info;

pid        logs/nginx.pid;


events {
 use epoll;   
 worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
       server_name  localhost;

        charset utf-8;


        location / {
            root   html;
            index  index.html index.htm    index.php;
        }

        location ~ .php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            include        fastcgi.conf;
        }
}
}

7、检测配置的语法,重启

[root@localhost ~]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@nginxetc]#killall -HUP nginx   //重启

8、PHP页面访问测试

[root@localhost ~]# vim /usr/local/nginx/html/mysql.php
<?php
$link=mysql_connect('localhost','root','123123');
if($link)echo"<h1>succeccful!</h1>";
mysql_close();
?>
[root@localhost ~]# vim /usr/local/nginx/html/php.php 
<?php
phpinfo();
?>

 

 1、代理

  在Java设计模式中,代理模式是这样定义的:给某个对象提供一个代理对象,并由代理对象控制原对象的引用。

  可能大家不太明白这句话,在举一个现实生活中的例子:比如我们要买一间二手房,虽然我们可以自己去找房源,但是这太花费时间精力了,而且房屋质量检测以及房屋过户等一系列手续也都得我们去办,再说现在这个社会,等我们找到房源,说不定房子都已经涨价了,那么怎么办呢?最简单快捷的方法就是找二手房中介公司(为什么?别人那里房源多啊),于是我们就委托中介公司来给我找合适的房子,以及后续的质量检测过户等操作,我们只需要选好自己想要的房子,然后交钱就行了。

  代理简单来说,就是如果我们想做什么,但又不想直接去做,那么这时候就找另外一个人帮我们去做。那么这个例子里面的中介公司就是给我们做代理服务的,我们委托中介公司帮我们找房子。

  Nginx 主要能够代理如下几种协议,其中用到的最多的就是做Http代理服务器。

 

2、正向代理

  弄清楚什么是代理了,那么什么又是正向代理呢?

  这里我再举一个例子:大家都知道,现在国内是访问不了 Google的,那么怎么才能访问 Google呢?我们又想,美国人不是能访问 Google吗(这不废话,Google就是美国的),如果我们电脑的对外公网 IP 地址能变成美国的 IP 地址,那不就可以访问 Google了。你很聪明,VPN 就是这样产生的。我们在访问 Google 时,先连上 VPN 服务器将我们的 IP 地址变成美国的 IP 地址,然后就可以顺利的访问了。

  这里的 VPN 就是做正向代理的。正向代理服务器位于客户端和服务器之间,为了向服务器获取数据,客户端要向代理服务器发送一个请求,并指定目标服务器,代理服务器将目标服务器返回的数据转交给客户端。这里客户端是要进行一些正向代理的设置的。

  PS:这里介绍一下什么是 VPN,VPN 通俗的讲就是一种中转服务,当我们电脑接入 VPN 后,我们对外 IP 地址就会变成 VPN 服务器的公网 IP,我们请求或接受任何数据都会通过这个VPN 服务器然后传入到我们本机。这样做有什么好处呢?比如 VPN 游戏加速方面的原理,我们要玩网通区的 LOL,但是本机接入的是电信的宽带,玩网通区的会比较卡,这时候就利用 VPN 将电信网络变为网通网络,然后在玩网通区的LOL就不会卡了(注意:VPN 是不能增加带宽的,不要以为不卡了是因为网速提升了)。

  可能听到这里大家还是很抽象,没关系,和下面的反向代理对比理解就简单了。

3、反向代理

  反向代理和正向代理的区别就是:正向代理代理客户端,反向代理代理服务器。

反向代理,其实客户端对代理是无感知的,因为客户端不需要任何配置就可以访问,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。

  下面我们通过两张图来对比正向代理和方向代理:  

 

  理解这两种代理的关键在于代理服务器所代理的对象是什么,正向代理代理的是客户端,我们需要在客户端进行一些代理的设置。而反向代理代理的是服务器,作为客户端的我们是无法感知到服务器的真实存在的。

  总结起来还是一句话:正向代理代理客户端,反向代理代理服务器。

原文地址:https://www.cnblogs.com/canflyfish/p/11537382.html