设为首页 收藏本站
查看: 1096|回复: 0

LNMP 部署(Linux+Nginx+Mysql+Php)

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-9-4 09:23:51 | 显示全部楼层 |阅读模式

1. 安装所需各种依赖包

yum –y install

gcc gcc-c++autoconf automakebison flex freetype freetype-devel fontconfig-develgettext-devel libjpeglibjpeg-devel libpng libpng-devel libxml2 libxml2-devellibtool libtool-ltdllibtool-ltdl-devel libtiff-devel libXpm-devel libiculibicu-devel libidn libidn-devellibxslt libxslt-devel zlib zlib-devel glibcglibc-devel glib2 glib2-devel bzip2bzip2-devel ncurses ncurses-devel curlcurl-devel e2fsprogs e2fsprogs-devel krb5krb5-devel openssl openssl-developenldap openldap-devel nss_ldapopenldap-clients openldap-servers pcrepcre-devel pam-devel vim-enhancedmysql-devel php-devel libevent libevent-devel


2.准备lnmp其他的源代码包

wgethttp://blog.s135.com/soft/linux/ ... nginx-0.8.46.tar.gz
wget http://blog.s135.com/soft/linux/nginx_php/php/php-5.2.14.tar.gz
wgethttp://blog.s135.com/soft/linux/ ... -fpm-0.5.14.diff.gz
wget http://blog.s135.com/soft/linux/ ... sql-5.5.3-m3.tar.gz
wget http://blog.s135.com/soft/linux/ ... iconv-1.13.1.tar.gz
wget http://blog.s135.com/soft/linux/ ... mcrypt-2.5.8.tar.gz
wget http://blog.s135.com/soft/linux/ ... mcrypt-2.6.8.tar.gz
wget http://blog.s135.com/soft/linux/ ... /memcache-2.2.5.tgz
wget http://blog.s135.com/soft/linux/ ... hash-0.9.9.9.tar.gz
wget http://blog.s135.com/soft/linux/nginx_php/pcre/pcre-8.10.tar.gz
wgethttp://blog.s135.com/soft/linux/ ... tor-0.9.6.1.tar.bz2
wget http://blog.s135.com/soft/linux/nginx_php/pdo/PDO_MYSQL-1.0.2.tgz
wget http://blog.s135.com/soft/linux/ ... /ImageMagick.tar.gz
wget http://blog.s135.com/soft/linux/ ... k/imagick-2.3.0.tgz

3.安装php-5.3.28源代码包所需要的函数支持包

tar zxvflibiconv-1.13.1.tar.gz
cd libiconv-1.13.1/
./configure --prefix=/usr/local
make
make install
cd ../

(libiconv库为需要做转换的应用提供了一个iconv()的函数,以实现一个字符编码到另一个字符编码的转换)

tar zxvflibmcrypt-2.5.8.tar.gz
cd libmcrypt-2.5.8/
./configure
make
make install
cd libltdl/
./configure --enable-ltdl-install
make
make install
cd ../../

(libmcrypt是加密算法扩展库。支持DES,3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256,ARCFOUR, SERPENT, SAFER+等算法。)

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
ln -s /usr/local/bin/libmcrypt-config /usr/bin/libmcrypt-config
tar zxvf mcrypt-2.6.8.tar.gz
cd mcrypt-2.6.8/
./configure
make
make install
cd ../


4. 编译安装MySQL 5.1.73-m3

groupadd mysql
useradd -g mysql mysql

mkdir -p /data/mysql

#创建数据存放目录

chown mysql.mysql -R/data/mysql/

mkdir -p /usr/local/mysql/

chown mysql.mysql -R/usr/local/mysql/

tar zxvfmysql-5.1.73-m3.tar.gz
cd mysql-5.1.73-m3
./configure --prefix=/usr/local/mysql--datadir=/data/mysql--with-charset=utf8--with-extra-charsets=complex--enable-thread-safe-client--with-big-tables --with-ssl --with-embedded-serve--enable-local-infile --enable-assembler--with-plugins=innobase--with-plugins=partition

