zoukankan      html  css  js  c++  java
  • linux 安装nginx+php+mysql

    nginx安装

    本文是介绍使用源码编译安装,包括具体的编译参数信息。

    正式开始前,编译环境gcc g++ 开发库之类的需要提前装好。

    安装make:

    yum -y install gcc automake autoconf libtool make

    安装g++:

    yum install gcc gcc-c++

    一般我们都需要先装pcre, zlib,前者为了重写rewrite,后者为了gzip压缩。

    1.选定源码目录

    可以是任何目录,本文选定的是/usr/local/src

    cd /usr/local/src

    2.安装PCRE库

    ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz 下载最新的 PCRE 源码包,使用下面命令下载编译和安装 PCRE 包:

     
    cd /usr/local/src
    wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz
    tar -zxvf pcre-8.39.tar.gz
    cd pcre-8.39
    ./configure
    make && make install
     

    3.安装zlib库

    http://zlib.net/zlib-1.2.11.tar.gz 下载最新的 zlib 源码包,使用下面命令下载编译和安装 zlib包:

      cd /usr/local/src
      wget http://zlib.net/zlib-1.2.11.tar.gz
      tar -zxvf zlib-1.2.11.tar.gz
      cd zlib-1.2.11
      ./configure
      make && make install

    4.安装ssl(某些vps默认没装ssl)

    cd /usr/local/src
    wget https://www.openssl.org/source/openssl-1.1.0b.tar.gz
    tar -zxvf openssl-1.1.0b.tar.gz
    ./config make && make install

    5.安装nginx

    https://nginx.org/en/download.html 

    可以去nginx官网下载选择的版本,尽量选择稳定版的版本。

    下面是把 Nginx 安装到 /usr/local/nginx 目录下的详细步骤

     cd /usr/local/src
     wget https://nginx.org/download/nginx-1.16.1.tar.gz
     tar -zxvf nginx-1.16.1.tar.gz
     cd nginx-1.16.1.tar.gz

    1、添加nginx用户和用户组

    groupadd -r nginx
    useradd -r -g nginx nginx

    你可能收到提示已经有了nginx 用户和组这个无所谓有了更好。

    2、配置nginx安装参数

      ./configure 
      --prefix=/usr/local/nginx 
      --sbin-path=/usr/local/nginx/sbin/nginx 
      --conf-path=/usr/local/nginx/nginx.conf 
      --pid-path=/usr/local/nginx/nginx.pid 
      --user=nginx 
      --group=nginx 
      --with-http_ssl_module 
      --with-http_flv_module 
     --with-http_mp4_module  
     --with-http_stub_status_module 
     --with-http_gzip_static_module 
     --http-client-body-temp-path=/var/tmp/nginx/client/ 
     --http-proxy-temp-path=/var/tmp/nginx/proxy/ 
     --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ 
     --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi 
     --http-scgi-temp-path=/var/tmp/nginx/scgi 
     --with-pcre=/usr/local/src/pcre-8.39 
     --with-zlib=/usr/local/src/zlib-1.2.11 
     --with-openssl=/usr/local/src/openssl-1.1.0b 

     

    --with-pcre=/usr/local/src/pcre-8.39 指的是pcre-8.39 的源码路径。

    --with-zlib=/usr/local/src/zlib-1.2.11 指的是zlib-1.2.11 的源码路径。

    --with-openssl=/usr/local/src/openssl-1.1.0b 指的是openssl-1.1.0b 的源码路径。

    编译安装

    1 make && make install

    安装成功后 /usr/local/nginx 目录下如下:

    3、启动

    确保系统的 80 端口没被其他程序占用,运行/usr/local/nginx/sbin/nginx 命令来启动 Nginx

     netstat -ano|grep 80
    /usr/local/nginx/sbin/nginx

    可能会出现mkdir /var/tmp/nginx/client failed的提示

    这时手动创建就可以了 mkdir -p /var/tmp/nginx/client就可以了

    打开浏览器访问此机器的 IP,如果浏览器出现 Welcome to nginx! 则表示 Nginx 已经安装并运行成功

    ps:

    若nginx成功运行后,通过ip地址无法访问服务器 则可能是防火墙的问题 需要开放80端口或关闭防火墙

    开启80端口
    firewall-cmd --zone=public --add-port=80/tcp --permanent
    命令含义:
    --zone #作用域
    --add-port=80/tcp #添加端口,格式为:端口/通讯协议
    --permanent #永久生效,没有此参数重启后失效
    重启防火墙
    firewall-cmd --reload

    或者永久关闭防火墙

    systemctl stop firewalld.service  //停止防火墙
    systemctl disable firewalld.service //不再开机停止运行防火墙

    nginx编译选项

    make是用来编译的,它从Makefile中读取指令,然后编译。

    make install是用来安装的,它也从Makefile中读取指令,安装到指定的位置。

    configure命令是用来检测你的安装平台的目标特征的。它定义了系统的各个方面,包括nginx的被允许使用的连接处理的方法,比如它会检测你是不是有CC或GCC,并不是需要CC或GCC,它是个shell脚本,执行结束时,它会创建一个Makefile文件。nginx的configure命令支持以下参数:

    • --prefix=path    定义一个目录,存放服务器上的文件 ,也就是nginx的安装目录。默认使用 /usr/local/nginx。
    • --sbin-path=path 设置nginx的可执行文件的路径,默认为  prefix/sbin/nginx.
    • --conf-path=path  设置在nginx.conf配置文件的路径。nginx允许使用不同的配置文件启动,通过命令行中的-c选项。默认为prefix/conf/nginx.conf.
    • --pid-path=path  设置nginx.pid文件,将存储的主进程的进程号。安装完成后,可以随时改变的文件名 , 在nginx.conf配置文件中使用 PID指令。默认情况下,文件名 为prefix/logs/nginx.pid.
    • --error-log-path=path 设置主错误,警告,和诊断文件的名称。安装完成后,可以随时改变的文件名 ,在nginx.conf配置文件中 使用 的error_log指令。默认情况下,文件名 为prefix/logs/error.log.
    • --http-log-path=path  设置主请求的HTTP服务器的日志文件的名称。安装完成后,可以随时改变的文件名 ,在nginx.conf配置文件中 使用 的access_log指令。默认情况下,文件名 为prefix/logs/access.log.
    • --user=name  设置nginx工作进程的用户。安装完成后,可以随时更改的名称在nginx.conf配置文件中 使用的 user指令。默认的用户名是nobody。
    • --group=name  设置nginx工作进程的用户组。安装完成后,可以随时更改的名称在nginx.conf配置文件中 使用的 user指令。默认的为非特权用户。
    • --with-select_module --without-select_module 启用或禁用构建一个模块来允许服务器使用select()方法。该模块将自动建立,如果平台不支持的kqueue,epoll,rtsig或/dev/poll。
    • --with-poll_module --without-poll_module 启用或禁用构建一个模块来允许服务器使用poll()方法。该模块将自动建立,如果平台不支持的kqueue,epoll,rtsig或/dev/poll。
    • --without-http_gzip_module — 不编译压缩的HTTP服务器的响应模块。编译并运行此模块需要zlib库。
    • --without-http_rewrite_module  不编译重写模块。编译并运行此模块需要PCRE库支持。
    • --without-http_proxy_module — 不编译http_proxy模块。
    • --with-http_ssl_module — 使用https协议模块。默认情况下,该模块没有被构建。建立并运行此模块的OpenSSL库是必需的。
    • --with-pcre=path — 设置PCRE库的源码路径。PCRE库的源码(版本4.4 - 8.30)需要从PCRE网站下载并解压。其余的工作是Nginx的./ configure和make来完成。正则表达式使用在location指令和 ngx_http_rewrite_module 模块中。
    • --with-pcre-jit —编译PCRE包含“just-in-time compilation”(1.1.12中, pcre_jit指令)。
    • --with-zlib=path —设置的zlib库的源码路径。要下载从 zlib(版本1.1.3 - 1.2.5)的并解压。其余的工作是Nginx的./ configure和make完成。ngx_http_gzip_module模块需要使用zlib 。
    • --with-cc-opt=parameters — 设置额外的参数将被添加到CFLAGS变量。例如,当你在FreeBSD上使用PCRE库时需要使用:--with-cc-opt="-I /usr/local/include。.如需要需要增加 select()支持的文件数量:--with-cc-opt="-D FD_SETSIZE=2048".
    • --with-ld-opt=parameters —设置附加的参数,将用于在链接期间。例如,当在FreeBSD下使用该系统的PCRE库,应指定:--with-ld-opt="-L /usr/local/lib".

    php安装配置

    安装依赖

    # yum install gcc bison bison-devel zlib-devel libmcrypt-devel mcrypt mhash-devel openssl-devel libxml2-devel libcurl-devel bzip2-devel readline-devel libedit-devel sqlite-devel
    1 yum -y install gcc gcc-c++ glibc
    yum -y install libmcrypt-devel mhash-devel libxslt-devel 
    libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel 
    zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel 
    ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel 
    krb5 krb5-devel libidn libidn-devel openssl openssl-devel
    下载安装包 
    cd /usr/local/src wget https://www.php.net/distributions/php-7.2.22.tar.gz tar -zvxf
    php-7.2.22.tar.gz cd php-5.6.30

    ./configure --prefix=/usr/local/php --enable-fpm --with-mcrypt
    --enable-mbstring --enable-pdo --with-curl --disable-debug --disable-rpath
    --enable-inline-optimization --with-bz2 --with-zlib --enable-sockets
    --enable-sysvsem --enable-sysvshm --enable-pcntl --enable-mbregex
    --with-mhash --enable-zip --with-pcre-regex --with-mysql --with-mysqli
    --with-gd --with-jpeg-dir --with-freetype-dir --enable-calendar
    make && make install

    以上就完成了php-fpm的安装

    下面是对php-fpm运行用户进行设置

    1、为php提供配置文件

    1 cp php.ini-production /usr/local/php/etc/php.ini

    2、为php-fpm提供配置文件

    1 cd /usr/local/php
    2 cp etc/php-fpm.conf.default etc/php-fpm.conf
    3 vim etc/php-fpm.conf

    修改
    user = www
    group = www

    如果www用户不存在,那么先添加www用户

    1 groupadd www
    2 useradd -g www www
    修改
    pm.max_children = 150
    pm.start_servers = 8
    pm.min_spare_servers = 5
    pm.max_spare_servers = 10
    pid = /usr/local/php/var/run/php-fpm.pid 

    3、启动php-fpm

    执行

    1 /usr/local/php/sbin/php-fpm
    使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了):
    1 ps aux | grep php-fpm

    3、nginx和php-fpm整合

    编辑/usr/local/nginx/nginx.conf

    1 vim /usr/local/nginx/nginx.conf

    修改如下:

    红框中“#”号去掉

    红框中“#”号去掉

    添加红框中内容

    改成如下

    重新载入nginx的配置文件:

    1 /usr/loca/nginx/sbin/nginx -s reload

    4、测试php文件

     在/usr/local/nginx/html下创建index.php文件,输入如下内容

    1 <?php
    2     phpinfo();
    3 ?>

    5、浏览器访问

    访问http://你的服务器ip/index.php,皆可以见到php信息了。


    安装Mysql5.7(解压缩版)

    #### 1、下载安装包 
    wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz
    推荐下载通用安装方法的TAR包

    2.检查库文件是否存在,如有删除。

    [root@localhost Desktop]$ rpm -qa | grep mysql
    mysql-libs-5.1.52-1.el6_0.1.x86_64
    [root@localhost ~]$ rpm -e mysql-libs-5.1.52.x86_64 --nodeps
    [root@localhost ~]$

    3.检查mysql组和用户是否存在,如无创建。

    [root@localhost ~]$ cat /etc/group | grep mysql
    mysql:x:490:
    [root@localhost ~]$ cat /etc/passwd | grep mysql
    mysql:x:496:490::/home/mysql:/bin/bash

    以上为默认存在的情况,如无,执行添加命令:

    [root@localhost ~]$groupadd mysql
    [root@localhost ~]$useradd -r -g mysql mysql
    //useradd -r参数表示mysql用户是系统用户,不可用于登录系统。

    4.解压TAR包,更改所属的组和用户

    [root@localhost ~]$ cd /usr/local/
    [root@localhost local]$ tar xvf mysql-5.7.12-linux-glibc2.5-x86_64.tar
    [root@localhost local]$ tar xvfz mysql-5.7.12-linux-glibc2.5-x86_64.tar.gz
    [root@localhost local]$ mv mysql-5.7.12-linux-glibc2.5-x86_64 /user/local/mysql
    [root@localhost local]$ chown -R mysql mysql/
    [root@localhost local]$ chgrp -R mysql mysql/
    [root@localhost local]$ cd mysql/

    5.安装和初始化数据库

    [root@localhost mysql]$ bin/mysqld --user=mysql
    
    [root@localhost mysql]$ cp -a ./support-files/my-default.cnf /etc/my.cnf
    [root@localhost mysql]$ cp -a ./support-files/mysql.server  /etc/init.d/mysqld
    [root@localhost mysql]$ cd bin/
    [root@localhost bin]# ./mysqld_safe --user=mysql &
    
    [root@localhost bin]# /etc/init.d/mysqld restart
    Shutting down MySQL..2016-06-01T22:27:50.498694Z mysqld_safe mysqld from pid file /usr/local/mysql/data/localhost.localdomain.pid ended
     SUCCESS! 
    Starting MySQL. SUCCESS! 
    [1]+  Done                    ./mysqld_safe --user=mysql
    [root@localhost bin]$ 
    //设置开机启动
    [root@localhost bin]$ chkconfig --level 35 mysqld on
    [root@localhost bin]$

    6.初始化密码

    mysql5.7会生成一个初始化密码,而在之前的版本首次登陆不需要登录。

     [root@localhost bin]$ cat /root/.mysql_secret

     ,xxxxxR5H9

     [root@localhost bin]$./mysql -uroot -p

    Enter password: 
    mysql > update mysql.user set authentication_string=password('123qwe') where user='root';
    Query OK, 0 rows affected, 1 warning (0.00 sec)
    mysql > alter user 'root'@'localhost' identified by '123qwe';
    Query OK, 0 rows affected (0.00 sec)
    mysql > flush privileges;
    Query OK, 0 rows affected (0.00 sec)

    7.添加远程访问权限

    mysql > use mysql; 
    Reading table information for completion of table and column names
    You can turn off this feature to get a quicker startup with -A
    
    
    Database changed
    mysql> update user set host = '%' where user = 'root';
    Query OK, 1 row affected (0.00 sec)
    Rows matched: 1  Changed: 1  Warnings: 0
    
    
    mysql> select host, user from user;
    +-----------+-----------+
    | host      | user      |
    +-----------+-----------+
    | %         | root      |
    | localhost | mysql.sys |
    +-----------+-----------+
    //重启生效
    /etc/init.d/mysqld restart

    【 引用】

    http://www.nginx.cn/install

    http://www.nginx.cn/231.html

    http://www.centoscn.com/mysql/2016/0711/7606.html

  • 相关阅读:
    oracle 聚合函数 LISTAGG ,将多行结果合并成一行
    oracle 数据库对于多列求最大值
    Java 简单的rpc 一
    centos7 安装php7
    win10下VM 中centos 安装共享文件
    CentOS7 cannot find a valid baseurl for repo base
    分布式事务
    利用虚拟映射文件加密大文件
    动态代理
    c++ 11 lambda表达式
  • 原文地址:https://www.cnblogs.com/kyuang/p/6801942.html
Copyright © 2011-2022 走看看