网页服务器和mysql服务器_实现Web服务器之间使用同一个MYSQL和相同的网页配置文件的方法...

实现Web服务器之间使用同一个MYSQL和相同的网页配置文件的方法

发布时间:2020-04-15 16:42:41

来源:亿速云

阅读:133

作者:三月

栏目:数据库

亿速云负载均衡(Cloud Load Balancer)是对多台云服务器进行流量分发的服务。亿速云负载均衡可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。亿速云负载均衡服务通过设置虚拟服务地址(VIP),将位于同一地域的多台云服务器资源虚拟成一个高性能、高可用的应用服务池。根据应用指定的方式,将来自客户端的网络请求分发到云服务器池中。亿速云负载均衡服务会检查云服务器池中云服务器实例的健康状态,自动隔离异常状态的实例,从而解决了云服务器的单点问题,同时提高了应用的整体服务能力。今天亿速云给大家介绍下实现Web服务器之间使用同一个MYSQL和相同的网页配置文件的方法

前言:

用NFS、LAMP、BIND结合的方法,应对网络中访问量增大而导致云服务器负载运行的情况。以实现Web服务器之间使用同一个MYSQL和相同的网页配置文件。

实验环境:

HostNameIP规划

nfs.preferred.com192.168.1.6NFS

ns.preferred.com192.168.1.5

mysql.preferred.com192.168.1.4MYSQL

www.preferred.com192.168.1.3WEB

www.preferred.com192.168.1.2WEB

实验拓扑:

de0172ad7be85f96d34ba8110b9316b1.png

实验步骤:

一、搭建NFS以下操作在nfs.preferred.com服务器上实现[root@localhost ~]# yum install nfs-utils -y    

[root@localhost ~]# rpm -qa | grep nfs-utils --color

nfs-utils-1.2.3-39.el6.x86_64

创建共享目录并配置nfs文件[root@localhost~]# mkdir /mydata

[root@localhost~]# mkdir /webdata

[root@localhost~]# cd /webdata/

[root@localhost webdata]# unzip wordpress-3.2.1-zh_CN.zip &> /dev/null

[root@localhost webdata]# chmod -R 777 wordpress

[root@localhost webdata]# ls -l

drwxrwxrwx 5 root root    4096 Oct 11  2016 wordpress

-rw-r--r-- 1 root root 4372680 Oct 11  2016 wordpress-3.2.1-zh_CN.zip

[root@localhost webdata]# vim /etc/exports

/mydata         192.168.1.4(rw,no_root_squash)

/webdata        192.168.1.2(rw,no_root_squash) 192.168.1.3(rw,no_root_squash)

[root@localhost ~]# service rpcbind start

注:rpcbind是一个RPC服务,主要是在nfs共享的时候负责通知客户端、服务器nfs端口号。

[root@localhost ~]# service nfs start

Starting NFS services:                                     [  OK  ]

Starting NFS quotas:                                       [  OK  ]

Starting NFS mountd:                                       [  OK  ]

Starting NFS daemon:                                       [  OK  ]

Starting RPC idmapd:                                       [  OK  ]

[root@localhost ~]# showmount -e 192.168.1.6    

Export list for 192.168.1.6:

/webdata 192.168.1.3,192.168.1.2

/mydata  192.168.1.4

二、搭建DNS以下操作在ns.preferred.com服务器上实现[root@localhost ~]# yum install bind -y | tail -n 5

Installed:

bind.x86_64 32:9.8.2-0.47.rc1.el6_8.1

Complete!

[root@localhost ~]# vim /etc/named.rfc1912.zones     

zone "preferred.com" IN {

type master;

file "preferred.com.zone";

};

zone "1.168.192.in-addr.arpa" IN {

type master;

file "192.168.1.5.zone";

};

[root@localhost ~]# vim /var/named/preferred.com.zone     

$TTL 86400

$ORIGIN preferred.com.

