Nginx/PHP + HeartBeat + DRBD + MySql

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


wKioL1jVINXg72HAAAC8dX3xeVc385.png


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/


wKioL1jVINXRV1EyAABGAjoPVnM345.png


(3)經常使用命令

nginx [開啓]

nginx -s reload[重載]

nginx -s stop[關閉]

     (4)隱藏(應該是刪除版本號)nginx 版本號

wKiom1jVINfAnvCtAAC34UIqmI8974.png


2.配置 nginx.conf文件


wKiom1jVINjD5Vt3AADAz1zvFBc896.png

[單核的話,工做鏈接數就1024*核數=1024嘍!]



wKioL1jVINqCpsp7AACW4C6ONjo915.png

[開啓PHP頁面加載的功能~]

 


2.在安裝添加PHP測試頁面(/user/lcoal/nginx/html/index.php)

wKiom1jVINuiJw_4AAAKo_znt5c215.png

wKioL1jVINyRaVESAAEmlwAwSJM879.png


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'

wKioL1jVIN2iO_9vAACGSWIjQjA444.png


          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    安裝以前下載

wKiom1jVIN7zBAgeAABq-SEBTgg666.png

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服務

wKioL1jVIN-g1Zv7AACDF3SozME331.png


(e)設置主/備機,而且進行強行同步存儲內容

 drbdadm primary/secondary example --force  [那個機子操做此命令那個爲主/輔,而且強行同步信息,輔助不用--force]

wKiom1jVIOOj0r55AAB5aqsrN2I505.png

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



wKiom1jVIOSB-nF3AAAQrHZsodY229.png

wKioL1jVIObw7CoAAABpyWjrL3o746.png



4.MySql數據庫中加一個遠程訪問的權限


wKioL1jVIOezV-VZAABJCd3fwbY969.png

這樣一來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/ 進行安裝

wKiom1jVIOnSysLhAADFPv1R0-c240.png

[安裝的時候根據提示,修改目錄權限]

這個是比較簡單啦!!

3.安裝遠程數據庫


wKioL1jVIOuRSFtXAAEQQAl06_g571.png

wKiom1jVIPGTVUc4AAGeqF4Kpec497.png



4.成功界面


wKiom1jVIPuQ6fn9AAG800gNI4I458.png




6、【核心】高可用存儲測試

1.服務正常的在server3.example.com上運行的數據庫信息

spacer.gif 

wKioL1jVIPvRb9sZAAA1i6nT9vY676.png

wKioL1jVIP2QBHuEAADHd6CL_Ug450.png


wKioL1jVI_LyBvlKAABcinOPSpo404.png

[drbd存儲也正常掛載]

2.關閉server3.example.com的heartbeat服務,數據庫信息正常的切換到server4.example.com數據庫服務備機上

wKiom1jVIP_BydgQAAC5XO3jBtk062.png

wKiom1jVIQGx9IGuAADFY-RK6sY838.png

相關文章
相關標籤/搜索