麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 網站 > Apache > 正文

超級服務器apache+mysql+php+ssl之完全安裝攻略(1)

2024-08-27 18:28:49
字體:
來源:轉載
供稿:網友

最大的網站源碼資源下載站,

目的我們的目標是安裝一個允許我們托管多個網站的web服務器,其中一些是針對電子商務的安全解決方案,而大部分網站是通過連接一個數據庫服務器并且提取其數據的腳本驅動的。

為了這個任務所需的工具是:

apache-一個網站服務器

mod_ssl-一個安全套接字層(ssl)的模塊

openssl-開放源代碼工具箱(mod_ssl所需)

rsaref-僅對美國用戶

mysql-一個數據庫服務器

php-一種腳本語言

“條條大路通羅馬”……因此這只是很多能達到我們要求的配置之一。我選擇這樣的配置,是因為它是最簡單和最快的一種。選擇mod_ssl/openssl的原因是因為我有它的先前經驗,是最快配置和最容易安裝的一種。為了彼此方便地與apache集成,我選擇了php和mysql。記住,perl能做到你想要做任何工作,然而,php對任何想學習它地程序員來說簡單并且容易。

希望你將在結束這個簡單的指南后能成功地完成下列目標。

安裝并設置mysql數據庫服務器

o 知道怎樣檢查mysql服務器的狀態

o 知道怎樣使用命令行客戶程序存取mysql服務器

o 知道怎樣從web存取你的db服務器

安裝并設置具備ssl的apache網站服務器

o 配置一個簡單的虛擬網站

o 知道怎樣停止并啟動服務器

o 知道怎樣做一些基本的主機托管配置

安裝并配置服務器端腳本的php 4.0超文本預處理器

o 知道怎樣編寫簡單的php代碼

o 知道怎樣使用php連接一個db

o 創建一個啟用php地簡單網站與一個數據庫溝通

創造一些樣本證書用于apache ssl

o 知道怎樣產生一個csr文件

o 知道怎樣加密一個鍵碼

o 知道怎樣 簽署你自己的證書

本文將覆蓋大量的信息。本指南作為一個入門性地的指南,讓你步入電子商務、網站腳本和安全套接字層 (ssl)的世界,目的是幫助你建立由存儲在數據庫中的動態信息驅動的安全網站。

本文絕非是一個詳細全面的文檔,它當然將有一些錯誤(希望最小),在你閱讀它時請記住這一點。然而,它將激起你的熱情并運行前面提到的產品,希望讓你更好理解這些東西是怎樣工作的。不需要以前的編程知識,但假定你有點計算機知識背景。我的目標是編寫這個文檔以便任何新手能理解我正在談論的東西。如果我達到了,那么我做了一件好事。如果你輕而易舉地建立了電子商務站點,比我做的更出色:-) 給我一些解釋。

假設

本文假設你已經把下列軟件安裝在你的系統上了。

perl (最好是ver 5+)

gzip或gunzip

gcc 和 gnu make

如果你沒有安裝好這些,你將需要采取必要的步驟在解釋本文的任何過程前把他們安裝好。

你也需要對unix命令、html、和sql的一個基本了解。你應該有怎樣管理你的linux機器的一個基本了解。你也需要一個完全正常的linux機器,你將在它上面安裝軟件。當然你將需要在前面列出的必要的軟件包以編譯源代碼,并且最后,保證你還沒有在linux機器中預裝了mysql、apache、或php。

工作原理

理解在幕后發生了什么是有幫助的。這里是一個過分簡化的工作原理,下圖和隨后的解釋目前不是完全正確的,只是它的一個要點概述:

情況是:我們有一個從一個數據庫取出一些數據的網頁。john doe從他的瀏覽器請求該頁,請求被發送給web服務器,接著調用一個php腳本。php腳本由php預處理器解釋并從數據庫中取出數據,然后結果由余下的php腳本加工并轉化成html,做后的html被發回用戶的瀏覽器。

讓我們一步一步地看:

john doe 從他的瀏覽器中點擊一個鏈接;他的瀏覽器發送對http://www.yourserver.com/test.php的請求。

apache得到對test.php的請求,它知道.php文件應由php預處理器(mod_php)處理,因此它通知 php處理它。它知道這些,是因為我們在apache的配置中指定它。

test.php是包含命令的一個php腳本。這些命令之一是打開一個到一個數據庫的連接并抓取數據。php 處理到數據庫的連接,并且解釋sql調用從db中提取數據。