@       IN      SOA     ns.preferred.com admin.preferred.com (

2016101001

1D

5M

7D

1D )

IN      NS      ns

ns      IN      A       192.168.1.5

www     IN      A       192.168.1.2

www     IN      A       192.168.1.3

nfs     IN      A       192.168.1.6

[root@localhost ~]# vim /var/named/192.168.1.5.zone     

$TTL 86400

@       IN      SOA     ns.preferred.com. admin.preferred.com (

2016101001

1H

5M

7D

1D )

IN      NS      ns.preferred.com.

5       IN      PTR     ns.preferred.com.

2       IN      PTR     www.preferred.com.

3       IN      PTR     www.preferred.com.

6       IN      PTR     nfs.preferred.com.

[root@localhost ~]# systemctl restart named

[root@localhost ~]# dig -t A www.preferred.com @192.168.1.5    

; <<>> DiG 9.9.4-RedHat-9.9.4-29.el7_2.4 <<>> -t A www.preferred.com @192.168.1.5

;; global options: +cmd

;; Got answer:

;; ->>HEADER<

;; flags: qr aa rd ra; QUERY: 1, ANSWER: 2, AUTHORITY: 1, ADDITIONAL: 2

;; OPT PSEUDOSECTION:

; EDNS: version: 0, flags:; udp: 4096

;; QUESTION SECTION:

;www.preferred.com.INA

;; ANSWER SECTION:

www.preferred.com.86400INA192.168.1.2

www.preferred.com.86400INA192.168.1.3

;; AUTHORITY SECTION:

preferred.com.86400INNSns.preferred.com.

;; ADDITIONAL SECTION:

ns.preferred.com.86400INA192.168.1.5

;; Query time: 0 msec

;; SERVER: 192.168.1.5#53(192.168.1.5)

;; WHEN: Tue Oct 11 04:22:36 EDT 2016

;; MSG SIZE  rcvd: 111

[root@localhost ~]# dig -x 192.168.1.2 @192.168.1.5    

; <<>> DiG 9.9.4-RedHat-9.9.4-29.el7_2.4 <<>> -x 192.168.1.2 @192.168.1.5

;; global options: +cmd

;; Got answer:

;; ->>HEADER<

;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 1, ADDITIONAL: 2

;; OPT PSEUDOSECTION:

; EDNS: version: 0, flags:; udp: 4096

;; QUESTION SECTION:

;2.1.168.192.in-addr.arpa.INPTR

;; ANSWER SECTION:

2.1.168.192.in-addr.arpa. 86400INPTRwww.preferred.com.

;; AUTHORITY SECTION:

1.168.192.in-addr.arpa.86400INNSns.preferred.com.

;; ADDITIONAL SECTION:

ns.preferred.com.86400INA192.168.1.5

;; Query time: 0 msec

;; SERVER: 192.168.1.5#53(192.168.1.5)

;; WHEN: Tue Oct 11 04:23:57 EDT 2016

;; MSG SIZE  rcvd: 117

三、搭建MYSQL以下操作在mysql.preferred.com服务器上实现[root@localhost ~]# mkdir /mydata/

[root@localhost ~]# mount -t nfs 192.168.1.6:/mydata/ /mydata/    

[root@localhost ~]# groupadd -r mysql    

[root@localhost ~]# useradd -r -g mysql -s /sbin/nologin mysql

[root@localhost ~]# cd /usr/local/

[root@localhost local]# ln -sv /root/mariadb-5.5.43-linux-x86_64 mysql

"mysql" -> "/root/mariadb-5.5.43-linux-x86_64"

[root@localhost local]# cd mysql/

[root@localhost mysql]# ls

bin      COPYING.LESSER  EXCEPTIONS-CLIENT  INSTALL-BINARY  man         README   share      support-files

COPYING  data            include            lib             mysql-test  scripts  sql-bench

