您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關CentOS 5.x,6.0如何編譯安裝Nginx1.2.3+MySQL5.5.15+PHP5.3.6,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
本安裝方法,我在centos5.8 和centos6里都嘗試過,是沒有問題的。不過很多包,官方都沒有下載的。讓我們這些新手很奇怪的是,,,
為什么有的官方下載地址,能用,但是過了一段時間就不能用了。只好重新去找包了。。。。只怪yum安裝版本太低了。。不然,誰想編譯啊。。。。
看很多人,都養成習慣。。把這些包放到
/user/local/src
這個目錄里,這可能是一個習慣吧!我也這樣操作的。。把這些需要包,都下載放進去。
首先,我告訴一下大家需要下載些什么。
先進入,下載目錄
以下是用secureCRT工具遠程登錄到服務器,在命令行下面操作的,不然不能復制太苦逼了。。哈哈
cd /user/local/src
1、下載nginx(目前穩定版)
wget http://nginx.org/download/nginx-1.2.3.tar.gz
2、下載pcre (支持nginx偽靜態)
wget http://downloads.sourceforge.net/project/pcre/pcre/8.31/pcre-8.31.tar.gz?use_mirror=ncu
4、下載MySQL
wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.15.tar.gz
5、下載php
wget http://mirrors.sohu.com/php/php-5.3.6.tar.gz
6、下載cmake(MySQL編譯工具,好像mysql5.x幾以后必須要cmake來編譯了)
wget http://www.cmake.org/files/v2.8/cmake-2.8.9.tar.gz
7、下載libmcrypt(PHPlibmcrypt模塊)
wget http://downloads.sourceforge.net/project/mcrypt/Libmcrypt/2.5.8/libmcrypt-2.5.8.tar.gz?use_mirror=ncu
裝之前,我們先改一些系統配置,centos默認,系統只開發了22端口
vi /etc/sysconfig/iptables
在
-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,80 -j ACCEPT(允許80端口通過防火墻) -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT(允許3306端口通過防火墻)
特別提示:很多網友把這兩條規則添加到防火墻配置的最后一行,導致防火墻啟動失敗,正確的應該是添加到默認的22端口這條規則的下面,如果你發現,你的這個和我的代碼不一樣,建議。你吧你的22端口例子賦值一次改成80,22,。
我還見過,我有的centos都沒有這個文件,如果確實不會的新手,可以直接
/etc/init.d/iptables stop#關閉防火墻
#最后重啟防火墻使配置生效
/etc/init.d/iptables restart
80端口不開,等下nginx安裝好了。我們也無法訪問。
安裝一些準備軟件,也是必須軟件。這些就不編譯了不然太累了。。。呵呵
yum install make apr* autoconf automake gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel gd kernel keyutils patch perl kernel-headers compat* mpfr cpp glibc libgomp libstdc++-devel ppl cloog-ppl keyutils-libs-devel libcom_err-devel libsepol-devel libselinux-devel krb5-devel zlib-devel libXpm* freetype libjpeg* libpng* php-common php-gd ncurses* libtool* libxml2 libxml2-devel patch
編譯安裝開始。。。。。。。。。。。。。。
cd /usr/local/src tar zxvf libmcrypt-2.5.8.tar.gz cd libmcrypt-2.5.8 ./configure make make install
cd /usr/local/src tar zxvf cmake-2.8.9.tar.gz cd cmake-2.8.9 ./configure make make install
cd /usr/local/src mkdir /usr/local/pcre #創建安裝目錄 mkdir /usr/local/pcre tar zxvf pcre-8.31.tar.gz cd pcre-8.31 ./configure --prefix=/usr/local/pcre make make install
以上的也可以考慮一鍵安裝
#!/bin/sh cd /usr/local/src tar zxvf libmcrypt-2.5.8.tar.gz cd libmcrypt-2.5.8 ./configure make make install cd /usr/local/src tar zxvf cmake-2.8.9.tar.gz cd cmake-2.8.9 ./configure make make install cd /usr/local/src mkdir /usr/local/pcre mkdir /usr/local/pcre tar zxvf pcre-8.31.tar.gz cd pcre-8.31 ./configure --prefix=/usr/local/pcre make make install
#cd /usr/local/src
# groupadd mysql #創建mysql用戶組
# useradd -g mysql mysql #創建mysql用戶
#mkdir /var/mysql #創建mysql目錄
#mkdir /var/mysql/data #創建存放數據目錄
# chown -R mysql:mysql /var/mysql/data/
#tar zxvf mysql-5.5.23.tar.gz #解壓
#cd mysql-5.5.23
#cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/var/mysql/data
#make #編譯
#make install #安裝
#cd /usr/local/mysql
#cp ./support-files/my-huge.cnf /etc/my.cnf #拷貝配置文件(注意:如果/etc目錄下面默認有一個my.cnf,直接覆蓋即可)
#vi /etc/my.cnf #編輯配置文件,在 [mysqld] 部分增加
datadir = /var/mysql/data #添加MySQL數據庫路徑
保存退出,然后運行以下命令
#./scripts/mysql_install_db --user=mysql #生成mysql系統數據庫
#cp ./support-files/mysql.server /etc/rc.d/init.d/mysqld #把Mysql加入系統啟動
#chmod 755 /etc/init.d/mysqld #增加執行權限
#chkconfig mysqld on #加入開機啟動
#vi /etc/rc.d/init.d/mysqld #編輯
basedir = /usr/local/mysql #MySQL程序安裝路徑
datadir = /var/mysql/data #MySQl數據庫存放目錄
保存退出,然后運行以下命令
===================== 支持遠程登陸
#/etc/init.d/mysqld start #開啟mysql服務
#mysql -u root mysql
mysql>use mysql;
mysql>desc user;
mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "root"; //為root添加遠程連接的能力。
mysql>update user set Password = password('xxxxxx') where User='root';
mysql>flush privileges;
mysql>exit
#/etc/init.d/mysqld restart #重啟mysql
groupadd www #添加www組
useradd -g www www -s /bin/false #創建nginx運行賬戶www并加入到www組,不允許www用戶直接登錄系統
tar zxvf nginx-0.8.55.tar.gz
cd nginx-0.8.55
./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_stub_status_module
make && make install
/usr/local/nginx/sbin/nginx #啟動nginx
/usr/local/nginx/sbin/nginx -s stop#啟動nginx
設置nginx開啟啟動
vi /etc/rc.d/init.d/nginx
編輯啟動文件添加下面內容
#!/bin/bash # nginx Startup script for the Nginx HTTP Server # it is v.0.0.2 version. # chkconfig: - 85 15 # description: Nginx is a high-performance web and proxy server. # It has a lot of features, but it's not for everyone. # processname: nginx # pidfile: /var/run/nginx.pid # config: /usr/local/nginx/conf/nginx.conf nginxd=/usr/local/nginx/sbin/nginx nginx_config=/usr/local/nginx/conf/nginx.conf nginx_pid=/usr/local/nginx/logs/nginx.pid RETVAL=0 prog="nginx" # Source function library. . /etc/rc.d/init.d/functions # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ ${NETWORKING} = "no" ] && exit 0 [ -x $nginxd ] || exit 0 # Start nginx daemons functions. start() { if [ -e $nginx_pid ];then echo "nginx already running...." exit 1 fi echo -n $"Starting $prog: " daemon $nginxd -c ${nginx_config} RETVAL=$? echo [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx return $RETVAL } # Stop nginx daemons functions. stop() { echo -n $"Stopping $prog: " killproc $nginxd RETVAL=$? echo [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /usr/local/nginx/logs/nginx.pid } reload() { echo -n $"Reloading $prog: " #kill -HUP `cat ${nginx_pid}` killproc $nginxd -HUP RETVAL=$? echo } # See how we were called. case "$1" in start) start ;; stop) stop ;; reload) reload ;; restart) stop start ;; status) status $prog RETVAL=$? ;; *) echo $"Usage: $prog {start|stop|restart|reload|status|help}" exit 1 esac exit $RETVAL
保存退出,然后運行以下命令:
chmod 775 /etc/rc.d/init.d/nginx #賦予文件執行權限
chkconfig nginx on #設置開機啟動
/etc/rc.d/init.d/nginx restart #重啟nginx
service nginx restart#重啟nginx
chown -R www.www /html #設置目錄所有者
chmod -R 755 /html#設置目錄權限
tar -zvxf php-5.3.10.tar.gz
cd php-5.3.10
./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-json --enable-xml --enable-mbstring --with-openssl --enable-ftp --enable-sockets --with-mysql=/usr/local/mysql --with-pdo-mysql=/usr/local/mysql --enable-fpm
make #編譯
make install #安裝
cp php.ini-production /usr/local/php/etc/php.ini #復制php配置文件到安裝目錄
rm -rf /etc/php.ini #刪除系統自帶配置文件
ln -s /usr/local/php/etc/php.ini /etc/php.ini #添加軟鏈接
cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf #拷貝模板文件為php-fpm配置文件
vi /usr/local/php/etc/php-fpm.conf #編輯
pid = run/php-fpm.pid #取消前面的分號,然后在下面的user及group處修改以下信息:
user = www #設置php-fpm運行賬號為www
group = www #設置php-fpm運行組為www
保存退出,接著運行下面的命令。
設置 php-fpm開機啟動
cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm #拷貝php-fpm到啟動目錄
chmod +x /etc/rc.d/init.d/php-fpm #添加執行權限
chkconfig php-fpm on #設置開機啟動
vi /usr/local/php/etc/php.ini #編輯配置文件
讓php支持<?=$time?>
搜索: short_open_tag = Off 改為short_open_tag = On
找到:;open_basedir =
修改為:open_basedir = .:/tmp/ #防止php木馬跨站,重要!!
找到:disable_functions =
修改為: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 #關閉錯誤提示
vi /usr/local/nginx/conf/nginx.conf
修改/usr/local/nginx/conf/nginx.conf 配置文件,需做如下修改
user www www; #首行user去掉注釋,修改Nginx運行組為www www;必須與/usr/local/php/etc/php-fpm.conf中的user,group配置相同,否則php運行出錯
index index.php index.html index.htm; #添加index.php
將所有root后面的目錄設置成
root /html;
但是。那個500的不要設置。
找到下面的這段代碼進行修改
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
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;
}
#取消FastCGI server部分location的注釋,并要注意fastcgi_param行的參數,改為$document_root$fastcgi_script_name,或者使用絕對路徑
保存退出,接著運行以下命令
/usr/local/nginx/sbin/nginx -s restart #重啟nginx
/etc/rc.d/init.d/php-fpm start #啟動php-fpm
這個時候。php-fpm好像啟動不了。。。。因為還有些配置沒有配置。。有機會把錯誤截圖弄上來。
好像是有幾個參數,沒有設置提示錯誤,可以根據這個。修改上面的php-fpm.conf文件
啟動錯誤解決:
ALERT: [pool www] pm.min_spare_servers(0) must be a positivevalue
編輯php-fpm.conf找到pm.min_spare_servers去除;號,注意非注釋內容pm.min_spare_servers
ALERT: [pool www] pm.max_spare_servers(0) must be a positivevalue
編輯php-fpm.conf找到pm.max_spare_servers去除;號,同樣非注釋內容pm.max_spare_servers
WARNING: [pool www] pm.start_servers is not set. It's been set to20.
編輯php-fpm.conf找到pm.start_servers 去除;號,同樣非注釋內容pm.start_servers
ERROR: bind() for address '127.0.0.1:9000' failed: Address alreadyin use (98)
查看進程,有N多進程
ps -ef | grep php#查php進程
killall php-fpm #殺死所有php-fpm進程
/etc/rc.d/init.d/php-fpm start #啟動php-fpm
這次正常了。
cd /html/ #進入nginx默認網站根目錄
rm -rf /html/* #刪除默認測試頁
vi index.php #新建index.php文件
<?php
phpinfo();
?>
:wq! #保存
在客戶端瀏覽器輸入服務器IP地址,可以看到相關的配置信息!
/etc/rc.d/init.d/nginx restart #重啟restart stop start
/etc/rc.d/init.d/php-fpm restart #重啟restart stop start
/etc/rc.d/init.d/php-fpm restart #重啟restart stop start
nginx默認站點目錄是:/html/
MySQL數據庫目錄是:/var/mysql/data
關于CentOS 5.x,6.0如何編譯安裝Nginx1.2.3+MySQL5.5.15+PHP5.3.6就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。