恢復更新後的第一篇博文, 前段時間因爲各類理由, 把博客更新給宕掉了, 我的獨立博客的開發也擱淺了, 如今隨着工做的逐步穩定, 決心把博客從新恢復更新, 繼續記錄着代碼路上的一點一滴。php
在上篇博文中提到, 筆者將把工做和學習環境全面轉移到Linux, 轉移也沒什麼目的, Windows用久了, 換個口味。目前使用的Linux環境是 Ubuntu 14.04, 該版本是一個長期支持版本, 對於想試一試Linux系統的朋友, 也是值得推薦的。html
筆者於昨天新入手了一個 VPS, 來做爲我的博客wid實驗室(widlabs.com)開發的實驗環境。因此在這篇博文中, 將介紹 CentOS 6 下 LNMP HTTP 環境的搭建, 從使用 ssh 登陸VPS講起, 一直到將域名解析到服務器IP上這一完整的網站搭建流程。mysql
新入手的VPS基本配置以下:nginx
在Linux下, 要遠程管理一臺服務器, 是很是輕鬆愉快的一件事, ssh 命令用來登陸遠程主機, 登陸後進入shell命令行模式, 而後就像在終端操做本身機器的同樣來操做遠程主機就能夠了, 惟一須要注意的就是不要把命令寫錯了, 如 rm -rf ./* 寫成 rm -rf /* 。sql
ssh 命令的通常用法爲: shell
ssh 用戶名@主機名 -p 主機ssh服務端口號
ssh服務的默認端口號爲22, 當使用默認端口時, -p選項是可選的, 第一次遠程鏈接某個主機時, 會提示主機真實性不能確認, 詢問是否繼續(yes/no), 輸入"yes"繼續便可鏈接, 以登陸 198.98.117.120 爲例:瀏覽器
carey@E530:~$ ssh root@198.98.117.120 -p 22
scp命令可實現從本機與遠程主機間文件的相互複製, 基於ssh服務, 通常用法以下:服務器
從本機複製文件到遠程主機: ssh
scp -P ssh服務端口號 本地文件路徑 目標主機用戶名@主機名:存放路徑
從遠程主機複製文件到本地: php-fpm
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
首先查看下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、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 所需依賴
[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直接經過yum方式安裝便可:
[root@widlabs ~]# yum install mysql mysql-server mysql-devel
[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; #} }
[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是否已正常工做。
[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
登陸域名服務商提供的管理面板, 選擇域名解析, 類型選擇A記錄, 記錄值爲指向的主機IP。
到這裏, 整個LNMP的HTTP基礎環境就算搭建完成了。