Make &&make install        #编译安装                                    

#############################################################################

--prefix=/usr/local/mysql//MySQL安装目录
--datadir=/mydata //数据库存放目录
--with-charset=utf8 //使用UTF8格式
--with-extra-charsets=complex //安装所有的扩展字符集
--enable-thread-safe-client //启用客户端安全线程
--with-big-tables //启用大表
--with-ssl //使用SSL加密
--with-embedded-server //编译成embeddedMySQL library (libmysqld.a),
--enable-local-infile //允许从本地导入数据
--enable-assembler //汇编x86的普通操作符,可以提高性能
--with-plugins=innobase //数据库插件
--with-plugins=partition //分表功能,将一个大表分割成多个小表

chown-R mysql:mysql/usr/local/mysql/

#把MySQL目录的权限给MySQL用户和组
/usr/local/mysql/bin/mysql_install_db--user=mysql
#用MySQL来初始化数据库,安装mysql和test数据库

chown -R mysql:mysql/usr/local/mysql/var/

#把初始化的数据库目录给MySQL所有者
/usr/local/mysql/bin/mysqld_safe--user=mysql &
#启动mysql服务
/usr/local/mysql/bin/mysqladmin-uroot password  123
#修改mysql登录密码为123
/usr/local/mysql/bin/mysql-uroot -p123
#用mysql登录

其他:
#cp /usr/local/src/software/mysql-5.1.38/support-files/mysql.server/etc/init.d/mysqld
#chmod 755 /etc/init.d/mysqld
#chkconfig --add mysqld
#chkconfig mysqld on
#service mysqld restart

登陆测试:

#cd /usr/local/mysql/bin
#mysql
>show databases;

# MySQL安装结束

5.编译安装PHP(FastCGI模式。使用fastCGI管理php,加快php解析速度)

tar zxvf php-5.3.28.tar.gz
gzip -cd php-5.2.17-fpm-0.5.14.diff.gz | patch -d php-5.3.28 -p1
#-p  1    是数字
#解压并打补丁,让php支持fpm来方便管理php-cgi进程(使用php-fpm管理fastCGI)

#gzip   -c  保留源文件  -d  解压

cd php-5.3.28/

./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-safe-mode --enable-bcmath --enable-shmop--enable-sysvsem --enable-inline-optimization--with-curl --with-curlwrappers--enable-mbregex --enable-fastcgi --enable-fpm--enable-force-cgi-redirect--enable-mbstring --with-mcrypt --with-gd--enable-gd-native-ttf --with-openssl--with-mhash --enable-pcntl--enable-sockets --with-ldap --with-ldap-sasl--with-xmlrpc --enable-zip--enable-soap
make ZEND_EXTRA_LIBS='-liconv'
#编译过程设定变量(编译过程需要)
make install

cp/php.ini-dist /usr/local/php/etc/php.ini
cd ../

6.准备编译安装PHP5扩展模块

tarzxvf memcache-2.2.5.tgz

cd memcache-2.2.5/
/usr/local/php/bin/phpize
./configure--with-php-config=/usr/local/php/bin/php-config
make &&make install
cd ../

cp /usr/local/php/php-5.3.28/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

chmod 755 /etc/init.d/php-fpm
这时候还不能使用/etc/init.d/php-fpm start启动,需修改一下php-fpm配置文件才可以,配置文件位置php安装目录 etc 目录下,默认有个参考文件.
cp php-fpm.conf.default php-fpm.conf
nano php-fpm.conf
,pm.start_servers = 20
,pm.min_spare_servers = 5
,pm.max_spare_servers = 35

7.修改php.ini文件,让php模块生效

cd/usr/local/php/php-5.3.28/ext/ftp

/usr/local/php/bin/phpize来执行