服務器服務器得到從php解釋器來的連接請求,并且處理這個請求。請求可能是類似于一個簡單的選擇語句,或數據庫表創建等。

數據庫然后將應答和結果回送到php解釋器。

apache回送該結果到john doe的瀏覽器,作為對他請求的應答。john doe現在看見一個包含從一個數據庫來的一些信息的網頁。

如果這是一個對https://www.yoursecureserver.com/test.php的請求,整個過程與上述類似,除了每個請求和應答在兩端被加密和解密,即,瀏覽器連接apache,獲得它的加密鍵碼,加密請求并發送它。

服務器看到請求,解密并且認證它。它處理文件,加密并且發送它。然后瀏覽器用服務器的鍵碼解密它。記住既然連接被加密,就是用不同的端口用。端口80用在在非安全連接上,而端口443用在安全連接時。

再說一次,它不是100%的正確,但是它足夠快地讓你知道幕后發生的事情的非常簡單的概述。

既然我們對我們正在試圖達到的目標有了一個很基本的了解,讓我們繼續安裝軟件吧。

準備

apache (web服務器)-http://www.apache.org

mod_ssl (安全服務器層)-http://www.modssl.org

openssl (ssl工具箱)-http://www.openssl.org

php (腳本語言)-http://www.php.net

mysql (sql數據庫服務器 )-http://www.mysql.com

下載所有(tar文件)源代碼到一個臨時目錄下。保證你把他們放在有很多空間的地方……你應該以root身份下載他們以避免權限問題。

我們的計劃

我們的計劃是首先安裝mysql服務器并保證它工作,然后我們將安裝php和mod_ssl,最后我們將安裝apache網站服務器。在我們安裝了apache以后,我們可以測試php和mod_ssl支持是否起作用了。

mysql源代碼安裝(unix)

你必須用來執行安裝mysql源代碼分發的基本命令是(自一個沒解開“tar”文件):

通過使用su成為 root用戶。

$su

直接進入你有tar文件的目錄。(使用一個臨時目錄。這里使用 /tmp/download/ )

#cd /tmp/download/

使用下列命令提取文件。

# gunzip -d -c mysql-3.22.xx.tar.gz | tar xvf -

改變到新目錄,它在提取期間創建。

# cd mysql-3.22.xx

現在你可以開始“配置”mysql服務器。你可以用configure指定很多選項,使用configure --help查看所有的選項。我已經選擇--prefix指定到安裝地點的直接路徑。configure將檢查你的編譯器和一些其他東西。如果你有任何錯誤,你可以檢查config.cache文件查看錯誤。

# configure --prefix=/usr/local/mysq

在你完成了配置以后,你可以執行下列命令make真正的二進制代碼。

# make

現在你已準備好安裝所有的二進制代碼。運行下列命令在你用configure --prefix選項指定的目錄下安裝二進制代碼。

# make install

在你安裝好二進制代碼后,現在是創建用于定義權限的mysql表的時候了。

# scripts/mysql_install_db

# cd /usr/local/mysql/bin

# ./safe_mysqld &

# ./mysqladmin -u root password "new-password"

注意:/usr/local/mysql是我選擇安裝mysql服務器的目錄。你可以通過改變目錄選擇另外的地方。

你可以通過運行一些簡單的測試來驗證服務器正在工作以確保mysql正在運行。輸出應該類似于下面所示的:bindir=/usr/local/mysql/bin。bindir依賴于你在上面的前綴選擇的目錄。

# bindir/mysqlshow -p

+---------------+

| databases |

+---------------+

| mysql |

+---------------+

一旦你安裝好mysql,它將自動地創建2個數據庫。一個mysql表,它控制在實際的服務器中用戶、主機和 數據庫權限;另一個是一個test數據庫,我們能使用test數據庫。然而,我們想給你一個快速而簡單的mysql可用的一些命令行選項的概述。這也將保證root被設置了對db服務器的全部存取權限,即:root有創建數據庫、數據庫表等的許可,因此我們將創建一個test2數據庫,在以后我們用它進行我們的測試。在你通過命令行進入mysql前,你將被提示root用戶的新口令。記住你以前改變了它。

# mysql -u root -p

mysql> show databases;

+----------------+

| database |

+----------------+

| mysql |

| test |

+----------------+

mysql> create database test2;

query ok, 1 row affected (0.00 sec)

