Nginx/PHP + HeartBeat + DRBD + MySql
php
1、項目簡介html
a) 主機服務器上下載並配置Nginx/PHP 服務,採用Nginx作代理,讓Discuz 社區軟件運行在Nginx/html/目錄下mysql
b) 數據庫服務器上 下載DRBD,而且將MySql數據庫數據加載在DRBD服務上,在又HeartBeat統一作雙機熱備,保證數據庫的安全,穩定的運行。nginx
2、下載並配置Nginx/PHPsql
1.下載配置Nginx數據庫
(1)在官網上下載穩定版的nginx,目前使用的爲nginx-1.10.3。vim
(2)配置源碼,並連接位置api
./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-http_stub_status_module瀏覽器
make && make 安全
ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/
(3)經常使用命令
nginx [開啓]
nginx -s reload[重載]
nginx -s stop[關閉]
(4)隱藏(應該是刪除版本號)nginx 版本號
2.配置 nginx.conf文件
[單核的話,工做鏈接數就1024*核數=1024嘍!]
[開啓PHP頁面加載的功能~]
2.在安裝添加PHP測試頁面(/user/lcoal/nginx/html/index.php)
2.下載配置PHP
下載 php-5.6.20.tar.bz2
(1)解決依賴性(具體安裝提示可看報錯信息,不過我仍是建議你先安裝下面這些,有時報錯信息會迷惑你(我不會告訴你位被迷惑過,浪費了一成天時間。。))
yum install net-snmp-devel curl-devel libxml2-devel libpng-devel libjpeg-devel freetype-devel gmp-devel openldap-devel -y
(2)配置源碼
./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --with-openssl --with-snmp --with-gd --with-zlib --with-curl --with-libxml-dir --with-png-dir --with-jpeg-dir --with-freetype-dir --with-out-pear --with-gettext --with-gmp --enable-inline-optimization --enable-soap --enable-ftp --enable-sockets --enable-mbstring --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --with-mcrypt --with-mysql --with-pdo-mysql --enable-mysqlnd
cp php.ini-production /usr/local/lnmp/php/etc/php.ini
cd /usr/local/lnmp/php/etc/
cp php-fpm.conf.default php-fpm.conf
cp/php-5.6.20/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm [配置啓動項目]
chmod +x /etc/init.d/php-fpm
(3)修改配置信息(vim /usr/local/lnmp/php/etc/php.ini )
1.date.timezone = 'Asia/shanghai'
2.pdo_mysql.default_socket=/usr/local/lnmp/mysql/data/mysql.sock[一共有三處,這個地址是源碼編譯的mysql.sock 地址,具體地址依據狀況而定]
3、添加 drbd(分佈式複製塊設備存儲)
1所用軟件下載
drbd-8.4.2.tar.gz(tar -zxf 解壓);
yum install -y gcc
2.執行./configure --enable-spec 和 ./configure --enbale-spec --with-km,
(a)按照提示(所需) 依次下載軟件(flex,rpm-build,等)
生成drbd.spec,drbd-km.spec,drbd-kernel.spec 等文件,用來製做rpm包
3.rpmbuild -bb drbd.spec 和 rpmbuild -bb drbd-km.spec 安裝以前下載
cp drbd-8.4.2.tar.gz ~/rpmbuild/SOURCES/
執行完上述操做以後會在 ~/rpmbuild/RPMS/x86_64 下生成8個drbd-*包,安裝(rpm -ivh *)它們,且發送給其它節點機並安裝。
4.**在/etc/drdb.d/ 中編輯自定義文件,此文件很是重要,即drbd服務所加載的服務機及其向關信息。
(a)在配置文件以前,向每一個虛擬機添加兩塊4G的虛擬網卡
(b) vim /etc/drdb.d/example.res
resource example {
meta-disk internal;
device /dev/drbd1;
syncer {
verify-alg sha1;
}
on server3.example.com {
disk /dev/vdb;
address 172.25.254.163:7789;
}
on server4.example.com {
disk /dev/vdb;
address 172.25.254.164:7789;
}
}
(c)scp example.com --> 172.25.254.164
(d)每個節點機都要進行drbd服務添加,drbdadm create-md example,而且開啓drbd服務
(e)設置主/備機,而且進行強行同步存儲內容
drbdadm primary/secondary example --force [那個機子操做此命令那個爲主/輔,而且強行同步信息,輔助不用--force]
watch cat /proc/drbd [能夠查看同步內容的進程]
(f)同步好了以後製做文件系統而且掛載(mkfs.ext4),這樣/dev/drbd 設備的內容就能夠同步了。
在掛載設備時,首先要設置當前機爲主,再進行mount 操做
drbdadm primary/secondary example
四、添加 mysql數據庫,並完成節點服務異常時,自動轉移服務到另外一個節點。
1.完善掛載mysql點
(1)在主節點中下載mysql-server
a.掛載 mount /dev/drbd1 /var/lib/mysql/,進入/var/lib/mysql,將其主組都該爲 mysql(chown mysql.mysql ~ -R)
b.此時,切換主輔 掛載 /dev/drbd1/ 到 /var/lib/mysql 開啓mysqld,就能夠達成mysql 數據庫數據共享了。
2.設置服務自動掛載,而且基於heartbeat 的服務轉移的策略
配置 /etc/ha.d/haresources
[行標]
150 server3.example.com IPaddr::172.25.254.168/24/eth0 drbddisk::example Filesystem::/dev/drbd1::/var/lib/mysql::ext4 mysqld
【主機名,VIP,加載drbd example文件,掛載文件系統/dev/drbd1 到 /var/lib/mysql ext4本地文件系統,mysql服務】
3.安全初始化MySql
4.在MySql數據庫中加一個遠程訪問的權限
這樣一來Discuz在安裝數據庫的時候就能夠遠程鏈接了)
5、Discuz社區版本
1.下載 Discuz_X3.2_SC_UTF8.zip
在 /usr/local/nginx/html 下解壓
unzip Discuz_x3.2_SC_UTF8.zip
2. 修改upload名稱爲hxl,而後打開瀏覽器,http://172.25.254.161/hxl/install/ 進行安裝
[安裝的時候根據提示,修改目錄權限]
這個是比較簡單啦!!
3.安裝遠程數據庫
4.成功界面
6、【核心】高可用存儲測試
1.服務正常的在server3.example.com上運行的數據庫信息
[drbd存儲也正常掛載]
2.關閉server3.example.com的heartbeat服務,數據庫信息正常的切換到server4.example.com數據庫服務備機上