天天看點

完全yum安裝LAMP環境并加載fastcgi子產品(首發)

1、前言

fastcgi的性能相信不用我多說各位都知道,這是我研究apache加載fastcgi子產品的動力。

經過一天的奮戰,終于成功地實作完全yum安裝環境下fastcgi子產品加載并配置成功。說實話筆者比較喜歡yum的簡單易用,同時創作本文時在baidu上參閱了很多技術文檔,暫時沒有發現非編譯安裝的資料,故而本文算是首發吧!

另外在這裡我要謝謝一些前輩的無私貢獻,創作出已經接近的技術文檔(僅fastcgi部分編譯安裝),同時也讓我更加堅信看官網會少走彎路。是以說,做技術的英文要不斷地修煉。

2、實驗部分

2.1、實驗環境

lampSer:

hostname=lamp-fcgi

ipaddress=10.168.0.171

client:

hostnmae=client

ipaddress=10.168.0.8

2.2、yum源的安裝

1

2

3

<code>yum -y </code><code>install</code> <code>https:</code><code>//dl</code><code>.fedoraproject.org</code><code>/pub/epel/epel-release-latest-6</code><code>.noarch.rpm</code>

<code>yum -y </code><code>install</code> <code>httpd mod_proxy_fcgi php-fpm mysql mysql-server php-mysql</code>

<code>yum -y </code><code>install</code> <code>policycoreutils-python</code>

2.3、配置部分

2.3.1、step1

注:如果你不想了解fastcgi的加載方式本步驟請直接跳過

檢查是否引入fastcgi子產品(預設開啟),主配置檔案:

<code>grep</code> <code>^Include </code><code>/etc/httpd/conf/httpd</code><code>.conf</code>

包含如下内容:

<code>Include conf.d/*.conf</code>

檢視fastcgi支援子產品配置檔案:

<code>grep</code> <code>LoadModule </code><code>/etc/httpd/conf</code><code>.d</code><code>/mod_proxy_fcgi</code><code>.conf</code>

<code>LoadModule proxy_fcgi_module modules</code><code>/mod_proxy_fcgi</code><code>.so</code>

2.3.2、step2

1)啟動php-fpm、httpd&amp;mysqld服務:

4

5

6

<code>/etc/init</code><code>.d</code><code>/php-fpm</code> <code>start</code>

<code>chkconfig php-fpm on</code>

<code>/etc/init</code><code>.d</code><code>/httpd</code> <code>start</code>

<code>chkconfig httpd on</code>

<code>/etc/init</code><code>.d</code><code>/mysqld</code> <code>start</code>

<code>chkconfig mysqld on</code>

注:關于mysql的安全設定請運作以下指令,這裡不再詳述!

<code>mysql_secure_installation</code>

2)确認php-fpm服務啟用

<code>netstat</code> <code>-anp | </code><code>grep</code> <code>php</code>

應當顯示如下:

<code>tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      2547</code><code>/php-fpm</code>

<code>unix  3      [ ]         STREAM     CONNECTED     34665  2547</code><code>/php-fpm</code>

<code>unix  3      [ ]         STREAM     CONNECTED     34664  2547</code><code>/php-fpm</code>

2.3.3、step3

1)vim編輯/etc/httpd/conf/httpd.conf

啟用并更改ServerName(去掉ServerName前面的#)

啟用NameVirtaulHost(去掉ServerName前面的#)

<code>ServerName www.cmdschool.org:80</code>

<code>NameVirtualHost *:80</code>

2)建立虛拟目錄:

<code>mkdir</code> <code>/var/www/www</code><code>.cmdschool.org</code>

3)添加測試頁面:

<code>echo</code> <code>'&lt;?php phpinfo(); ?&gt;'</code> <code>&gt; </code><code>/var/www/www</code><code>.cmdschool.org</code><code>/index</code><code>.php</code>

4)確定selinux是Enforcing狀态:

<code>getenforce</code>

5)恢複預設的selinux type:

<code>restorecon -RFvv </code><code>/var/www/www</code><code>.cmdschool.org/</code>

顯示如下:

<code>restorecon reset </code><code>/var/www/www</code><code>.cmdschool.org</code><code>/index</code><code>.php context unconfined_u:object_r:httpd_sys_content_t:s0-&gt;system_u:object_r:httpd_sys_content_t:s0</code>

6)檢查目前的selinux type:

<code>ll -dZ </code><code>/var/www/www</code><code>.cmdschool.org/</code>

7)開啟虛拟目錄對fastcgi的支援并設定虛拟目錄:

vim編輯/etc/httpd/conf.d/www.cmdschool.org.conf

7

8

9

10

11

<code>DirectoryIndex </code><code>/index</code><code>.php index.php</code>

<code>&lt;VirtualHost *:80&gt;</code>

<code>    </code><code>ProxyPassMatch ^/(.*\.php(/.*)?)$ fcgi:</code><code>//127</code><code>.0.0.1:9000</code><code>/var/www/www</code><code>.cmdschool.org/$1</code>

<code>    </code><code>DocumentRoot </code><code>/var/www/www</code><code>.cmdschool.org</code>

<code>    </code><code>ServerName www.cmdschool.org</code>

<code>&lt;</code><code>/VirtualHost</code><code>&gt;</code>

<code>&lt;Directory </code><code>/var/www/www</code><code>.cmdschool.org&gt;</code>

<code>    </code><code>Options All</code>

<code>    </code><code>AllowOverride all</code>

<code>&lt;</code><code>/Directory</code><code>&gt;</code>

8)重新開機php-fpm&amp;httpd服務:

<code>/etc/init</code><code>.d</code><code>/php-fpm</code> <code>restart</code>

<code>/etc/init</code><code>.d</code><code>/httpd</code> <code>restart</code>

2.3.4、step4

設定防火牆:

vim編輯/etc/sysconfig/iptables

<code>-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT</code>

重新開機防火牆:

<code>/etc/init</code><code>.d</code><code>/iptables</code> <code>restart</code>

2.4.5、step5

In client

測試伺服器

1)vim編輯/etc/hosts

確定包含www.cmdschool.org的指向10.168.0.171的唯一值:

<code>10.168.0.171 www.cmdschool.org</code>

2)curl測試

<code>curl www.cmdschool.org</code>

3)浏覽器測試

<a href="http://s3.51cto.com/wyfs02/M02/75/4D/wKiom1Y1Q8rzTVEVAASArOO087I487.jpg" target="_blank"></a>

本文轉自 tanzhenchao 51CTO部落格,原文連結:http://blog.51cto.com/cmdschool/1708237,如需轉載請自行聯系原作者