LNMP 环境搭建

更新时间:2024-02-28 23:46:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

Linux Red Hat 6.4下 Nginx + Mysql + PHP

服务器环境搭建

系统平台:RHEL 6.4 Nginx版本:nginx-1.1.8 Mysql版本:5.1.59 PHP版本:php-5.2.17

安装准备

在安装Linux操作系统时添加如下几个包,不然无法使用源码安装

关于依赖包的问题:

用 rpm -qa | grep 依赖包名

查看是否安装了改该包,然后安装其相应的devel文件即可 比如:

#rpm -qa | grep libxxx libxxx-1.0.0.el6.x86_64 其devel包的名字为

libxxx-devel-1.0.0.el6.x86_64

1.安装libiconv

#tar zxvf libiconv-1.13.tar.gz #cd libiconv-1.13/

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

#make install cd ../

2.安装libmcrypt 实现加密功能的库

# tar zxvf libmcrypt-2.5.8.tar.gz # cd libmcrypt-2.5.8/ # ./configure # make

# make install # /sbin/ldconfig

# 注:这里不要退出去。

# cd libltdl/

# ./configure --enable-ltdl-install # make

# make install

3.安装mhash(哈稀函数库) # tar zxvf mhash-0.9.9.9.tar.gz # cd mhash-0.9.9.9/ # ./configure # make

# make install # cd ../

ln -s /usr/local/lib/libmcrypt.la /usr/lib/libmcrypt.la ln -s /usr/local/lib/libmcrypt.so /usr/lib/libmcrypt.so ln -s /usr/local/lib/libmcrypt.so.4 /usr/lib/libmcrypt.so.4 ln -s /usr/local/lib/libmcrypt.so.4.4.8 /usr/lib/libmcrypt.so.4.4.8 ln -s /usr/local/lib/libmhash.a /usr/lib/libmhash.a ln -s /usr/local/lib/libmhash.la /usr/lib/libmhash.la ln -s /usr/local/lib/libmhash.so /usr/lib/libmhash.so ln -s /usr/local/lib/libmhash.so.2 /usr/lib/libmhash.so.2 ln -s /usr/local/lib/libmhash.so.2.0.1 /usr/lib/libmhash.so.2.0.1 4. 安装mcrypt

# tar zxvf mcrypt-2.6.8.tar.gz # cd mcrypt-2.6.8/ # /sbin/ldconfig #./configure # make # make install # cd ../

如果出现libmcrypt not found的错误 执行下面的语句:

#exprot LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH

5. 安装libxml2-devel

# rpm -ivh libxml2-devel-2.7.6-8.el6_3.4.x86_64.rpm 6.安装libpng-devel

# rpm -ivh libpng-devel-1.2.49-1.el6_2.x86_64.rpm 7.安装freetype、freetype-devel

# rpm -ivh freetype-devel-2.3.11-6.el6_2.9.x86_64.rpm 8.安装 openssl-devel

# rpm -ivh openssl-devel-1.0.0-27.el6.x86_64.rpm # openssl-devel依赖于krb5-devel #

rpm -ivh krb5-devel-1.10.3-10.el6.x86_64.rpm

# krb5-devel 依赖于 # # # #

rpm -ivh keyutils-libs-devel-1.4-4.el6.x86_64.rpm rpm -ivh libcom_err-devel-1.41.12-14.el6.x86_64.rpm rpm -ivh libselinux-devel-2.0.94-5.3.el6.x86_64.rpm

libselinux-devel依赖于

rpm -ivh libsepol-devel-2.0.41-4.el6.x86_64.rpm

9.安装nucurese

# tar -zxvf ncurses-5.6.tar.gz # cd ncurses-5.6 #./configure

--with-shared

--without-debug

--without-ada

--enable-overwrite # make

# make install

Mysql安装

先用rpm -qa | grep mysql 查看是否已经安装mysql 如果显示:

MySQL-server-* MySQL-client-*

用 rpm -e mysql* -nodeps 将其卸载 删除mysql服务

# chkconfig --list | grep -i mysql #chkconfig --del mysql

Whereis mysql 删除残留文件夹

建立mysql组,建立mysql用户并且加入到mysql组中 # groupadd mysql

# useradd mysql -g mysql # tar zxvf mysql-5.1.59.tar.gz # cd mysql-5.1.59

# ./configure --prefix=/usr/local/mysql --without-debug

--with-extra-charsets=gbk --with-extra-charsets=all --enable-assembler --with-pthread

--enable-thread-safe-client

--with-mysqld-ldflags=-all-static /*不带共享库的形式编译mysqld*/ --with-client-ldflags=-all-static --with-big-tables

--with-readline /*要采用rpm方式安装ncurses或tar包安装*/

--with-ssl /*要采用rpm方式安装openssl*/ --with-embedded-server --enable-local-infile --with-plugins=innobase # make # make install

