恢復更新后的第一篇博文, 前段時間由于各種理由, 把博客更新給宕掉了, 個人獨立博客的開發也擱淺了, 現在隨著工作的逐步穩定, 決心把博客重新恢復更新, 繼續記錄著代碼路上的一點一滴。
在上篇博文中提到, 筆者將把工作和學習環境全面轉移到linux, 轉移也沒什么目的, Windows用久了, 換個口味。目前使用的Linux環境是 Ubuntu 14.04, 該版本是一個長期支持版本, 對于想試一試Linux系統的朋友, 也是值得推薦的。
筆者于昨天新入手了一個 VPS, 來作為個人博客wid實驗室(widlabs.com)開發的實驗環境。所以在這篇博文中, 將介紹 CentOS 6 下 LNMP HTTP 環境的搭建, 從使用 ssh 登錄VPS講起, 一直到將域名解析到服務器ip上這一完整的網站搭建流程。
新入手的VPS基本配置如下:
在Linux下, 要遠程管理一臺服務器, 是非常輕松愉快的一件事, ssh 命令用來登錄遠程主機, 登錄后進入shell命令行模式, 然后就像在終端操作自己機器的一樣來操作遠程主機就可以了, 唯一需要注意的就是不要把命令寫錯了, 如rm -rf ./* 寫成 rm -rf /*。
ssh 命令的一般用法為:
ssh 用戶名@主機名 -p 主機ssh服務端口號
ssh服務的默認端口號為22, 當使用默認端口時, -p選項是可選的, 第一次遠程連接某個主機時, 會提示主機真實性不能確認, 詢問是否繼續(yes/no), 輸入"yes"繼續即可連接, 以登錄 198.98.117.120 為例:
carey@E530:~$ ssh [email protected] -p 22
scp命令可實現從本機與遠程主機間文件的相互復制, 基于ssh服務, 一般用法如下:
從本機復制文件到遠程主機:
scp -P ssh服務端口號 本地文件路徑 目標主機用戶名@主機名:存放路徑
從遠程主機復制文件到本地:
scp -P ssh服務端口號 目標主機用戶名@主機名:文件路徑 本機存放路徑
以上傳本次配置LNMP環境所需的文件為例, Nginx的源碼包 nginx-1.6.0.tar.gz, php的源碼包 php-5.5.10.tar.gz, 新起一個終端:
carey@E530:~/download$ scp -P 22 nginx-1.6.0.tar.gz [email protected]:/home/uploadcarey@E530:~/download$ scp -P 22 php-5.5.10.tar.gz [email protected]:/home/upload
首先查看下VPS的CentOS系統中預裝的一些軟件包:
yum list installed
清理掉自帶的Apache、PHP、MySQL服務(如果存在), 執行命令:
yum remove httpd mysql-server mysql php
檢查是否已安裝GCC, 執行命令 gcc -v 未安裝則執行yum方式安裝:
yum install gcc
安裝GCC是必要的, 因為下面我們將對Nginx、PHP進行編譯方式安裝。
安裝 Nginx創建Nginx、PHP專用用戶與用戶組
[root@widlabs ~]# groupadd www[root@widlabs ~]# useradd -s /sbin/nologin -M -g www nginx
安裝Nginx所需依賴
[root@widlabs ~]# yum install pcre-devel[root@widlabs ~]# yum install zlib-devel
進行nginx編譯安裝
[root@widlabs ~]# cd /home/upload #進入nginx源碼包所在目錄[root@widlabs upload]# tar tar zxvf nginx-1.6.0.tar.gz[root@widlabs upload]# cd nginx-1.6.0[root@widlabs nginx-1.6.0]# ./configure --PRefix=/usr/local/nginx --user=nginx --group=www --with-pcre[root@widlabs nginx-1.6.0]# make[root@widlabs nginx-1.6.0]# make install安裝 PHP
安裝 PHP 所需依賴
[root@widlabs nginx-1.6.0]# cd /home/upload #進入php源碼包所在目錄#若 wget 命令可用, 則執行:[root@widlabs upload]# wget ftp://mcrypt.hellug.gr/pub/crypto/mcrypt/libmcrypt/libmcrypt-2.5.6.tar.gz#注: wget不可用時, 可先 yum install wget, 或到 ftp://mcrypt.hellug.gr/pub/crypto/mcrypt/libmcrypt/ 下載libmcrypt-2.5.6.tar.gz源碼包, 再使用scp命令上傳到VPS;[root@widlabs upload]# tar zvxf libmcrypt-2.5.6.tar.gz[root@widlabs upload]# cd libmcrypt-2.5.6[root@widlabs libmcrypt-2.5.6]# ./configure --prefix=/usr/local/libmcrypt[root@widlabs libmcrypt-2.5.6]# make[root@widlabs libmcrypt-2.5.6]# make install[root@widlabs libmcrypt-2.5.6]# cd ..[root@widlabs upload]# yum install libxml2-devel
進行PHP編譯安裝
[root@widlabs upload]# tar zxvf php-5.5.10.tar.gz[root@widlabs upload]# cd php-5.5.10[root@widlabs php-5.5.10]# ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php --with-mysql --with-mysqli --with-pdo-mysql --enable-opcache --enable-mbstring --enable-mbregex --with-mcrypt=/usr/local/libmcrypt --with-mhash --enable-cgi --enable-fpm #可根據自身需要增加相應編譯選項[root@widlabs php-5.5.10]# make[root@widlabs php-5.5.10]# make install[root@widlabs php-5.5.10]# cp php.ini-development /usr/local/php/php.ini[root@widlabs php-5.5.10]# cd /usr/local/php/etc[root@widlabs etc]# cp php-fpm.conf.default php-fpm.conf三、安裝MySQL
MySQL直接通過yum方式安裝即可:
[root@widlabs ~]# yum install mysql mysql-server mysql-devel四、配置 Nginx、PHPNginx 的配置
[root@widlabs ~]# cd /usr/local/nginx/conf[root@widlabs conf]# cp nginx.conf nginx.conf.bak[root@widlabs conf]# vi nginx.conf
server { listen 80; server_name widlabs.com www.widlabs.com; #網站域名 #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm index.php; #添加 index.php } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ /.php$ { # proxy_pass http://127.0.0.1; #} # 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 /scripts$fastcgi_script_name; 改為 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; #} }PHP 的配置
[root@widlabs ~]# vi /usr/local/php/php.ini
[Date]; Defines the default timezone used by the date functions; http://php.net/date.timezonedate.timezone = PRC五、測試配置是否正確
[root@widlabs ~]# cd /usr/local/nginx/html #/usr/local/nginx/html 即為網站默認工作目錄[root@widlabs html]# echo '<?php echo phpinfo(); ?>' > test.php #新建 test.php 作為php執行測試[root@widlabs html]# service mysqld start #啟動MySQL服務[root@widlabs html]# /usr/local/php/sbin/php-fpm #啟動PHP FastCGI管理器[root@widlabs html]# /usr/local/nginx/sbin/nginx #啟動Nginx
通過瀏覽器訪問主機IP, 以及 test.php, 判斷Nginx是否已正常工作。
[root@widlabs ~]# vi /etc/rc.local
#!/bin/sh## This script will be executed *after* all the other init scripts.# You can put your own initialization stuff in here if you don't# want to do the full Sys V style init stuff.touch /var/lock/subsys/local#添加/sbin/service mysqld start/usr/local/php/sbin/php-fpm/usr/local/nginx/sbin/nginx
重啟VPS判斷開機自啟動是否正確:
[root@widlabs ~]# reboot now七、解析域名到服務器IP
登錄域名服務商提供的管理面板, 選擇域名解析, 類型選擇A記錄, 記錄值為指向的主機IP。
到這里, 整個LNMP的HTTP基礎環境就算搭建完成了。
新聞熱點
疑難解答