利用lamp架构搭建Discuz论坛,并实现对数据库的高可用
admin
2023-05-25 20:41:21
0

lamp架构=LAMP指的Linux(操作系统)、Apache(HTTP 服务器),MySQL(数据库软件) 和PHP(有时也是指Perl或Python) 的第一个字母,一般用来建立web 服务器。

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用



#############源码安装php###########

tar jxf php-5.6.20.tar.bz2

cd php-5.6.20

解决依赖性:

yum install freetype-devel libmcrypt-2.5.8-9.el6.x86_64.rpm net-snmp-devel libmcrypt-devel-2.5.8-9.el6.x86_64.rpm libpng-devel gmp-devel libjpeg-turbo-devel libcurl-devel libxml2-devel -y

检测依赖性:

[root@server1 php-5.6.20]# ./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 --without-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-mhash --with-mysql --with-mysqli --with-pdo-mysql --enable-mysqlnd

没有报错之后就可以执行以下操作:

[root@server1 php-5.6.20]# make && make install

[root@server1 php-5.6.20]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini

[root@server1 php-5.6.20]# cd /usr/local/lnmp/php/etc/

[root@server1 etc]# cp php-fpm.conf.default php-fpm.conf

cd /mnt/php-5.6.20/sapi/fpm/

[root@server1 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm

[root@server1 fpm]# chmod +x /etc/init.d/php-fpm

[root@server1 fpm]# cd /usr/local/lnmp/php/etc/

[root@server1 etc]# vim php-fpm.conf#取消25行的注释

 25 pid = run/php-fpm.pid

 

[root@server1 etc]# vim php.ini ##修改时区

925 date.timezone = 'Asia/Shanghai'

[root@server1 etc]# /etc/init.d/php-fpm start

Starting php-fpm  done

[root@server1 etc]# cd /usr/local/

[root@server1 local]# cd nginx/sbin/

[root@server1 sbin]# ls

nginx

[root@server1 sbin]# pwd

/usr/local/nginx/sbin

[root@server1 sbin]# vim ~/.bash_profile

PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin

 

[root@server1 sbin]# source ~/.bash_profile

[root@server1 sbin]# nginx -t

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

 

 cd /usr/local/nginx/conf

[root@server1 conf]# vim nginx.conf

 49         location / {

 50             root   html;

 51             index index.php index.html index.htm;#调整优先级,先看index.php

 52         }

 

 71         location ~ \.php$ {

 72             root           html;

 73             fastcgi_pass   127.0.0.1:9000;

 74             fastcgi_index  index.php;

 75             fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;

 76             include        fastcgi.conf;

[root@server1 conf]# nginx

[root@server1 conf]# nginx -t

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

[root@server1 conf]# cd ..

[root@server1 nginx]# cd html/

[root@server1 html]# vim nginx.php

phpinfo()

?>

找到当前主机mysql的缓存文件

[root@server1 mysql]# ll /var/lib/mysql/mysql.sock

srwxrwxrwx 1 mysql mysql 0 3月  23 17:16 /var/lib/mysql/mysql.sock

 

cd /usr/local/lnmp/php/etc

[root@server1 etc]# vim php.ini

#默认数据存储在/var/lib/mysql/mysql.sock这个文件中

1001 pdo_mysql.default_socket=/var/lib/mysql/mysql.sock

1150 mysql.default_socket =/var/lib/mysql/mysql.sock

1209 mysqli.default_socket =/var/lib/mysql/mysql.sock

[root@server1 etc]# /etc/init.d/php-fpm reload

Reload service php-fpm  done

 

测试:

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

Php安装成功!

 

 

 

 

Heartbeat + mysql +drbd

三个部分分别提供了高可用,数据库,以及存储服务。将之后的论坛整合成一个完整的体系

说明:server3server4提供以上三个服务

1数据库

直接yum install mysql-server -y  #server3server4都做

mysql_secure_installation#安全初始化,设置root密码,否则数据库不要密码也能登陆

 

2.Heartbeat

[root@server3 heartbeat]# ls

heartbeat-3.0.4-2.el6.x86_64.rpm        heartbeat-libs-3.0.4-2.el6.x86_64.rpm

heartbeat-devel-3.0.4-2.el6.x86_64.rpm  ldirectord-3.9.5-3.1.x86_64.rpm

Server3server4都要安装

[root@server3 heartbeat]# yum install * -y

[root@server3 heartbeat]# cd /etc/ha.d/

[root@server3 ha.d]# ls

harc  rc.d  README.config  resource.d  shellfuncs

[root@server3 ha.d]# cp /usr/share/doc/heartbeat-3.0.4/{authkeys,ha.cf,haresources} .

[root@server3 ha.d]# vim ha.cf

48 keepalive 2

56 deadtime 30

76 udpport 1111

91 bcast   eth0

157 auto_failback on

211         node    server3.example.com

212         node    server4.example.com

222 ping 172.25.50.250

254 respawn hacluster /usr/lib64/heartbeat/ipfail

262 apiauth ipfail gid=haclient uid=hacluster

 

[root@server3 ha.d]# vim authkeys

 23 auth 1

 24 1 crc

 25 #2 sha1 HI!

 26 #3 md5 Hello!

[root@server3 ha.d]# vim haresources

在文件最后添加:

server3.example.com IPaddr::172.25.50.200/24/eth0 drbddisk::homework Filesystem::/dev/drbd2::/var/lib/mysql::ext4 mysqld

 

##做测试可以用:server3.example.com IPaddr::172.25.50.200/24/eth0 mysqld(上面的是针对drbd所作的)

 

[root@server3 ha.d]# scp ha.cf haresources authkeys 172.25.50.40:/etc/ha.d/

两边都重新启动heartbeat

3.drbd共享存储

server3server4都划分一个4G的虚拟磁盘

[root@server3 mnt]# fdisk -l

Disk /dev/vdb: 4294 MB, 4294967296 bytes

16 heads, 63 sectors/track, 8322 cylinders

Units = cylinders of 1008 * 512 = 516096 bytes

Sector size (logical/physical): 512 bytes / 512 bytes

I/O size (minimum/optimal): 512 bytes / 512 bytes

Disk identifier: 0x00000000

 

[root@server4 drbd]# fdisk -l

Disk /dev/vda: 4294 MB, 4294967296 bytes

16 heads, 63 sectors/track, 8322 cylinders

Units = cylinders of 1008 * 512 = 516096 bytes

Sector size (logical/physical): 512 bytes / 512 bytes

I/O size (minimum/optimal): 512 bytes / 512 bytes

Disk identifier: 0x00000000

 

安装以下rpm

drbd-8.4.2-2.el6.x86_64.rpm

drbd-bash-completion-8.4.2-2.el6.x86_64.rpm

drbd-heartbeat-8.4.2-2.el6.x86_64.rpm

drbd-km-2.6.32_431.el6.x86_64-8.4.2-2.el6.x86_64.rpm

drbd-pacemaker-8.4.2-2.el6.x86_64.rpm

drbd-udev-8.4.2-2.el6.x86_64.rpm

drbd-utils-8.4.2-2.el6.x86_64.rpm

drbd-xen-8.4.2-2.el6.x86_64.rpm

[root@server3 drbd]# rpm -ivh *

Server4也需要安装这些rpm

[root@server3 mnt]# cd /etc/drbd.d/

[root@server3 drbd.d]# ls

global_common.conf

[root@server3 drbd.d]# vim homework.res

[root@server3 drbd.d]# cat homework.res

resource homework {

meta-disk internal;

device /dev/drbd2;#自定义的共享磁盘名称

syncer {verify-alg sha1;

}

on server3.example.com {#节点的hostname

disk /dev/vdb;#自身主将用来设置成共享的磁盘路径

address 172.25.50.30:7789;#节点ip

}

on server4.example.com {

disk /dev/vda;

address 172.25.50.40:7789;

}

}

这样就无需担心发布共享磁盘名称不一样如何解决的问题了

[root@server3 drbd.d]# scp homework.res 172.25.50.40:/etc/drbd.d/

[root@server3 drbd.d]# drbdadm create-md homework

##server3server4都做

  --==  Thank you for participating in the global usage survey  ==--

The server's response is:

Writing meta data...

initializing activity log

NOT initializing bitmap

New drbd meta data block successfully created.

[root@server3 drbd.d]# /etc/init.d/drbd start#server4同时启动

Starting DRBD resources: [

     create res: homework

   prepare disk: homework

    adjust disk: homework

     adjust net: homework

]

[root@server3 drbd.d]# cat /proc/drbd

version: 8.4.2 (api:1/proto:86-101)

GIT-hash: 7ad5f850d711223713d6dcadc3dd48860321070c build by root@server1.example.com, 2017-02-21 09:59:13

 

 1: cs:Connected ro:Secondary/Secondary ds:Inconsistent/Inconsistent C r-----

    ns:0 nr:0 dw:0 dr:0 al:0 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:4194140

[root@server3 drbd.d]# drbdadm primary homework --force

[root@server3 drbd.d]# mkfs.ext4 /dev/drbd2

[root@server3 mnt]# mount /dev/drbd2 /mnt/mount/

[root@server3 mnt]# cd mount/

[root@server3 mount]# ls

lost+found

[root@server3 mount]# touch 111

[root@server3 mount]# ls

111  lost+found

[root@server3 mount]# cd ..

[root@server3 mnt]# umount /mnt/mount/

[root@server3 mnt]# drbdadm secondary homework

[root@server4 drbd.d]# drbdadm primary homework

[root@server4 drbd.d]# vim homework.res

[root@server4 drbd.d]# mount /dev/drbd2 /mnt/mount/

[root@server4 drbd.d]# cd /mnt/mount/

[root@server4 mount]# ls

111  lost+found

[root@server4 mnt]# umount /mnt/mount/

[root@server4 mnt]# drbdadm secondary homework

 

在挂载的目录下看到在server3上创建的文件,说明分布式共享存储配置成功

 

Heartbeat+mysql

关闭两台虚拟机的 heartbeat 服务

[root@server3 mnt]# /etc/init.d/mysqld stop

[root@server3 mnt]# drbdadm primary homework

[root@server3 mnt]# mount /dev/drbd2 /mnt/mount/

 

[root@server3 mount]# cd /var/lib/mysql/

[root@server3 mysql]# cp -r * /mnt/mount/

[root@server3 ~]# umount /mnt/mount/

[root@server3 ~]# mount /dev/drbd2 /var/lib/mysql/

[root@server3 ~]# chown mysql.mysql /var/lib/mysql/ -R

[root@server3 ~]# /etc/init.d/mysqld start

正在启动 mysqld:                                          [确定]

[root@server3 ~]# cd

[root@server3 ~]# /etc/init.d/mysqld stop

停止 mysqld:                                              [确定]

[root@server3 ~]# umount /var/lib/mysql/

[root@server3 ~]# drbdadm secondary homework

 

server3server4heartbeat服务打开服务会自动开启,当server3heatbeat服务关闭是。Vip172.25.50.200会调转到server4上。

 

最后:

整合

 

现在我们来搭建一个论坛

[root@server1 mnt]# unzip Discuz_X3.2_SC_UTF8.zip -d /usr/local/nginx/html/

##将这个论坛压缩包解压在nginx的默认发布目录中

 

[root@server1 mnt]# cd /usr/local/nginx/html/

[root@server1 html]# ls

50x.html  index.html  nginx.php  readme  upload  utility

[root@server1 html]# cd upload/

[root@server1 upload]# ls

admin.php  connect.php      forum.php  member.php  search.php  uc_server

api        cp.php           group.php  misc.php    source      userapp.php

api.php    crossdomain.xml  home.php   plugin.php  static

archiver   data             index.php  portal.php  template

config     favicon.ico      install    robots.txt  uc_client

[root@server1 upload]# chmod 777 config/

[root@server1 upload]# chmod 777 data/ -R

[root@server1 upload]# chmod 777 uc_* -R

 

serer3上设置root用户可以远程登陆的权限

 grant all privileges on *.* to "root"@"%" identified  by "redhat";

Query OK, 0 rows affected (0.00 sec)

 

测试方法,在serer1上远程登陆172.25.50.200这个ip的数据库

并且在数据库中有解的权限即可。

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用 

 

在浏览器上:172.25.50.10/upload/

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

 

数据库写入测试:在server3

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

 

高可用测试:

关闭server3上的heartbeat服务。

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

利用lamp架构搭建Discuz论坛,并实现对数据库的高可用

如图,可以看见heartbeat服务停了之后,sererv4自动接管数据库,这时查看数据库内容与在server3上看到的一致!

实验成功!!!!!!!!!!!!!!!!!!!!!!!!


相关内容

热门资讯

青岛一排水沟出现蓝色水体,当地... 澎湃新闻记者 薛莎莎 实习生 陈芷若5月19日深夜,青岛市城阳区联合调查组发布通报:针对网友反映的城...
塞尔维亚总统武契奇将于5月24... 5月20日,据外交部网站消息,外交部发言人宣布:应国家主席习近平邀请,塞尔维亚总统武契奇将于5月24...
国家中医药管理局通报3・15晚... 针对2026年总台3·15晚会曝光的涉中医药领域违法违规问题,国家中医药管理局发布通报:针对辽宁沈阳...
回响∣一粒种子的无限可能 【编者按】由中共河南省委宣传部、河南广播电视台联合制作的理论宣传系列微视频《回响·第四季》正式上线!...
捷克总理最新涉华表态,中方回应 ‍‍5月20日,外交部发言人郭嘉昆主持例行记者会。有记者提问,据报道,捷克总理巴比什近日在捷媒发表评...
固强新材料取得防缠绕搅拌叶片组... 国家知识产权局信息显示,浙江固强新材料有限公司取得一项名为“一种防缠绕的搅拌叶片组件”的专利,授权公...
一人公司加速崛起 中国城市竞逐... [ 当技术让个人的能力边界不断扩展,当政策让创业的门槛不断降低,“一个人就是一支队伍”正在成为现实。...
群核科技空间智能大模型完成国家... 央广网北京5月20日消息(记者 刘家怡)5月18日,浙江省互联网信息办公室发布浙江省生成式人工智能服...
“OpenAI联创”Karpa... AI圈最知名的技术布道者,“Vibe Coding之父”,选择了OpenAI最强劲的对手。 5月19...
坚定不移沿着习近平总书记指引的... 兰考县政务服务中心帮办代办人员指导居民办理业务。 河南日报全媒体记者 马青竹 摄敞亮的大厅内秩序井然...