# /usr/local/mysql/bin/mysql_install_db --user=mysql #以Mysql身份初始化数据库

# cp ./support-files/mysql.server /etc/init.d/mysql #复制Mysql启动服务至系统

# cp ./support-files/my-medium.cnf /etc/my.cnf # chmod 755 /etc/init.d/mysql

# cd /usr/local/mysql/ #切换到cd /usr/local/mysql/目录下 # chown -R mysql . #改变当前目录下的所有者为mysql用户 # chown -R mysql /var/lib/mysql/ #修改数据库目录的权限

# chgrp -R mysql . #改变当前目录下的mysql用户的文件为mysql组

# /usr/local/mysql/bin/mysqld_safe --user=mysql& # service mysql start #启动mysql服务

如果出现找不到mysql.sock文件,修改 /etc目录下的my.cof文件 把 socket=/var/lib/mysql.sock改成socket=/tmp/mysql.sock即可

# /usr/local/mysql/bin/mysqladmin -u root password 'admin' #设置管理员密码

# /usr/local/mysql/bin/mysql -u root -p #测试密码输入

# mysql> \\q /*退出mysql*/

# chkconfig --add mysql #添加mysqld服务到系统 # chkconfig mysql on #打开myslqd服务 # service mysql restart #重启Mysql

PHP 安装

依赖包

# rpm -ivh libidn-devel-1.18-2.el6.x86_64.rpm # rpm -ivh libcurl-devel-7.19.7-35.el6.x86_64.rpm # rpm -ivh cyrus-sasl-devel-2.1.23-13.el6_3.1.x86_64.rpm # rpm -ivh openldap-devel-2.4.23-31.el6.x86_64.rpm # rpm -ivh libjpeg-turbo-devel-1.2.1-1.el6.x86_64.rpm ./configure 中如果报libjpeg.(a|so)not found错误 检查libjpeg是否安装,如果安装了

# cp -frp /usr/lib64/libjpeg.* /usr/lib/ libpng libldap同理

# cp -frp /usr/lib64/libpng* /usr/lib/ # cp -frp /usr/lib64/libldap* /usr/lib/

# tar -zxvf php-5.2.17.tar.gz

# gzip -cd php-5.2.17-fpm-0.5.14.diff.gz | patch -d php-5.2.17 -p1 # cd php-5.2.17

./configure --prefix=/usr/local/php \\ --with-config-file-path=/usr/local/php/etc \\ --with-mysql=/usr/local/mysql/ \\

--with-mysqli=/usr/local/mysql/bin/mysql_config --with-iconv-dir=/usr/local/ \\ --with-freetype-dir

--with-jpeg-dir

--with-png-dir

--with-zlib

--with-libxml-dir=/usr/ \\

--enable-xml --disable-rpath --enable-discard-path --enable-bcmath \\ --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers \\ --enable-mbregex --with-mcrypt

--with-gd

--enable-fastcgi --enable-gd-native-ttf

--enable-fpm --with-openssl

--enable-force-cgi-redirect --enable-mbstring \\ --with-mhash --enable-pcntl \\

--enable-sockets --with-ldap --with-ldap-sasl --with-xmlrpc --enable-zip --enable-soap

--enable-safe-mode \\\\此选项可选,如果使用可以增加安全性,但是一些功能会被制约 # make ZEND_EXTRA_LIBS='-liconv' #直接make会报错 # make install Php-fpm配置

php-fpm是为PHP打的一个FastCGI管理补丁,可以平滑变更php.ini配置而无需重启php-cgi: 创建用户与用户组

/usr/sbin/groupadd www /usr/sbin/useradd -g www www

将 /usr/local/php/etc/php-fpm.conf 重命名 #备份原文件 创建名为php-fpm.conf的文件输入以下内容:

php-fpm启动与管理

/usr/local/php/sbin/php-fpm start

注:/usr/local/php/sbin/php-fpm还有其他参数,包括:

start|stop|quit|restart|reload|logrotate,修改php.ini后不重启php-cgi,重新加载配置文件使用reload,就保持了在php的fastcgi进程持续运行的状态下,又重新加载了php.ini。

Nginx 安装

1、安装rewrite模块支持包pcre库:

pcre是perl所用到的正则表达式,目的是让所装的软件支持正则表达式。默认情况下,Nginx只处理静态的网页请求,也就是html.如果是来自动态的网页请求,比如*.php,那么Nginx就要根据正则表达式查询路径,然后把*.PHP交给PHP去处理。 # tar zxvf pcre-7.9.tar.gz # cd pcre-7.9/ # ./configure

# make && make install cd ../ 2.安装Nginx

# tar zxvf nginx-1.1.8.tar.gz # cd nginx-1.1.8/ #./configure

--user=www

--group=www

--prefix=/usr/local/nginx