[root@localhost mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/mydata/    

Installing MariaDB/MySQL system tables in '/mydata' ...

161010 13:33:59 [Note] ./bin/mysqld (mysqld 5.5.43-MariaDB) starting as process 2183 ...

OK

Filling help tables...

161010 13:33:59 [Note] ./bin/mysqld (mysqld 5.5.43-MariaDB) starting as process 2191 ...

OK

...

[root@localhost mysql]# ls /mydata/    

aria_log.00000001  aria_log_control  mysql  performance_schema  test

[root@localhost mysql]# mkdir /etc/mysql/

[root@localhost mysql]# cp support-files/my-large.cnf /etc/mysql/my.cnf

[root@localhost mysql]# vim /etc/mysql/my.cnf    

datadir = /mydata

innodb_file_per_table = on

skip_name_resolve = on

[root@localhost mysql]# service mysqld start

Starting MySQL...                                          [确定]

[root@localhost mysql]# ss -tnl | grep 3306    

LISTEN     0      50                        *:3306                     *:*                       *:*

[root@localhost mysql]# mysql

-bash: mysql: command not found

注:尝试登陆MYSQL却报错,不要紧张。这是因为/usr/local/bin目录下确实mysql导致,只需要建立一个软连接即可解决。

[root@localhost ~]# ln -sv /usr/local/mysql/bin/mysql /usr/bin/

"/usr/bin/mysql" -> "/usr/local/mysql/bin/mysql"

[root@localhost ~]# mysql    

Welcome to the MariaDB monitor.  Commands end with ; or \g.

Your MariaDB connection id is 115

Server version: 5.5.43-MariaDB-log MariaDB Server

Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> CREATE DATABASE pre;

Query OK, 1 rows affected (0.00 sec)

MariaDB [(none)]> GRANT ALL ON pre.* TO 'jds'@'%' IDENTIFIED BY 'redhat';    

Query OK, 0 rows affected (0.01 sec)

MariaDB [(none)]> FLUSH PRIVILEGES;

Query OK, 0 rows affected (0.00 sec)

四、搭建WEB以下操作在www.preferred.com(192.168.1.2)服务器上实现[root@localhost ~]# yum install httpd php-mysql php -y | tail -n 10

warning: rpmts_HdrFromFdno: Header V3 RSA/SHA1 Signature, key ID c105b9de: NOKEY

Importing GPG key 0xC105B9DE:

Userid: CentOS-6 Key (CentOS 6 Official Signing Key) 

Package: centos-release-6-5.el6.centos.11.1.x86_64 (@anaconda-CentOS-201311272149.x86_64/6.5)

From: /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

php-cli.x86_64 0:5.3.3-48.el6_8    php-common.x86_64 0:5.3.3-48.el6_8

php-pdo.x86_64 0:5.3.3-48.el6_8

Updated:

httpd.x86_64 0:2.2.15-54.el6.centos

Dependency Updated:

httpd-tools.x86_64 0:2.2.15-54.el6.centos

Complete!

[root@localhost ~]# mkdir /webdata

[root@localhost ~]# vim /etc/httpd/conf/httpd.conf    

ServerName www.preferred.com:80

ServerName www.preferred.com

DocumentRoot /webdata/wordpress

[root@localhost ~]# service rpcbind start

[root@localhost ~]# mount -t nfs 192.168.1.6:/webdata /webdata

[root@localhost ~]# ls /webdata/

wordpress  wordpress-3.2.1-zh_CN.zip

[root@localhost ~]# service httpd start

Starting httpd:                                            [  OK  ]

接下来安装wordpress,没有的话可以自己去下载一个https://wordpress.org/download/[root@localhost ~]# cd /webdata/wordpress

[root@localhost wordpress]# ls

index.php        wp-app.php            wp-config.php         wp-includes        wp-pass.php      wp-settings.php

license.txt      wp-atom.php           wp-config-sample.php  wp-links-opml.php  wp-rdf.php       wp-signup.php

readme.html      wp-blog-header.php    wp-content            wp-load.php        wp-register.php  wp-trackback.php

wp-activate.php  wp-comments-post.php  wp-cron.php           wp-login.php       wp-rss2.php      xmlrpc.php

wp-admin         wp-commentsrss2.php   wp-feed.php           wp-mail.php        wp-rss.php

[root@localhost wordpress]# cp wp-config-sample.php wp-config.php    

[root@localhost wordpress]# vim wp-config.php

// ** MySQL 设置 - 具体信息来自您正在使用的主机 ** //

/** WordPress 数据库的名称 */

define('DB_NAME', 'pre');    

/** MySQL 数据库用户名 */

define('DB_USER', 'jds');

/** MySQL 数据库密码 */

define('DB_PASSWORD', 'redhat');

/** MySQL 主机 */

define('DB_HOST', '192.168.1.4');

/** 创建数据表时默认的文字编码 */

define('DB_CHARSET', 'utf8');

/** 数据库整理类型。如不确定请勿更改 */

define('DB_COLLATE', '');

[root@localhost ~]# mysql -ujds -predhat -h 192.168.1.4    

ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.1.4' (113)

注:遇到这个问题怎么个人都不好了,在MYSQL服务器上取消防火墙也不行。所以尝试在MYSQL服务器的防火墙上加上端口的允许。

[root@localhost ~]# iptables -L -n | grep 3306

[root@localhost ~]# iptables -I INPUT -s 0/0 -p tcp --dport 3306 -j ACCEPT

[root@localhost mysql]# iptables -L -n | grep 3306

ACCEPT     tcp  --  0.0.0.0/0            0.0.0.0/0           tcp dpt:3306

[root@localhost ~]# mysql -ujds -predhat -h 192.168.1.4    

Welcome to the MariaDB monitor.  Commands end with ; or \g.

Your MariaDB connection id is 116

Server version: 5.5.43-MariaDB-log MariaDB Server

Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> SHOW DATABASES;

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

| Database           |

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

| information_schema |

| mysql              |

| performance_schema |

| pre                |    

| test               |

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

5 rows in set (0.00 sec)

3e4a1e79d6a8184dbe01e0741cf3a0f2.png

测试访问正常!!!

以下操作在www.preferred.com(192.168.1.3)服务器上实现[root@localhost ~]# yum install httpd php-mysql php -y

[root@localhost ~]# mkdir /webdata

[root@localhost ~]# vim /etc/httpd/conf/httpd.conf    

ServerName www.preferred.com:80

ServerName www.preferred.com

DocumentRoot /webdata/wordpress

[root@localhost ~]# service rpcbind start

[root@localhost ~]# mount -t nfs 192.168.1.6:/webdata /webdata

[root@localhost ~]# ls /webdata/

wordpress  wordpress-3.2.1-zh_CN.zip

[root@localhost ~]# service httpd start

Starting httpd:

[  OK  ]

afc9ac80ea060f1f966471e1ef739900.png

先用WEB(192.168.1.3)进行测试。发布一条文章

52d9ea490a203028b66569267d7684f9.png

用WEB(192.168.1.2)进行测试。现在访问看看

40549555fce4e2b32ad1f3141b94b797.png

看到了在WEB(192.168.1.3)上发布的文章,我们在WEB(192.168.1.2)上也发布一篇

46b58af481c0027b858e516cd5e0f676.png

最后我们在WEB(192.168.1.3)上查看

23b526b2d9237e40fbf03f57f2413b15.png

至此,我们实验的目的已经达到。

如果大家还有什么地方需要了解的可以在亿速云官网找我们的专业技术工程师的,亿速云技术工程师在行业内拥有十几年的经验了,所以会比小编回答的更加详细专业。亿速云官网链接www.yisu.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/378932.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

传128GB版iPad4售价为799/929美元

外媒9to5mac报道&#xff0c;苹果将推出一款升级版iPad4&#xff0c;外观和iPad 4相同&#xff0c;还是黑白两色的&#xff0c;只加入了新的SKU。 据报道&#xff0c;这款升级版iPad4还有128GB版&#xff0c;随着这条消息传出&#xff0c;不久关于128GB版iPad4的售价信息也传出…

(西工程-金花)小米路由器连接哆点设置WiFi保姆式教程

小米路由器连接电源,用根网线一端插入寝室的网口处,另一端插入小米路由器的WAN口手机或者电脑连接WiFi,我这里是通过手机浏览器打开192.168.31.1进入无线路由器管理页面进行配置小米路由器&#xff0c;配置WiFi的一些基本参数,例如:WiFi名称,密码之类的信息 进入无线路由器管理…

基于MINA框架快速开发网络应用程序

1&#xff0e;MINA框架简介 Netty、Mina、Cindy都是不错的NIO开源框架&#xff0c;后两者都是在Netty的基础上演化出来的。MINA(Multipurpose Infrastructure for Network Applications)是用于开发高性能和高可用性的网络应用程序的基础框架。通过使用MINA框架可以可以省下处理…

Python中@staticmethod和@classmethod之间的区别

classmethod装饰器 (The classmethod Decorator) The classmethod decorator is an inbuilt function decorator that gets evaluated after the function is defined. The result of the evaluation shadows the function definition. The classmethods first argument is alw…

go 声明二维数组_一篇文章了解Go语言中数组Arrays的使用内幕

概述与其他编程语言类似&#xff0c;Go语言也有数组array。Go语言中&#xff0c;数组的行为和其他语言没有什么不同.Go语言中还有一个叫做切片slice的东西&#xff0c;它就像是对数组的引用。在本文中&#xff0c;我们将只研究数组。定义数组是同一类型元素的连续集合&#xff…

ffmpeg 使用ffplay 进行 hls 拉流 分析 1

ffmpeg 使用 ffplay 进行 hls 拉流 分析 1 从使用ffplay 调用 http://192.168.1.100:8080/live/livestream.m3u8 开始&#xff0c;进入到ffmpeg 的分析使用的协议选择相应的解复用器的步骤。 其他协议或者文件方式的使用ffplay也是这个步骤流程的。 目录&#xff1a;一、流程图…

搜狗输入法输出特殊符号快捷键

https://www.petefreitag.com/cheatsheets/ascii-codes/ 参考上个编码网站大全 详细步骤为&#xff1a;alt长按 &#xff0b; 编码数字 例如&#xff1a;平方的编码为178-----长按alt178 即可&#xff0c;178是数字一个一个挨个按即可 常用的特殊符号如下&#xff1a; 平方&…

echo 12345678 | base64 产生的结果跟12345678真正的base64编码不对

echo "12345678" | base64 产生的结果跟"12345678"真正的base64编码不对 弄了好久才搞清楚&#xff0c;echo 命令是带换行符的&#xff0c;改成echo -n "12345678" | base64就没问题了转载于:https://www.cnblogs.com/senix/archive/2013/01/30/…

[BuildRelease Management]CC.NET架构

一 CC.NET的操作流程 1) 等待Trigger的唤醒&#xff1b; 2&#xff09;从Source Control System查询上次build以后的修改列表&#xff1b; 3&#xff09;如果任何修改被发现或是Trigger触发类型为 force the build &#xff1a; 3.1&#xff09;为build产生一个label number&a…