查找extension_dir= "./"
修改为:
vi /usr/local/php/etc/php.ini
extension_dir="/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/"
手工添加
extension = "memcache.so"
extension = "pdo_mysql.so"
extension = "imagick.so"
再查找output_buffering= Off
修改为output_buffering= On
再查找 ; cgi.fix_pathinfo=0
修改为cgi.fix_pathinfo=0,防止Nginx文件类型错误解析漏洞

8.配置eAccelerator加速PHP:

mkdir -p/usr/local/eaccelerator_cache
vi /usr/local/php/etc/php.ini

/usr/local/php/bin/phpize

到配置文件的最末尾,粘上以下内容:
[eaccelerator]
zend_extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/eaccelerator.so"
eaccelerator.shm_size="64"
eaccelerator.cache_dir="/usr/local/eaccelerator_cache"
eaccelerator.enable="1"
eaccelerator.optimizer="1"
eaccelerator.check_mtime="1"
eaccelerator.debug="0"
eaccelerator.filter=""
eaccelerator.shm_max="0"
eaccelerator.shm_ttl="3600"
eaccelerator.shm_prune_period="3600"
eaccelerator.shm_only="0"
eaccelerator.compress="1"
eaccelerator.compress_level="9"

9.准备php-cgi和nginx进程执行者用户

useraddnginx


10.创建php-fpm配置文件-php-fpm.conf

vi/usr/local/php/etc/php-fpm.conf
<value name="display_errors">0</value>
#0改成1,页面上会输出错误日志.  取消注释
unix user of processes
     <valuename="user">nginx</value>
      Unix group of processes
      <value name="group">nginx</value>                         取消注释

     <valuename="max_children">128</value>
#最大子进程数128,如果内存小于2G,则64个最佳
<value name="rlimit_files">65535</value>
# Set open file desc rlimit,同时打开的文件数,linux系统允许同时打开的文件数为1024,修改linux系统中允许同时打开的文件,ulimit-SHn 65535,而且这个参数重启后还能生效,加到/etc/profile全局配置文件的最后,开机就会生效,ulimit-a查看openfiles 65535
       ulimit  用户控制shell启动进程所占用的资源
             -H  设定硬性资源限制,也就是管理员设定的限制
             -S   设定软性资源限制,弹性限制
             -n   设定可同时打开的最大文件个数
             -f    设定单个文件最大大小
             -a   查看目前的限制
<value name="max_requests">1024</value>
#最大请求数, Howmuch requests each process should executebefore respawn.一个子进程能够回应1042个请求11. 启动php-cgi(fastcgi)进程,监听127.0.0.1的9000端口,进程数为128(如果服务器内存小于3GB,可以只开启64个进程),用户为nginx:

/usr/local/php/sbin/php-fpmstart
#启动php-cgi
/usr/local/php/sbin/php-fpm reload
#重新加载配置文件
/usr/local/php/sbin/php-fpm stop
#关闭php-fpm,此时nginx肯定连不上php

##Php-fpm启动:

/etc/init.d/php-fpm start

11.安装Nginx所需的pcre库

tar zxvf pcre-8.10.tar.gz
cd pcre-8.10/
./configure
make && make install
cd ../

yum installpcre* //如过你已经装了,请跳过这一步

#为了支持rewrite功能,我们需要安装pcre

yum installopenssl*

#安装openssl

#需要ssl的支持,如果不需要ssl支持,请跳过这一步

yum installzlib zlib-devel

# gzip 类库安装


12.安装Nginx

tar zxvf nginx-0.8.46.tar.gz

cd nginx-0.8.46/

./configure --user=nginx--group=nginx--prefix=/usr/local/nginx --with-http_stub_status_module--with-http_ssl_module--with-http_gzip_static_module


为Nginx添加proxy_cache模块,对视频进行缓存

wget http://labs.frickle.com/files/ngx_cache_purge-2.0.tar.gz