--with-http_stub_status_module --with-http_ssl_module # make

# make install

3.Nginx 安装后只有一个程序文件,本身并不提供各种管理程序,它是使用参数和系统信号机制对 Nginx 进程本身进行控制的。 Nginx 的参数包括有如下几个:

-c :使用指定的配置文件而不是 conf 目录下的 nginx.conf 。 -t:测试配置文件是否正确,在运行时需要重新加载配置的时候,此命令非常重要,用来检测所修改的配置文件是否有语法错误。 -v:显示 nginx 版本号。

-V:显示 nginx 的版本号以及编译环境信息以及编译时的参数。 例如我们要测试某个配置文件是否书写正确,我们可以使用以下命令 sbin/nginx -t -c conf/nginx.con nginx配置

1.在/usr/local/nginx/conf/目录中创建nginx.conf文件: rm -f /usr/local/nginx/conf/nginx.conf vi /usr/local/nginx/conf/nginx.conf

======================================= nginx.conf才是nginx web服务器的配置文件

======================================= user www www; #/*启动nginx服务的用户与组*/ worker_processes 1; #/*启动nginx服务的工作进程*/ error_log logs/nginx_error.log crit; #/*错误日志,以及等级*/ pid /usr/local/nginx/nginx.pid; #/*nginx服务进程PID*/ worker_rlimit_nofile 51200; events {

use epoll; #/*工作模式*/

worker_connections 51200; #/*每进程允许最大的同时连接数*/ } http {

include mime.types;

default_type application/octet-stream; #charset gb2312;

server_names_hash_bucket_size 128;

client_header_buffer_size 32k; large_client_header_buffers 4 32k;

sendfile on;

tcp_nopush on; keepalive_timeout 60; tcp_nodelay on;

fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k;

fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 128k; gzip on;

gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.0; gzip_comp_level 2;

gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on;

#limit_zone crawler $binary_remote_addr 10m; server {

listen 80; #/*监听端口*/ server_name localhost; #/*服务器名称*/

index index.html index.htm index.php; #/*缺省主页名称*/

root /usr/local/nginx/html; #/*网站根目录,也可以采用下面内容*/ #也可以采用相对路径,下面注释部分*/ #location / {

# root html;

# index index.html index.htm; # }

#limit_conn crawler 20;

#通过FastCGI方式支持PHP,php页面由fastcgi代理处理,这也是反向代理的一个应用,这里可以是jsp/asp等脚本。

#Nginx是通过本机的9000端口将PHP请求转发给PHP的,PHP自己是从本机的9000端口侦听数据,Nginx与PHP通过本机的9000端口完成了数据请求。 location ~ .*\\.(php|php5)?$ {

#fastcgi_pass unix:/tmp/php-cgi.sock;

fastcgi_pass 127.0.0.1:9000; #/*fastcgi监听端口*/ fastcgi_index index.php;

include fcgi.conf; #/*fastcgi配置文件,修改为以下内容*/ }

#对于某一类型的文件,设置过期时间,静态的页面通常设置长一点。 #静态文件,nginx自己处理

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

expires 30d; } #日志的格式

log_format access '$remote_addr - $remote_user [$time_local] \

'$status $body_bytes_sent \ '\ access_log logs/access.log access; } }

说明:以上配置文件只是基本配置文件,要实现其它功能的话,需要在此基础上进行修改。 2.在/usr/local/nginx/conf/目录中创建fcgi.conf文件: 说明:可以直接粘贴以下内容。 vi /usr/local/nginx/conf/fcgi.conf

fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx; 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_FILENAME $document_root$fastcgi_script_name; 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 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; nginx启动与管理 1.启动nginx

/usr/local/nginx/sbin/nginx 2.测试nginx配置文件

修改/usr/local/nginx/conf/nginx.conf配置文件后,请执行以下命令检查配置文件是否正确:

# /usr/local/nginx/sbin/nginx -t

如果屏幕显示以下两行信息,说明配置文件正确:

the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

the configuration file /usr/local/nginx/conf/nginx.conf was tested successfully 3.查看Nginx主进程号

ps -ef | grep \屏幕显示的即为Nginx主进程号,例如: 6302

这时,执行以下命令即可使修改过的Nginx配置文件生效: # kill -HUP 6302

或者无需这么麻烦,找到Nginx的Pid文件:

# kill -HUP `cat /usr/local/nginx/logs/nginx.pid` 重启nginx

# /usr/local/nginx/sbin/nginx -s reload

4.配置开机自动启动Nginx + PHP vi /etc/rc.local 加入以下内容: ulimit -SHn 51200

/usr/local/php/sbin/php-fpm start /usr/local/nginx/sbin/nginx 5.测试nginx

vi /usr/local/nginx/html/phpinfo.php

本文来源:https://www.bwwdw.com/article/c21a.html

Top