centos6.5安裝nginx+php+mysql
來自: http://my.oschina.net/odison/blog/614371
1.nginx 安裝
查看yum下nginx版本信息
yum list | grep nginx
發現版本太低,手動添加nginx的yum倉庫:
vi /etc/yum.repos.d/nginx.repo
內容:
[nginx] name=nginx repo baseurl=http://nginx.org/packages/centos/$releasever/$basearch/ gpgcheck=0 enabled=1
編輯保存之后再查看nginx版本
安裝:
yum install -y nginx
安裝完成之后可以通過 service nginx start 來啟動服務
注:
/etc/init.d/nginx start # 啟動Nginx服務 /etc/init.d/nginx stop # 停止Nginx服務 /etc/nginx/nginx.conf # Nginx配置文件位置
nginx的安裝到此完成,啟動之后可以在瀏覽器ip訪問,會顯示nginx的頁面
2.安裝php、php-fpm
先下載php5.6版本,下載的源碼放在/usr/local/src/ 下
cd /usr/local/src/ wget tar -zcvf php-5.6.8.tar.gz
編譯php需要一些依賴包:
yum install -y libxml2 libxml2-devel openssl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libmcrypt libmcrypt-devel mcrypt mhash
configure:
./configure --prefix=/usr/local/php5 --with-config-file-path=/usr/local/php5/etc --enable-fpm --disable-ipv6 --enable-pdo --with-pdo-mysql --with-openssl --with-mcrypt --with-mhash --enable-json --enable-mbstring --with-gd --with-openssl-dir --with-jpeg-dir --with-png-dir --with-zlib-dir --with-freetype-dir --enable-gd-native-ttf --enable-gd-jis-conv --enable-zip
安裝:
make make install
安裝完成之后設置fpm
cp /usr/local/php5/etc/php-fpm.conf.default /usr/local/php5/etc/php-fpm.conf vi php-fpm.conf // 找到如下幾行,確保如下幾行前沒有”;” pid = run/php-fpm.pid error_log = log/php-fpm.log log_level = notice listen = 127.0.0.1:9000 pm = dynamic pm.max_children = 50 pm.start_servers = 20 pm.min_spare_servers = 5 pm.max_spare_servers = 35 pm.max_requests = 500
pm表示使用哪種方式,有兩個值可以選擇,就是static(靜態)或者dynamic(動態)。在更老一些的版本中,dynamic被稱作apache-like。這個要注意看配置文件的說明。
下面4個參數的意思分別為:
pm.max_children:靜態方式下開啟的php-fpm進程數量。
pm.start_servers:動態方式下的起始php-fpm進程數量。
pm.min_spare_servers:動態方式下的最小php-fpm進程數量。
pm.max_spare_servers:動態方式下的最大php-fpm進程數量。
如果dm設置為static,那么其實只有pm.max_children這個參數生效。系統會開啟設置數量的php-fpm進程。
如果dm設置為 dynamic,那么pm.max_children參數失效,后面3個參數生效。
系統會在php-fpm運行開始 的時候啟動pm.start_servers個php-fpm進程,
然后根據系統的需求動態在pm.min_spare_servers和 pm.max_spare_servers之間調整php-fpm進程數。
利用php自帶的php-fpm管理工具,可以很方便的start,stop,restart
把管理工具從源碼包里放到php5/sbin文件夾里,方便使用
cp /usr/local/php-5.6.8/sapi/fpm/init.d.php-fpm /usr/local/php5/sbin/ cd /usr/local/php5/sbin/ chmod 755 init.d.php-fpm ./init.d.php-fpm start Starting php-fpm done
3.安裝MYSQL-Server
(只針對centos 6.5 64)
略去查看操作系統版本...
cd /usr/local/src/ mkdir mysql-server-5.6.21
下載三個rpm軟件包:
MySQL-client-5.6.21-1.rhel5.x86_64.rpm
MySQL-devel-5.6.21-1.rhel5.x86_64.rpm
MySQL-server-5.6.21-1.rhel5.x86_64.rpm
cd mysql-server-5.6.21 wget http://dev.mysql.com/Downloads/MySQL-5.6/MySQL-server-5.6.21-1.rhel5.x86_64.rpm wget http://dev.mysql.com/Downloads/MySQL-5.6/MySQL-devel-5.6.21-1.rhel5.x86_64.rpm wget http://dev.mysql.com/Downloads/MySQL-5.6/MySQL-client-5.6.21-1.rhel5.x86_64.rpm
安裝依賴:
yum install -y libaio
安裝mysql
rpm -ivh MySQL-server-5.6.21-1.rhel5.x86_64.rpm rpm -ivh MySQL-client-5.6.21-1.rhel5.x86_64.rpm rpm -ivh MySQL-devel-5.6.21-1.rhel5.x86_64.rpm
修改配置文件
cp /usr/share/mysql/my-default.cnf /etc/my.cnf
初始化mysql
/usr/bin/mysql_install_db
啟動mysql
service mysql start
查看進程
ps -ef | grep mysql
netstat -anpt | grep 3306
安裝過程中會隨機生成root密碼并保存在/root/.mysql_secret 文件中,用more命令查看
more /root/.mysql_secret
然后用查詢的密碼登錄mysql
mysql -uroot -p******** #****為你查詢到的密碼
修改密碼
SET PASSWORD = PASSWORD('123456'); #123456 為你要設置的root密碼
配置mysqld 啟動mysql
cp /usr/share/mysql/mysql.server /etc/init.d/mysqld service mysqld start chkconfig mysqld on #設置開機啟動
到此mysql安裝完成
4.配置nginx支持php
cd /etc/nginx/ vi nginx.conf #打開gzip gzip on;
配置vhost,假設域名為www.a.com
cd /etc/nginx/conf.d/ vi www.a.com.conf #內容如下 server { listen 80; server_name www.a.com a.com; #讓不帶www的域名跳轉到帶www的域名 if($host != 'www.a.com') { rewrite ^(.*)$ http://www.a.com/$1 permanent; } location / { #開啟ssi支持shtml ssi on; ssi_silent_errors on; ssi_types text/shtml; index index.shtml index.php index.htm index.html; root /mnt/www/www.a.com; #框架路由設置 if ( !-e $request_filename ) { rewrite ^(.*)$ /index.php?url=$1 last; } } location ~\.php$ { root /mnt/www/www.a.com; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } location ~\.(jpg|jpeg|png|js|css) { root /mnt/www/www.a.com; expires 30d; } }
測試一下 配置文件是否有錯誤
/etc/init.d/nginx configtest nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful
在數據盤mnt上,新建文件夾/mnt/www/www.a.com,并新建info.php測試文件,內容為
<?php phpinfo(); ?>
在瀏覽器訪問www.a.com/info.php,能顯示信息則配置完成
5.phpMyAdmin 安裝配置
5.0 檢查并修改php對mysql和mysqli支持
phpinfo() 輸出可以看到當前php對mysql的支持程度,假設在頁面輸出信息里面并沒有找到mysql的支持
cd /usr/local/src/php-5.6.8/ext/mysql /usr/local/php5/bin/phpize #執行這句命令生成configure文件 ./configure --with-php-config=/usr/local/php5/bin/php-config --with-mysql=shared --enable-shared
編譯安裝 make && make install
mysqli的編譯過程也是類似
cd /usr/local/src/php-5.6.8/ext/mysqli /usr/local/php5/bin/phpize #執行這句命令在mysqli目錄下生成configure
此時可以查看目錄下是否生成了configure可執行文件
./configure --with-php-config=/usr/local/php5/bin/php-config --enable-embedded-mysqli=shared --enable-shared
沒有錯誤的話繼續
make make install
一切正常的話,此時會提示你 mysqli.so 生成,當然也可以全盤搜下
find / -name "mysqli.so" #拷貝 mysql.so mysqli.so 到 php5/ext/ cd /usr/local/php5/ mkdir ext cp /usr/local/php5/lib/php/extensions/no-debug-non-zts-20131226/mysqli.so /usr/local/php5/ext/ #mysqli.so 路徑為上面命令查找所得 cp /usr/local/php5/lib/php/extensions/no-debug-non-zts-20131226/mysql.so /usr/local/php5/ext/
切換到php5目錄查看php.ini 是否存在,不存在則拷貝源碼目錄下的
cd /usr/local/php5/etc vi php.ini #添加下面內容 extension_dir = "/usr/local/php5/ext"; extension = mysqli.so ; extension = mysql.so ;
5.1 安裝部署phpMyAdmin
下載phpMyAdmin (http://www.phpmyadmin.net/home_page/index.php),解壓后上傳到www目錄下(tar上傳解壓也行),把文件夾重命名為 phpMyAdmin,(方便訪問)
cd /mnt/www/phpMyAdmin cp config.sample.inc.php config.inc.php vi config.inc.php #修改以下內容 $cfg['blowfish_secret'] = 'www.oschina.com'; #這里的內容隨意設置,在cookie訪問模式下不能為空 /* Authentication type */ $cfg['Servers'][$i]['auth_type'] = 'cookie'; /* Server parameters */ $cfg['Servers'][$i]['host'] = '127.0.0.1'; #重要,這里設置成localhost有可能會出現phpMyAdmin無法訪問數據庫 $cfg['Servers'][$i]['connect_type'] = 'tcp'; $cfg['Servers'][$i]['compress'] = false; $cfg['Servers'][$i]['AllowNoPassword'] = false; $cfg['Servers'][$i]['user'] = 'root'; $cfg['Servers'][$i]['password'] = '111111'; #這里設置數據庫的密碼
上面的 host = 127.0.0.1 再強調一遍,設置成localhost有可能會無法訪問數據庫
接下來就是繼續配置nginx
cd /etc/nginx/conf.d/ vi phpmyadmin.conf
#文件內容 server { listen 9090; server_name localhost; #charset koi8-r; #access_log /var/log/nginx/log/host.access.log main; location / { ssi on; ssi_silent_errors on; ssi_types text/shtml; root /mnt/www/phpMyAdmin; index index.html index.htm index.php; if ( !-e $request_filename ) { rewrite ^(.*)$ /index.php?url=$1 last; } } location ~\.php$ { root /mnt/www/phpMyAdmin; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} location ~\.(jpg|jpeg|png|js|css) { root /mnt/www/phpMyAdmin; expires 30d; } }
保存退出后,重啟nginx服務,重啟mysqld服務,即可。