热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

centos6LNMP的搭建(linux+nginx+mysql+php)

LNMP的搭建(linux+nginx+mysql+php)简介LNMP代表的就是:Linux系统下Nginx+MySQL+PHP网站服务器架构。Linux是一类Unix计算机操作


LNMP的搭建(linux+nginx+mysql+php)

  • 简介
  • LNMP代表的就是:Linux系统下Nginx+MySQL+PHP网站服务器架构。

  • Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等。

  • Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。

  • Mysql是一个小型关系型数据库管理系统。

  • PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。

  • 这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统。

  • 特点

Nginx是一个小巧而高效的Linux下的Web服务器软件,由 Igor Sysoev 为俄罗斯访问量第二的 Rambler 站点开发,在一些俄罗斯的大型网站上运行多年,相当稳定。

Nginx性能稳定、功能丰富、运维简单、处理静态文件速度快且消耗系统资源极少



  • 系统环境

系统平台:centos6

Nginx版本:nginx-1.2.7

Mysql版本:mysql-5.5.20

Php版本:php-5.5.12




  • 安装准备

如未安装则使用yum install安装(系统默认安装)。

#yum install 

gcc gcc-c++   ---编译器

autoconf      ---shell脚本工

libjpeg libjpeg-devellibpng libpng-devel

freetype freetype-devel     ---字体引擎

libxml2 libxml2-devel       --- C语言的XML程式库

zlib zlib-devel             ---提供数据压缩用的函式库

glibc glibc-devel           ---lib库(c运行库),linux中最底层api

glib2 glib2-devel          

bzip2 bzip2-devel           ---无损压缩软件

ncurses ncurses-devel       ---提供字符终端处理库

curl curl-devel             ---利用URL语法在命令行方式下工作的开源文件传输工具

e2fsprogs e2fsprogs-devel   ---Ext2(及Ext3/4)文件系统工具集,包含了创建、修复、配置、调试文件系统

krb5 krb5-devel             ---客户端/服务器结构与DES加密技术

libidn libidn-devel         ---实施字符串预处理、Punycode 和 IDNA规格定义的工具

openssl openssl-devel       ---加密传输

openldap openldap-devel      ---轻型目录访问协议的自由和开发的实现

openldap-clientsopenldap-servers  --openldap服务器客户端


  • 安装并编译libmcrypt

#tar –zxvf libmcrypt-2.5.7.tar.gz

#cd libmcrypt-2.5.7

#./configure --prefix=/usr/local/libmcrypt

#make && make install


  •  安装并编译pcre

#tar zxvf pcre-8.31.tar.gz

#cd pcre-8.31

#./configure--prefix=/usr/local/pcre

#make

#make install

 

  •  安装mysql

1.先下载mysql-5.5.10.tar.gz和cmake-2.8.4.tar.gz两个源件

先安装cmake

#tar -zxv -fcmake-2.8.5.tar.gz

#cd cmake-2.8.5

#./configure

#make

#make install

  • 创建mysql的安装目录及数据库存放目录

#mkdir -p/usr/local/mysql

#mkdir -p/usr/local/mysql/data

  • 创建mysql用户及用户组

# groupadd mysql

# useradd -r -gmysql mysql

  • 安装mysql

#cd ~

#tar -zxv -fmysql-5.5.20.tar.gz

#cd mysql-5.5.20

#cmake .

#make

#make install

参数说明:

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql       //安装目录

-DINSTALL_DATADIR=/usr/local/mysql/data        //数据库存放目录

-DDEFAULT_CHARSET=utf8                       //使用utf8字符

-DDEFAULT_COLLATION=utf8_general_ci           //校验字符

-DEXTRA_CHARSETS=all                           //安装所有扩展字符集

-DENABLED_LOCAL_INFILE=1                       //允许从本地导入数据

注意事项:

重新编译时,需要清除旧的对象文件和缓存信息。

# make clean

# rm -fCMakeCache.txt

# rm -rf /etc/my.cnf

2.配置

1)  设置目录权限

#cd/usr/local/mysql

#chown -R root:mysql . //     (把当前目录中所有文件的所有者所有者设为root,所属组为mysql)

#chown -Rmysql:mysql data

2)  #cpsupport-files/my-medium.cnf /etc/my.cnf

3)  创建系统数据库的表

# cd /usr/local/mysql

#scripts/mysql_install_db --user=mysql

