除錯環境:Redhat9.0Apache1.3.29Mysql3.23.58PHP4.3.4
Linux系統的安裝我就不講了,這是基本功,其實這篇文章在類似Redhat的其他linux也應該通用,大家只要掌握我提供的方法就行。記得安裝Redhat9。0的時候不要安裝系統預設的apache,mysql和php以及相關的軟體。已經安裝的請用rpm-e*刪除已經安裝的套件。
1.安裝Mysql3.23.58
其實老實說直接安裝Mysql官方網站提供的rpm包也是一個比較可行的辦法,他的官方網站的rpm包的提供基本跟tar包發行是同步的,這點我比較喜歡,至少安裝rpm包的在後面的調試中不會出現mysql庫檔案找不到的情況。但這裡還是有必要講一下自訂安裝的步驟,畢竟網友自訂安裝的還說挺多的。
軟體取得: http://www.mysql.com/downloads/index.html
安裝步驟:
tarzxvfmysql-3.23.58.tar.gz
cdmysql-3.23.58
./configure--prefix=/usr/local/mysql--sysconfdir=/etc--localstatedir=/var/lib/mysql
make
makeinstall
#prefix=/usr/local/mysqlmysql安裝的目標目錄
#sysconfdir=/etcmy.ini設定檔的路徑
#localstatedir=/var/lib/mysql資料庫存放的路徑
安裝完以後要初始化資料庫,當然你是升級的話不用做這步;
/usr/local/mysql/bin/mysql_install_db
如果系統沒有mysql這個使用者的話,最好做以下這一步:
useradd-Mord/var/lib/mysql-s/bin/bash-c"MySQLServer"-u27mysql
然後我啟動mysql
/usr/local/mysql/bin/safe_mysqld&
ok,先看看mysql能否正常運作
mysql-urootmysql
一般情況下都是無法正常連結資料庫,錯誤提示一般為:
ERROR2002:Can'tconnecttolocalMySQLserverthroughsocket'/var/lib/mysql/mysql.sock'(2)
其實網路上大家問的最多的都是整個問題,說什麼連結不到mysqld.sock,其實大家不妨看看mysql的錯誤日誌就明白怎麼回事,我這裡的錯誤日誌是在/var/lib/mysql/ *.err你會發現mysql只所以不能啟動,是因為/var/lib/mysql的權限不允許mysql服務訪問,英文mysql預設是呼叫mysql用戶來啟動服務的,好了,既然知道是什麼原因找到不能啟動,那就簡單了。我們只要 chown-Rmysql:mysql/var/lib/mysql就行,如果還是啟動不了,再慢慢調試權限,反正一般啟動不了都是權限的問題。
如果大家還是不能啟動不了的話,那就用我的比較繁瑣的權限的設置,反正我每次都是這麼做的,一般不會有問題,見下:
chown-Rroot/usr/local/mysql
chgrp-Rmysql/usr/local/mysql
chown-Rroot/usr/local/mysql/bin
chgrp-Rmysql/usr/local/mysql/bin
chgrp-Rmysql/var/lib/mysql
chmod777/var/lib/mysql
chown-Rroot/var/lib/mysql/mysql
chgrp-Rmysql/var/lib/mysql/mysql
chmod777/var/lib/mysql/mysql
chown-Rroot/var/lib/mysql/mysql/*
chgrp-Rmysql/var/lib/mysql/mysql/*
chmod777/var/lib/mysql/mysql/*
chmod777/usr/local/mysql/lib/mysql/libmysqlclient.a
做完上面的步驟,然後把你編譯目錄的一個腳本COPY過去
cpsupport-files/mysql.server/etc/rc.d/init.d/mysqld
chkconfig--addmysqld
用ntsysv設定使mysql每次啟動都能自動運作。
好了,至此mysql安裝完畢,你可以這樣啟動你的mysql服務
/etc/rc.d/init.d/mysqldstart
下面這步比較關鍵,
ln-s/usr/local/mysql/lib/mysql/usr/lib/mysql
ln-s/usr/local/mysql/include/mysql/usr/include/mysql
大家可以不做這步,大可以在編譯其他軟體的時候自訂myslq的函式庫檔路徑,但我還是喜歡把函式庫檔連結到預設的位置,這樣你在編譯類似PHP,Vpopmail等軟體時可以不用指定mysql的庫文件位址。