tar zxf tar zxvfngx_cache_purge-2.0.tar.gz
nginx和ngx_cache_purge必须在同一级目录

cd nginx-1.6.1
/usr/local/nginx/sbin/nginx –V

#查看编译参数

./configure --user=nginx--group=nginx--prefix=/usr/local/nginx --with-http_stub_status_module--with-http_ssl_module--with-http_gzip_static_module --add-module=../ngx_cache_purge-2.0

make &&make install


user  nginxnginx;               #定义Nginx运行的用户和用户组

worker_processes  1;

error_log logs/error.log;

pid       logs/nginx.pid;       #文件描述符数量

worker_rlimit_nofile 65535;

events                           #工作模式与连接数上限

{

    use epoll;

   worker_connections 65535;

}

http                             #设定http服务器

{

   include       mime.types;

   default_type  application/octet-stream;

    #charsetutf-8;

   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;

   server_names_hash_bucket_size128;

   client_header_buffer_size32k;

   large_client_header_buffers4 64k;

    sendfile       on;

   tcp_nopush     on;

   keepalive_timeout 120;

  #FastCGI相关参数是为了改善网站的性能:减少资源占用,提高访问速度。

   fastcgi_connect_timeout300;

   fastcgi_send_timeout300;

   fastcgi_read_timeout300;

   fastcgi_buffer_size64k;

    fastcgi_buffers464k;

   fastcgi_busy_buffers_size128k;

   fastcgi_temp_file_write_size128k;

  #gzip模块设置

    gzip on;

   gzip_min_length 1k;

   gzip_buffers 4 16k;

   gzip_http_version1.0;

   gzip_comp_level 2;

   gzip_typestext/plain application/x-javascript text/cssapplication/xml;   #压缩类型

    gzip_varyon;

#limit_zonecrawler$binary_remote_addr 10m;        #开启限制IP连接数的时候需要使用

    server

     {

       listen       80;                                             #监听端口

       server_name 122.112.94.100;                       #主机名,或IP。如果是主机名,要能够DNS解析

       location / {

           root   html;                                             #网站主目录。/usr/local/nginx/html/

           index  index.html index.htmindex.php;         #默认网页顺序

                   }

       error_page   500 502 503 504  /50x.html;

        location =/50x.html {

           root   html;

                             }

    #limit_conn   crawler 20;

   location~.*\.(php|php5)?$            #正则表达式:碰到网页文件名是.php或.php5结尾

  {

   root           html;

   fastcgi_pass  127.0.0.1:9000;          #连接fastcgi,用来解析php语句

   fastcgi_index index.php;              #首页为index.php

   fastcgi_param  SCRIPT_FILENAME /usr/loal/nginx/html$fastcgi_script_name;  #启动fast-cgi

   include       fastcgi_params;          #包括fastcgi_params中参数

   }

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

    {

     expires     30d;                   #图片格式缓存30天

    }

    location~.*\.(js|css)?$

    {

     expires     1h;                     #js/css缓存2小时

    }

   log_format  access '$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 access;

     }

}

    #server {

   #    listen      8000;

   #    listen      somename:8080;

   #    server_name somename  alias  another.alias;

   #    location / {

   #        root  html;

   #        index index.html index.htm;

   #    }

    #}

    # HTTPS server

    #

    #server {

   #    listen      443 ssl;

   #    server_name localhost;

   #    ssl_certificate      cert.pem;

   #    ssl_certificate_key  cert.key;

   #    ssl_session_cache    shared:SSL:1m;

   #    ssl_session_timeout  5m;

   #    ssl_ciphers HIGH:!aNULL:!MD5;

   #    ssl_prefer_server_ciphers  on;

   #    location / {

   #        root  html;

   #        index index.html index.htm;

   #    }

    #}



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-24361-1-1.html 上篇帖子: Linux+Nginx Web Server+Mysql+PHP 续 下篇帖子: windows下WAMP php5.x redis扩展 Linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表