python 入门到实践期末考试常出现的考试内容_Python编程入门到实践—列表篇(一)...

一、列表是什么&#xff1f;列表由一系列按特定顺序排列的元素组成。可以创建包含字母表中所有字母、数字0-9或所有家庭成员姓名的列表&#xff1b;也可以将任何东西加入列表中&#xff0c;其中的元素之间可以没有任何关系。列表通常包含多个元素&#xff0c;给列表指定一个表示…

c#中将集合写入文本_在C#中将记录插入MySQL数据库

c#中将集合写入文本In the last tutorial (how to connect with MySQL database in C#?), we learned about making the connection with MySQL database in C#. Here, in this tutorial, we will learn how to insert the records in MySQL database in C#? 在上一教程( 如何…

read/fread write/fwrite 的区别

fread就是通过read来实现的&#xff0c;fread是C语言的库&#xff0c;而read是系统调用。 差别在read每次读的数据是调用者要求的大小&#xff0c;比如调用者要求读取10个字节数据&#xff0c;read就会从内核缓冲区&#xff08;操作系统开辟的一段空间用来存储磁盘上的数据&am…

如何在子网中访问上层网络的计算机文件夹

场景 公司路由器A&#xff0c;直接接外部网线&#xff0c;内部ip192.168.11.1&#xff0c;lan口又接了路由器A1&#xff0c;IP为192.168.11.2&#xff0c;A1的lan端口接了一台电脑A&#xff0c;Ip为192.168.0.2&#xff0c;接了另外一个路由A2&#xff0c;Ip为192.168.11.3&…

