VPS CentOS-6 下 LNMP HTTP web服務器的搭建步驟
筆者于昨天新入手了一個 VPS, 來作為個人博客wid實驗室(widlabs.com)開發(fā)的實驗環(huán)境。所以在這篇博文中, 將介紹 CentOS 6 下 LNMP HTTP 環(huán)境的搭建, 從使用 ssh 登錄VPS講起, 一直到將域名解析到服務器IP上這一完整的網(wǎng)站搭建流程。
新入手的VPS基本配置如下:
虛擬化技術: OpenVZ操作系統(tǒng): CentOS-6 x86_64 BaseCPU: Intel(R) Xeon(R) CPU E3-1240 V2 @ 3.40GHz內(nèi)存: 2GB硬盤: 50GB HDD
一、準備工作 ssh登錄VPS、scp上傳文件
ssh 登錄VPS
在Linux下, 要遠程管理一臺服務器, 是非常輕松愉快的一件事, ssh 命令用來登錄遠程主機, 登錄后進入shell命令行模式, 然后就像在終端操作自己機器的一樣來操作遠程主機就可以了, 唯一需要注意的就是不要把命令寫錯了, 如 rm -rf ./* 寫成 rm -rf /* 。
ssh 命令的一般用法為:
ssh 用戶名@主機名 -p 主機ssh服務端口號
ssh服務的默認端口號為22, 當使用默認端口時, -p選項是可選的, 第一次遠程連接某個主機時, 會提示主機真實性不能確認, 詢問是否繼續(xù)(yes/no), 輸入"yes"繼續(xù)即可連接, 以登錄 198.98.117.120 為例:
carey@E530:~$ ssh root@198.98.117.120 -p 22
scp 上傳文件
scp命令可實現(xiàn)從本機與遠程主機間文件的相互復制, 基于ssh服務, 一般用法如下:
從本機復制文件到遠程主機:
scp -P ssh服務端口號 本地文件路徑 目標主機用戶名@主機名:存放路徑
從遠程主機復制文件到本地:
scp -P ssh服務端口號 目標主機用戶名@主機名:文件路徑 本機存放路徑
以上傳本次配置LNMP環(huán)境所需的文件為例, 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系統(tǒng)中預裝的一些軟件包:
yum list installed
清理掉自帶的Apache、PHP、MySQL服務(如果存在), 執(zhí)行命令:
yum remove httpd mysql-server mysql php
檢查是否已安裝GCC, 執(zhí)行命令 gcc -v 未安裝則執(zhí)行yum方式安裝:
yum install gcc
安裝GCC是必要的, 因為下面我們將對Nginx、PHP進行編譯方式安裝。
安裝 Nginx
創(chuàng)建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 命令可用, 則執(zhí)行:
[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 #可根據(jù)自身需要增加相應編譯選項
[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; #網(wǎng)站域名
#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 即為網(wǎng)站默認工作目錄
[root@widlabs html]# echo '<?php echo phpinfo(); ?>' > test.php #新建 test.php 作為php執(zhí)行測試
[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 網(wǎng)站服務的開機自啟動
[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基礎環(huán)境就算搭建完成了。
相關文章
Linux expect實現(xiàn)自動登錄腳本實例代碼
expect是一個基于Tcl的用于自動交互操作的工具語言,它適合用來編寫需要交互的自動化腳本,比如上面提到的SSH輸入用戶名密碼,自動FTP等等場景。下面這篇文章主要給大家介紹了關于Linux expect實現(xiàn)自動登錄腳本的相關資料,需要的朋友可以參考下。2018-03-03Ubuntu14.04服務器環(huán)境下配置PHP7.0+Apache2+Mysql5.7的方法
這篇文章主要介紹了Ubuntu14.04服務器環(huán)境下配置PHP7.0+Apache2+Mysql5.7的方法,較為詳細的分析了Ubuntu14.04操作系統(tǒng)環(huán)境下配置PHP7.0+Apache2+Mysql5.7的具體步驟與相關命令使用技巧,需要的朋友可以參考下2018-04-04