VPS CentOS-6 下 LNMP HTTP服務器的搭建
前言
恢復更新后的第一篇博文, 前段時間由於各種理由, 把博客更新給宕掉了, 個人獨立博客的開發也擱淺了, 現在隨着工作的逐步穩定, 決心把博客重新恢復更新, 繼續記錄着代碼路上的一點一滴。
在上篇博文中提到, 筆者將把工作和學習環境全面轉移到Linux, 轉移也沒什么目的, Windows用久了, 換個口味。目前使用的Linux環境是 Ubuntu 14.04, 該版本是一個長期支持版本, 對於想試一試Linux系統的朋友, 也是值得推薦的。
筆者於昨天新入手了一個 VPS, 來作為個人博客wid實驗室(widlabs.com)開發的實驗環境。所以在這篇博文中, 將介紹 CentOS 6 下 LNMP HTTP 環境的搭建, 從使用 ssh 登錄VPS講起, 一直到將域名解析到服務器IP上這一完整的網站搭建流程。
新入手的VPS基本配置如下:
- 虛擬化技術: OpenVZ
- 操作系統: CentOS-6 x86_64 Base
- CPU: Intel(R) Xeon(R) CPU E3-1240 V2 @ 3.40GHz
- 內存: 2GB
- 硬盤: 50GB HDD
一、准備工作 ssh登錄VPS、scp上傳文件
ssh 登錄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 root@198.98.117.120 -p 22

scp 上傳文件
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 root@198.98.117.120:/home/upload
carey@E530:~/download$ scp -P 22 php-5.5.10.tar.gz root@198.98.117.120:/home/upload
二、編譯安裝 Nginx、PHP
首先查看下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、PHP
Nginx 的配置
[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.timezone date.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是否已正常工作。

六、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基礎環境就算搭建完成了。