現在選擇新的數據庫使用,并創建一個名為tst_tbl的新表, 有下列2個字段。字段1是是一個id字段,允許你知道記錄的id。實質上為了簡化這只是的一個行號。第二個字段是你一個name字段,存儲書名信息。這些字段的格式是:字段1(id)是一個長度為3的整數(int),而字段2(name)是一個長度為50的字符(char)字段。為搜索和索引數據,我們指定id為鍵碼。

mysql> use test2;

database changed

mysql> create table books ( id int(3) not null

-> auto_increment, name char(50) not null,

-> unique(id), primary key(id));

query ok, 0 rows affected (0.00 sec)

現在我們用下列命令驗證一切正確無誤。

mysql> show tables

+---------------------+

| tables in test2 |

+---------------------+

| books |

+---------------------+

1 row in set (0.00 sec)

mysql> describe books;

+-------+-------------+------+------+----------+------------------------+

| field | type | null | key | default | extra |

+-------+-------------+------+------+----------+------------------------+

| id | int(3) | | pri | 0 | auto_increment |

| name | char(50) | | | | |

+-------+-------------+------+------+----------+------------------------+

2 rows in set (0.00 sec)

注意到describe命令基本上“描述”了表的布局。相當不錯吧!

好,該試一些確實有用的sql命令,插入并從數據庫中選擇數據,現在把幾個記錄加到新表中。記住這些是簡單的書名記錄,但是一旦你獲得了sql足夠的經驗,你可以為一些大的電子商務站點創建確實復雜的數據庫。讓我們創建2本假想的書的2條記錄。第一條記錄是我在將來某天寫的一本書的名字-“php 4 newbies”,另一本是一個很有用的linux書,“red hat linux 6 server”, 由mohammed j. kabir所著。

mysql> insert into books (name) values("php 4 newbies");

query ok, 1 row affected (0.00 sec)

mysql> insert into books (name) values("red hat linux 6 server");

query ok, 1 row affected (0.00 sec)

現在我們可以檢查新紀錄,發出一條“選擇所有”命令

mysql> select * from books;

+----+----------------------------------+

| id | name |

+----+----------------------------------+

| 1 | php for newbies |

| 2 | red hat linux 6 server |

+----+----------------------------------+

2 rows in set (0.00 sec)

很好,mysql服務器完全起作用了。我們可以繼續加入,但是此時沒什么意義。注意到當你向數據庫中插入記錄時,你怎樣不必指定id號,這是因為你創建了啟用auto_increment選項的id字段。

讓我演示一下如何做一個快速刪除。這只是讓你知道,記住,你可在mysql的網站http://www.mysql.com上找到所需的有關mysql命令和服務器的所有信息。

mysql> delete from books where id=1;

query ok, 1 row affected (0.00 sec)

mysql> select * from books;

+----+-----------------------------------+

| id | name |

+----+-----------------------------------+

| 2 | red hat linux 6 server |

+----+-----------------------------------+

1 row in set (0.00 sec)

好了,退出mysql,繼續安裝。你可在完成所有安裝并且一切工作正常后玩mysql也不遲。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 在线日韩亚洲 | 黄色久| 久青草免费视频 | 成人9禁啪啪无遮挡免费 | 国产精品美女久久久久久不卡 | 欧美精品一区自拍a毛片在线视频 | 亚洲一区成人在线 | 精品亚洲成a人在线观看 | 可以免费看的av | 国产精品视频一区二区三区四区五区 | 精品视频 久久久 | 99在线精品视频免费观看20 | 激情宗合网 | 免费在线观看亚洲 | 日韩在线播放一区二区 | 特色一级黄色片 | 欧美女同hd | 97se亚洲综合在线韩国专区福利 | 蜜桃成品人免费视频 | 中文字幕在线一 | 久久精品国产亚洲7777 | 欧美视频在线一区二区三区 | 99视频在线观看视频 | 深夜免费视频 | 久久久噜噜噜久久熟有声小说 | 91精品国产九九九久久久亚洲 | 一级免费特黄视频 | av日韩在线免费观看 | 激情毛片| 欧美性生活久久 | 91网站链接 | 国产精品成年片在线观看, 激情小说另类 | 中文字幕国产亚洲 | 久久精品女人天堂av | 久久久久久精 | 黄色免费小视频网站 | 毛片成人网 | 性生活视频网站 | 精品日韩欧美 | 欧美一级棒 | 久久激情国产 |