4)  设置环境变量

# vi/root/.bash_profile

# .bash_profile

# Get the aliasesand functions

if [ -f ~/.bashrc]; then

        . ~/.bashrc

fi

 

# User specificenvironment and startup programs

 

PATH=$PATH:$HOME/bin:/usr/local/mysql/bin:/usr/local/mysql/lib

 

export PATH           

5)  手动启动mysql

# cd/usr/local/mysql/

# ./bin/mysqld_safe --user=mysql &   (启动MySQL,但不能停止)

6)  )另一种简单的启动mysql的方法(mysql已经被添加到系统服务中)

# service mysql.server start

如果上述命令出现:mysql.server 未识别的服务

则可能mysql还没添加到系统服务中,下面用另一种方法添加 

# cp support-files/mysql.server /etc/init.d/mysql

然后再用#service mysql start 来启动mysql即可.                        

  • 查看一下mysql是否启动成功

#netstat -nltp 

tcp   0   0 0.0.0.0:3306    0.0.0.0:*     LISTEN      1288/mysqld 


  • 设置mysql密码

 

/usr/local/mysql/bin/mysqladmin-u root -p password "123456"

 

输入;123456 密码就是123456

做个软连接:

ln-s /usr/local/mysql/bin/mysql /usr/bin/


  • Nginx的安装

  1. 1.需要三个安装包

1)openssl-fips-ecp-2.0.1.tar

2)pcre-8.31.tar

3)zlib-1.2.7.tar

2.依次安装openssl-fips-ecp-2.0.1.tarzlib-1.2.7.tar,pcre-8.31.tar

1)安装openssl-fips-ecp-2.0.1.tar

#tar -zxvf openssl-fips-ecp-2.0.1.tar.gz

#cd openssl-fips-ecp-2.0.1

#./config

#make

#make install

  • 安装zlib-1.2.7.tar

#cd ~

# tar -zxvf zlib-1.2.7.tar.gz

# cd zlib-1.2.7

# ./configure

#make

#make install

  • 安装pcre-8.31.tar

#cd ~

# tar -zxvf pcre-8.31.tar.gz

# cd pcre-8.31

# ./configure

#make

#make install

4)安装nginx

#cd ~

# tar -zxvfnginx-1.2.7.tar.gz

# cd nginx-1.2.7

#./configure--with-pcre=../pcre-8.31 --with-zlib=../zlib-1.2.7--with-openssl=../openssl-fips-ecp-2.0.1

#make

#make install

到此nginx安装完成

5)检测是否安装成功

# cd /usr/local/nginx/sbin/

#./nginx –t   --查看是否安装成功

 启动nginx

#./nginx

或者/etc/init.d/nginx start

查看端口

# netstat –nltp

 LISTEN   26557/nginx   tcp  0   0 0.0.0.0:21      0.0.0.0:*              



6)修改配置文件

# vim /usr/local/nginx/conf/nginx.conf

user  www www;

worker_processes  2;


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  2048;

}



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  65;


  # gzip压缩功能设置

    gzip on;

    gzip_min_length 1k;

    gzip_buffers    4 16k;

    gzip_http_version 1.0;

    gzip_comp_level 6;

    gzip_types text/html text/plain text/css text/Javascript application/json application/Javascript application/x-Javascript application/xml;

    gzip_vary on;


  # http_proxy 设置

    client_max_body_size   10m;

    client_body_buffer_size   128k;

    proxy_connect_timeout   75;

    proxy_send_timeout   75;

    proxy_read_timeout   75;

    proxy_buffer_size   4k;

    proxy_buffers   4 32k;

    proxy_busy_buffers_size   64k;

    proxy_temp_file_write_size  64k;

    proxy_temp_path   /usr/local/nginx/proxy_temp 1 2;


  # 设定负载均衡后台服务器列表 

    upstream  backend  { 

              #ip_hash; 

              server   192.168.10.100:8080 max_fails=2 fail_timeout=30s ;  

              server   192.168.10.101:8080 max_fails=2 fail_timeout=30s ;  

    }


  # 很重要的虚拟主机配置

    server {

        listen       80;

        server_name  itoatest.example.com;

        root   /apps/oaapp;


        charset utf-8;

        access_log  logs/host.access.log  main;


        #对 / 所有做负载均衡+反向代理

        location / {

            root   /apps/oaapp;

            index  index.jsp index.html index.htm;


            proxy_pass        http://backend;  

            proxy_redirect off;

            # 后端的Web服务器可以通过X-Forwarded-For获取用户真实IP

            proxy_set_header  Host  $host;

            proxy_set_header  X-Real-IP  $remote_addr;  

            proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;

            proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;


        }


        #静态文件,nginx自己处理,不去backend请求tomcat

        location  ~* /download/ {  

            root /apps/oa/fs;  


        }

        location ~ .*\.(gif|jpg|jpeg|bmp|png|ico|txt|js|css)$   

        {   

            root /apps/oaapp;   

            expires      7d; 

        }

        location /nginx_status {

            stub_status on;

            access_log off;

            allow 192.168.10.0/24;

            deny all;

        }


        location ~ ^/(WEB-INF)/ {   

            deny all;   

        }

        #error_page  404              /404.html;


        # redirect server error pages to the static page /50x.html

        #

        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

    }


  ## 其它虚拟主机,server 指令开始

}



  • 同时查看下iptables是否开放了80端口。

#vim /etc/sysconfig/iptables

# Firewall configuration written by system-config-firewall

# Manual customization of this file is not recommended.

*filter

:INPUT ACCEPT [0:0]

:FORWARD ACCEPT [0:0]

:OUTPUT ACCEPT [0:0]

-A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

-A INPUT -p icmp -j ACCEPT

-A INPUT -i lo -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 21 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT

# service iptables restart 重启iptables

# /etc/init.d/nginx restart    重启nginx


  • 安装并编译PHP

#tar -zvxf php-5.3.10.tar.gz

#cd php-5.3.10

#mkdir -p /usr/local/php5 #建立php安装目录

#./configure --prefix=/usr/local/php5

--with-config-file-path=/usr/local/php5/etc   ---设置php.ini的搜索路径(默认

PREFIX/lib)

--with-mysql=/usr/local/mysql

--with-mysql-sock=/tmp/mysql.sock

--with-gd            ---处理图形的拓展库

--with-iconv         ---函数

--with-zlib          ---打开zlib库的支持

--enable-xml

--enable-magic-quotes       ---默认启用magic quotes

--enable-safe-mode          ---启用安全模式

--enable-bcmath          ---函数

--enable-shmop           ---允许PHP读、写、创建、删除UNIX共享内存段

--enable-sysvsem

--enable-inline-optimization

--with-curlwrappers      ---运用curl工具打开url流

--enable-mbregex

--enable-fpm

--enable-mbstring        ---多字节,字符串的支持

--enable-ftp             ---打开ftp的支持

--enable-gd-native-ttf   ---支持TrueType字符串函数库   

--with-openssl           --- openssl的支持,加密传输

--enable-pcntl          --- freeTDS需要,链接mysql

--enable-sockets         ---

--with-xmlrpc            ---打开xml-rpc的c语言

--enable-zip             ---打开对zip的支持

--enable-soap           

--with-pear         

--with-gettext           ---打开gnu 的gettext 支持,编码库用到

--enable-session        

--with-mcrypt            ---算法

--with-curl              ---打开curl浏览工具的支持

#make

#make install

这时会报错configure:error: mcrypt.h not found. Please reinstall libmcrypt

1.解决#使用wget可以通过以下路径下载  

2.wget ftp://mcrypt.hellug.gr/pub/crypto/mcrypt/attic/libmcrypt/libmcrypt-2.5.7.tar.gz  

3.   

4.#解压  

5.tar -zxvf libmcrypt-2.5.7.tar.gz   

6.   

7.#进入目录  

8.cd libmcrypt-2.5.7  

9.   

10.#编译(默认安装到/usr/local/lib/)  

11../configure --prefix=/usr/local/libmcrypt  

12.   

13.#执行安装  

14.make && make install  

15. 

  • 下载libmcrypt-2.5.8.tar.gz

#tar zxvf libmcrypt-2.5.8.tar.gz

#cd libmcrypt-2.5.8

#./configure--prefix=/usr/local/libmcrypt

#make 

#make install

 

=========================================

  • 下载mhash-0.9.9.9.tar.gz

#tar zxvf mhash-0.9.9.9

#cd mhash-0.9.9.9

#./configrue --prefix=/usr/local/mhash

#make

#make install


=========================================

#tar zxvf mcrypt-2.6.8.tar.gz

#cd mcrypt-2.6.8

#cd mcrypt-2.6.8

exportLD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/mhash/lib

export LDFLAGS="-L/usr/local/mhash/lib-I/usr/local/mhash/include/"

exportCFLAGS="-I/usr/local/mhash/include/"

#./configure --prefix=/usr/local/mcrypt--with-libmcrypt-prefix=/usr/local/libmcrypt

#make

#make install

或者:yum install epel-release  //扩展包更新包

#yum update //更新yum源

#yum installlibmcrypt libmcrypt-devel mcrypt mhash  

 

修改配置文件

#cp php.ini-production /usr/local/php5/etc/php.ini #复制php配置文件到安装目录

#rm -rf /etc/php.ini #删除系统自带配置文件

#ln -s /usr/local/php5/etc/php.ini /etc/php.ini #添加软链接

#cp /usr/local/php5/etc/php-fpm.conf.default/usr/local/php5/etc/php-fpm.conf #拷贝模板文件为php-fpm配置文件

#vim /usr/local/php5/etc/php-fpm.conf #编辑

user = www #设置php-fpm运行账号为www

group = www #设置php-fpm运行组为www

pid = run/php-fpm.pid #取消前面的分号设置php-fpm开机启动

#chmod +x /etc/rc.d/init.d/php-fpm #添加执行权限

#chkconfig php-fpm on #设置开机启动

或vim /etc/rc.local

 

#vim /usr/local/php5/etc/php.ini #编辑配置文件

  找到:;open_basedir =   (379行)

  修改为:open_basedir = .:/tmp/ #防止php木马跨站

  找到:disable_functiOns=   (385行)

  修改为:disable_functiOns=

passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,escapeshellcmd,dll,popen,disk_free_space,checkdnsrr,checkdnsrr,getservbyname,getservbyport,disk_total_space,posix_ctermid,posix_get_last_error,posix_getcwd,posix_getegid,posix_geteuid,posix_getgid,posix_getgrgid,posix_getgrnam,posix_getgroups,posix_getlogin,posix_getpgid,posix_getpgrp,posix_getpid,posix_getppid,posix_getpwnam,posix_getpwuid,posix_getrlimit,posix_getsid,posix_getuid,posix_isatty,posix_kill,posix_mkfifo,posix_setegid,posix_seteuid,posix_setgid,posix_setpgid,posix_setsid,posix_setuid,posix_strerror,posix_times,posix_ttyname,posix_uname


#列出PHP可以禁用的函数,如果某些程序需要用到这个函数,可以删除,取消禁用。

  找到:;date.timezOne=  

  修改为:date.timezOne= PRC #设置时区

  找到:expose_php = On   

  修改为:expose_php = OFF #禁止显示php版本的信息

  找到:display_errors = On  

  修改为:display_errors = OFF #关闭错误提示


启动方式

#cp /root/lnmp/php-5.5.12/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

#/etc/init.d/php-fpm restart



  • 配置nginx支持php

 

修改配置文件

#vim /usr/local/nginx/conf/nginx.conf

user www www;

#首行user去掉注释,修改Nginx运行组为www www;必须与

/usr/local/php5/etc/php-fpm.conf中的user,group配置相同,否则php运行出错。

index index.php index.html index.htm; #添加index.php

 

       location ~ \.php$ {

          root           html;

             fastcgi_pass   127.0.0.1:9000;

            fastcgi_index  index.php;

            fastcgi_param SCRIPT_FILENAME$document_root$fastcgi_script_name;

           include        fastcgi_params;

         }

 

  • 报错解决

http://www.oschina.net/question/878142_106780

报错:

2016/08/31 13:56:25 [error]15197#0: *1 FastCGI sent in stderr: "PHP message: PHP Warning:  Unknown: open_basedir restriction in effect.File(/usr/local/nginx/html/index.php) is not within the allowed path(s):(.:/tmp/) in Unknown on line 0

PHP message: PHPWarning:  Unknown: failed to open stream:Operation not permitted in Unknown on line 0

Unable to open primaryscript: /usr/local/nginx/html/index.php (Operation not permitted)" whilereading response header from upstream, client: 192.168.1.206, server:localhost, request: "GET /index.php HTTP/1.1", upstream:"fastcgi://127.0.0.1:9000", host: "192.168.1.188"

 

解决:修改/etc/php.ini下open_basedir

改成open_basedir = /usr/local/nginx/html/:/tmp/



  • 重启服务

#/etc/init.d/nginx restart #重启nginx


  • 测试

#cd /usr/local/nginx/html/ #进入nginx默认网站根目录

#rm -rf /usr/local/nginx/html/* #删除默认测试页

#vim index.php #新建index.php文件

phpinfo();

?>


  • 设置权限

#chown www:www /usr/local/nginx/html/ -R #设置目录所有者

#chmod 700 /usr/local/nginx/html/ -R #设置目录权限

 

 

 

在客户端浏览器输入服务器IP地址,可以看到相关的配置信息!




本文出自 “losers” 博客,请务必保留此出处http://losers.blog.51cto.com/12343498/1877743

centos6 LNMP的搭建(linux+nginx+mysql+php)


推荐阅读
  • 目录结构如下:Nginx基础知识NginxHTTP服务器的特色及优点Nginx的主要企业功能Nginx作为web服务器的主要应用场景包括:Nginx的安装安装环境 ... [详细]
  • CentOS8.4 安装PHP7.4.25
    1、下载官网:https:www.php.netdownloads#cdmydata#wgethttps:www.php.netdistributionsphp ... [详细]
  • 代码:在mysql5.6,运行正常,5.7报错SELECTsum((selecta.numwherea.status1))astotalFROMmes_order_productA ... [详细]
  • 【自制小工具】代码生成器
    【自制小工具】代码生成器陆陆续续接触过好几款代码生成工具,发现确实好用,但都会有那么点不完善的地方,所以索性就自己做一个吧。界面非常简单,反正是自己用的,简单点用起来也方便上图:左 ... [详细]
  • kepserver中文手册,kepserver使用教程,kepserver设置
    下面介绍一下KepServer模拟器的使用,以下示例使用服务器随附的Simulator驱动程序来演示创建、配置和运行项目的过程。Simulator驱动程序是基于内存的驱动程序,能为 ... [详细]
  • 以SOA服务为导向的信息系统构建是通过有计划地构建信息系统时,一种简单而有柔性的方法,就是组件化与服务导向架构。过去的信息系统,是在使用者需要新功能时才开发的,也就是响应不同时 ... [详细]
  • 安全3AAuthentication:认证Authorzation:授权Accouting|Audition:审计用户管理用户:UID:0,不一定是root,root的uid非0时 ... [详细]
  • 前言微服务架构(MicroserviceArchitecture)是一种架构概念,旨在通过将功能分解到各个离散的服务中以实现对解决方案的解耦。你可以将其看作是在架构层次而非获取服务 ... [详细]
  • 步骤一:明确主打的核心目标用户群(对应产品侧的定位)这个核心目标用户群体是该产品成功挤进市场的切入点,甚至是撬动市场的支点和撬杠。市面上几乎很少有产品是专门给一个群体用而对其他群体 ... [详细]
  • CentOS7.2详细安装步骤(二)
    7)语言设置(可以在上一个主界面进行设置,这里不用再次设置)8)SECURITY设置(安全设置)选择default(默认的)策略就可以,通过进行选择,单击完成即可Default#默 ... [详细]
  • spotify engineering culture part 1
    原文,因为原视频说的太快太长,又没有字幕,于是借助youtube,把原文听&打出来了。中文版日后有时间再翻译。oneofthebigsucceessfactorshereatSpo ... [详细]
  • MyBatis模糊查询和多条件查询一、ISmbmsUserDao层根据姓名模糊查询publicListgetUser();多条件查询publicList ... [详细]
  • Xib九宫格应用管理使用xib封装一个自定义view的步骤1新建一个继承UIView的自定义view,假设类名叫做(AppView)2新建一个AppView.xib文件来描述 ... [详细]
  • 论文阅读及复现 | Improved Semantic Representations From TreeStructured Long ShortTerm Memory Networks
    两种形式的LSTM变体Child-SumTree-LSTMsN-aryTree-LSTMshttps:paperswithcode.compaperimproved-semanti ... [详细]
  • 102安装Linux系统
    安装Linux系统 安装CentOS系统准备系统光盘插入CentOS7光盘,引导安装程序设置主机,将光盘作为第一-引导设备从CentOS7光盘启动主机检测安装光盘的完整性从ISO镜 ... [详细]
author-avatar
抚摸3下1314_519_743
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有