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; # } #}
|