溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

模擬百萬(wàn)PV架構(gòu)

發(fā)布時(shí)間:2020-08-05 09:51:56 來(lái)源:網(wǎng)絡(luò) 閱讀:354 作者:Cher1shDan 欄目:數(shù)據(jù)庫(kù)

案例

本案例設(shè)計(jì)采用四層模式實(shí)現(xiàn),主要分為前端反向代理層,web層,數(shù)據(jù)庫(kù)緩存層和數(shù)據(jù)庫(kù)層。前端反向代理層采用主備模式,web層采用集群模式,數(shù)據(jù)庫(kù)緩存層采用主備模式,數(shù)據(jù)庫(kù)層采用主從模式。

拓?fù)鋱D如下。 實(shí)線是正常情況下的數(shù)據(jù)流向連接,虛線是異常情況下的數(shù)據(jù)流向連接
模擬百萬(wàn)PV架構(gòu)

前端反向代理服務(wù)器配置

安裝帶有nginx rpm軟件包的源

rpm -ivh http://nginx.org/packages/centos/7/noarch/RPMS/\
nginx-release-centos-7-0.el7.ngx.noarch.rpm

yum install keepalived nginx -y

vim /etc/keepalived/keepalived.conf
global_defs {
    route_id NGINX_HA     ##主從服務(wù)器的ID不同
}

vrrp_script nginx {      ##設(shè)置腳本
    script "/opt/shell/nginx.sh"   
    interval 2        ##間隔2秒
}

vrrp_instance VI_1 {
    state MASTER    ##主為MASTER,從為BACKUP
    interface ens33
    virtual_router_id 51    
    priority 100     ##優(yōu)先級(jí),主的高于從
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
}

track_script {     ##運(yùn)行腳本
    nginx
}

virtual_ipaddress {
    192.168.x.x   ##設(shè)置內(nèi)網(wǎng)虛擬IP和外網(wǎng)虛擬IP     
    x.x.x.x
    }
}

mkdir /opt/shell
vi /opt/shell/nginx.sh   ##創(chuàng)建腳本,此腳本的目的是當(dāng)keepalived啟動(dòng)的時(shí)候,nginx同時(shí)啟動(dòng),且如果不關(guān)閉keepalived,nginx同樣無(wú)法關(guān)閉

#!/bin/bash
k=`ps -ef | grep keepalived | grep -v grep | wc -l`
if [ $k -gt 0 ];then
    /bin/systemctl start nginx.service
else
/bin/systemctl stop nginx.service
fi

chmod +x /opt/shell/nginx.sh   ##給予腳本運(yùn)行權(quán)限

接下來(lái)配置NGINX 的調(diào)度功能
vim /etc/nginx/nginx.conf

在http中添加

 upstream tomcat_pool {
                server 192.168.x.x:8080;
                server 192.168.x.x:8080; ##兩臺(tái)tomcat的地址
                ip_hash;           #會(huì)話穩(wěn)固功能,如果不用這條,需要另外做session共享
        }
        server {
                listen 80;
                server_name 192.168.x.x; #虛擬IP  
                location / {
                        proxy_pass http://tomcat_pool;
                        proxy_set_header X-Real-IP $remote_addr;
                }
    }

nginx -t -c /etc/nginx/nginx.conf  ##測(cè)試配置文件語(yǔ)法
systemctl start keepalived.service    ##nginx也會(huì)被打開(kāi)

tomcat配置(兩臺(tái)相同)

tar xf apache-tomcat-8.5.23.tar.gz
tar xf jdk-8u144-linux-x64.tar.gz

cp -rv jdk1.8.0_144/ /usr/local/java

vi /etc/profile

export JAVA_HOME=/usr/local/java
export JRE_HOME=/usr/local/java/jre
export PATH=$PATH:/usr/local/java/bin
export CLASSPATH=./:/usr/local/java/lib:/usr/local/java/jre/lib

source /etc/profile   ##使系統(tǒng)識(shí)別java

輸入 java -version 能看到版本號(hào)說(shuō)明完成

cp -r apache-tomcat-8.5.23 /usr/local/tomcat8

ln -s /usr/local/tomcat8/bin/startup.sh /usr/bin/tomcatup    ##啟動(dòng)tomcat

ln -s /usr/local/tomcat8/bin/shutdown.sh /usr/bin/tomcatdown    ##關(guān)閉tomcat

netstat -anpt | grep 8080
## 看到8080  服務(wù)開(kāi)啟成功

通過(guò)客戶(hù)端訪問(wèn) http://192.168.x.x:8080  ##測(cè)試默認(rèn)測(cè)試頁(yè)是否正常顯示

vi /usr/local/tomcat8/webapps/ROOT/index.jsp ##修改默認(rèn)網(wǎng)頁(yè)內(nèi)容

輸入調(diào)度服務(wù)器(虛擬IP) 地址,測(cè)試兩臺(tái)節(jié)點(diǎn)服務(wù)器的調(diào)度情況。

vim /usr/local/tomcat8/conf/server.xml

在<Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
下插入

<Context path="" docBase="SLSaleSystem" reloadable="true" debug="0"></Context>
##日志調(diào)試信息debug為0表示信息越少,docBase指定訪問(wèn)目錄