基于Web的套打方案分析

应用web化&#xff0c;不论对开发商&#xff0c;还是对用户来说&#xff0c;实在是一种很经济的选择&#xff0c;因为基于web的应用&#xff0c;客户端的规则很简单&#xff0c;容易学习&#xff0c;容易维护&#xff0c;容易发布。但对程序员来说&#xff0c;因为浏览器的局限…

day1-Linux操作系统基础

该专栏所有内容笔记均来自传智播客培训班 1.什么是操作系统&#xff08;operate system OS&#xff09; 小议&#xff1a;承上启下作用&#xff0c;向下可以控制硬件&#xff0c;向上能够支持软件的运行。一个可以控制硬件的软件。 小明找小红聊天&#xff0c;小明打开QQ&…

关闭浏览器 清空session_跨境网络小知识之Session

跨境小伙伴们大家好&#xff0c;上一篇为大家介绍了Cookie&#xff0c;今天就为大家介绍下连接cookie的另一端Session&#xff0c;交互过程中&#xff0c;二者缺一不可。与Cookie相对&#xff0c;Session是存储在服务端的&#xff0c;他们之间是通过一个叫做sessionID的东东建立…

我和乘子交替方向法admm_找到最大和交替子序列

我和乘子交替方向法admmProblem statement: 问题陈述&#xff1a; Given a sequence of numbers, you have to find the maximum sum alternating subsequence and print the value. A sequence is an alternating sequence when it will be maintain like (increasing) ->…

Dojo学习笔记(一):Hello Dojo!

欢迎来到Dojo世界&#xff01;在这篇文章中你将会学习到如何加载Dojo以及探索Dojo的一些核心功能。你还会了解Dojo的基于AMD的模块架构&#xff0c;探索如何加载额外的模块来增加功能到您的Web站点或应用程序&#xff0c;并找出在出错的时如何得到帮助。让我们开始吧 开始学习D…

转:我眼中的Visual Studio 2010架构工具

来自&#xff1a;http://www.cnblogs.com/wayfarer/archive/2010/07/30/1788398.html我眼中的Visual Studio 2010架构工具影响架构质量的是构建体系架构的思想、原则、实践与架构师的经验&#xff0c;绝不是工具。即使是最优秀的架构工具&#xff0c;也不可能像倚天宝剑一般——…

VMware创建Ubuntu操作系统到网络配置详细流程

一、创建虚拟机 Ubuntu下载链接 1&#xff0c;看个人需求了&#xff0c;有更高的版本&#xff0c;下载Ubuntu镜像 2&#xff0c;VMware官网随便下载即可 3&#xff0c;创建新的虚拟机 4&#xff0c;自定义 5&#xff0c;默认即可 6&#xff0c;稍后安装操作系统 7&#xf…