mysql安裝

由于是模擬架構(gòu),本篇mysql用mariadb代替

yum install -y mariadb-server mariadb

systemctl start mariadb.service
systemctl enable mariadb.service

netstat -anpt | grep 3306

mysql_secure_installation    ##常規(guī)安全設(shè)置

----------導(dǎo)入數(shù)據(jù)庫(kù)-----------

mysql -u root -p  < xxxx.sql   ##導(dǎo)入商城網(wǎng)站數(shù)據(jù)庫(kù)

mysql -uroot -p

show databases;    ##確定導(dǎo)入成功

GRANT all ON xxxx.* TO 'root'@'%' IDENTIFIED BY 'abc123';    ##給數(shù)據(jù)庫(kù)授權(quán)

flush privileges;    ##刷新數(shù)據(jù) 

----------------以下在兩臺(tái)tomcat節(jié)點(diǎn)做----------------

tar xf SLSaleSystem.tar.gz -C
/usr/local/tomcat8/webapps/

cd /usr/local/tomcat8/webapps/SLSaleSystem/WEB-INF/classes

vi jdbc.properties ##修改數(shù)據(jù)庫(kù)IP地址是VRRP的虛擬IP,以及授權(quán)的用戶(hù)名root和密碼abc123。

------------網(wǎng)站測(cè)試------

http://192.168.x.x:8080/   ##默認(rèn)的用戶(hù)名admin 密碼:123456

http://192.168.x.x ##輸入虛擬地址測(cè)試登錄,并且關(guān)閉主再測(cè)試登錄

redis集群

yum install redis -y

vi /etc/redis.conf

bind 0.0.0.0   ##修改

systemctl start redis.service

redis-cli -h 192.168.x.x -p 6379 ##測(cè)試連接

192.168.x.x:6379> set name test  ##設(shè)置name 值是test

192.168.x.x:6379> get name ##獲取name值

在從服務(wù)器上

266 slaveof 192.168.x.x  6379 ##主服務(wù)器的IP不是虛擬IP

redis-cli -h 192.168.x.x -p 6379 ##登錄從,如能成功獲取主上設(shè)置的值,說(shuō)明主從同步成功
192.168.x.x:6379> get name
"test"

-------------配置商城項(xiàng)目中連接redis的參數(shù)---

vi /usr/local/tomcat8/webapps/SLSaleSystem/WEB-INF/classes/applicationContext-mybatis.xml

      <!--redis 配置 開(kāi)始-->

<constructor-arg value="192.168.x.x"/>    ##虛擬IP  
<constructor-arg value="6379"/>

------------以下測(cè)試緩存效果-----
redis-cli -h 192.168.x.x -p 6379   ##虛擬IP

192.168.175.188:6379> info

keyspace_hits:1  或者 keyspace_misses:2    ##關(guān)注這個(gè)值,命中數(shù)和未命中數(shù)

登錄商城,然后反復(fù)點(diǎn)擊需要數(shù)據(jù)庫(kù)參與的操作頁(yè)面,再回來(lái)檢查keyspace_hits或者keyspace_misses: 值變化。

---------以下配置redis集群主從切換---只在主服務(wù)器是操作--------

vi /etc/redis-sentinel.conf

protected-mode no
sentinel monitor mymaster 192.168.x.x 6379 1   ##1表示1臺(tái)從 注意:修改
sentinel down-after-milliseconds mymaster 3000   ##故障切換時(shí)間單位是毫秒

service redis-sentinel start   ##啟動(dòng)集群
netstat -anpt | grep 26379

redis-cli -h 192.168.x.x -p 26379 info Sentinel ##查看集群信息

mysql 主從

在主 和 從mysql服務(wù)器上
vim /etc/my.cnf

[mysqld]
binlog-ignore-db=mysql,information_schema
character_set_server=utf8
log_bin=mysql_bin
server_id=1     ## 主從服務(wù)器的 server_id 不相同
log_slave_updates=true
sync_binlog=1

systemctl restart mysqld

在 主MYSQL上 為 從服務(wù)器授予權(quán)限

mysql -u root -p

grant replication slave on *.* to 'replication'@'192.168.x.%' identified by '123456';

show master status; 
+-------------------+----------+--------------+------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-bin.000002 |      335 |              |                  |
+-------------------+----------+--------------+------------------+

在從服務(wù)器上

mysql -u root -p

change master to master_host='192.168.x.x',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=335;

start slave;

show slave status \G;

  Slave_IO_Running: Yes
  Slave_SQL_Running: Yes
## 出現(xiàn)這兩條YES 則說(shuō)明 MYSQL主從復(fù)制完成

全部服務(wù)安裝完成

本案例數(shù)據(jù)庫(kù)的架構(gòu)簡(jiǎn)單了一點(diǎn),配置文件也是默認(rèn)的沒(méi)有經(jīng)過(guò)優(yōu)化,如果數(shù)據(jù)庫(kù)的壓力很大,可以考慮優(yōu)化,也可以使用讀寫(xiě)分離架構(gòu),或者采用多主多從模式。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI