六 SpringCloudAlibaba-Nacos(伪集群和持久化)

Nacos默认有自带嵌入式数据库derby,但是如果做集群模式的话,就不能使用自己的数据库不然每个节点一个数据库,那么数据就不统一了,需要使用外部的mysql

1.1.持久化

1.1.1.切换数据库

修改conf/application.properties文件,增加支持mysql数据源配置(目前只支持mysql,版本要求:5.6.5+)

### If use MySQL as datasource:
spring.datasource.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
db.url.0=jdbc:mysql://192.168.31.19:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=root
db.password.0=1111

1.1.2.初始化数据库

创建nacos数据库并导入sql

1.1.3.测试

重启nacos测试nacos所有写到嵌入式数据库的数据是否都写到了mysql:

2.2.集群

2.2.1.部署架构图:

2.2.2.节点规划

2.2.3.集群搭建

1. 找到conf/cluster.conf.example ,将其改名为 conf/cluster.conf ,并将内容改为如下:

 2. 复制三份Nacos

[root@localhost bin]# cd /usr/local
[root@localhost java]# mkdir nacos_cluster
[root@localhost java]# cp -r nacos nacos_cluster/nacos_8848
[root@localhost java]# cp -r nacos nacos_cluster/nacos_8849
[root@localhost java]# cp -r nacos nacos_cluster/nacos_8850

3. 将 conf/application.properties 中的端口号分别改为:

server.port=8848
server.port=8849
server.port=8850

2.3.配置代理服务

2.3.1.安装nginx

   1.Linux安装nginx的依赖库

yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel

   2.下载nginx

wget -c https://nginx.org/download/nginx-1.12.0.tar.gz

   3.解压安装包

tar -zxvf nginx-1.12.0.tar.gz

  4.配置nginx安装包

cd nginx-1.12.0

./configure --prefix=/usr/local/nginx

注意:./configure配置nginx安装到/usr/java/nginx目录下

   5.编译并安装

make && make install

2.3.2.配置nginx代理nacos

upstream nacos {
  server 192.168.198.131:8848;
  server 192.168.198.131:8849;
  server 192.168.198.131:8850;
}

server {
  listen 80;
  server_name  localhost;
  location / {
    proxy_pass http://nacos;
  }
}

2.5.测试

 1.启动nacos集群

[root@localhost upload]# cd /usr/local/nacos_cluster/nacos_8848/bin
[root@localhost bin]# ./startup.sh
[root@localhost bin]# cd /usr/local/nacos_cluster/nacos_8849/bin
[root@localhost bin]# ./startup.sh
[root@localhost bin]# cd /usr/local/nacos_cluster/nacos_8850/bin
[root@localhost bin]# ./startup.sh

3.将微服务注册到Nacos集群

 4.访问nacos集群

启动nacos-config服务,并通过nginx访问nacos集群:http://192.168.209.129/nacos

3.Nacos开机自启

1.1.编写开机启动文件

  1. 添加nacos.service文件

vim /lib/systemd/system/nacos.service

文件内容如下:

[Unit]
Description=nacos
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/nacos/bin/startup.sh -m standalone
ExecReload=/usr/local/nacos/bin/shutdown.sh
ExecStop=/usr/local/nacos/bin/shutdown.sh
PrivateTmp=true

[Install]
WantedBy=multi-user.target

2.2.修改nacos的startup.sh

  修改JAVA_HOME路径并注销之后的3行配置,如下:

[ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/usr/local/jdk1.8.0_191 
#[ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/usr/java
#[ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/opt/taobao/java
#[ ! -e "$JAVA_HOME/bin/java" ] && unset JAVA_HOME

2.3.设置开机启动

systemctl daemon-reload        #重新加载服务配置
systemctl enable nacos.service #设置为开机启动
systemctl start nacos.service  #启动nacos服务
systemctl stop nacos.service   #停止nacos服务

3.总结

问题:

        1.为什么要做持久化:

                Nacos默认有自带嵌入式数据库derby,但是如果做集群的话,集群启动的Nacos就比较多,那么每个内嵌的数据库都要进行配置一个配置文件和服务信息,而且数据就不统一了,需要使用外部的mysql,每个Nacos启动的时候都去读取外部的mysql

        2.切换数据库步骤:

                2.1Nacos集群配置

                注意:Linux Mysql版本要求:5.6.5+

                ① 找到nacos安装目录,切换到nacos目录下/conf/application.properties修改配置文件,修改mysql ip地址、端口号、数据库、账号、密码

                ②在配置的数据库中创建nacos数据库并导入sql (sql文件在nacos/conf/nacos-mysql.sql)

                ③ 重启nacos,在配置中心中创建配置文件,测试nacos所有写到嵌入式数据库的数据是否都写到了mysql:

        3.集群搭建的步骤:

                ① 找到nacos/conf/cluster.conf.example, 将其复制一份并且改名为cluster.conf(复制一份的原因是备份一个,避免把原来的配置文件改坏掉,而且无法修复)

                ②创建一个目录把安装nacos整个目录复制三份放进去并且要区分出这三份的目录名(可以是五份可以是七分但是一定要是奇数)

                ③将 conf/application.properties 中的端口号分别改为:

                server.port=8848
                server.port=8849
                server.port=8850

                2.1配置代理服务

                ①安装nginx

                           下载nginx

                                wget -c https://nginx.org/download/nginx-1.12.0.tar.gz

                           解压安装包

                                tar -zxvf nginx-1.12.0.tar.gz

                           在nginx解压后的目录下安装nginx的依赖库(nginx需要c语言依赖)

                                yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel

                           配置nginx安装路径      

                                cd nginx-1.12.0

                                ./configure --prefix=c

                           编译并安装

                                make && make install

                  ②配置nginx代理nacos

                                cd  /usr/local/nginx/conf

                                vim nginx.conf                //编辑/nginx/conf/下的nginx.conf文件

                                upstream nacos {
                                server 192.168.198.131:8848;
                                server 192.168.198.131:8849;
                                server 192.168.198.131:8850;
                              }

                                server {
                                  listen 80;
                                  server_name  localhost;
                                  location / {
                                    proxy_pass http://nacos;
                                  }
                                }

                 2.1配置代理服务

                        ①测试

                                1.启动nacos集群

[root@localhost upload]# cd /usr/local/nacos_cluster/nacos_8848/bin
[root@localhost bin]# ./startup.sh
[root@localhost bin]# cd /usr/local/nacos_cluster/nacos_8849/bin
[root@localhost bin]# ./startup.sh
[root@localhost bin]# cd /usr/local/nacos_cluster/nacos_8850/bin
[root@localhost bin]# ./startup.sh

                                2.启动nginx

[root@localhost nginx]# cd /usr/local/nginx/sbin/
[root@localhost sbin]# ./nginx 

                                3.将微服务注册到Nacos集群(nginx配置的80端口此时不需要配置端口)

 

       启动服务访问nacos集群并且会发现三个nacos都有对应的服务

                原因:

                        三个nacos经过算法投票会选出一个大哥(两个小弟),服务启动接收服务的如果是一个小弟那么这个小弟会告诉大哥,大哥会告诉另一个小弟让其同步一下。如果接收的是一个大哥,那么大哥会告诉另两个小弟让其同步一下。(算法比较复杂但是最基本要求就是Nacos必须是奇数)

                2.1Nacos开机自启(此功能仅自学可用)

                        ①在linux root上面编写开机自启文件:

                                     vim /lib/systemd/system/nacos.service

                        ②修改/nacos/bin/startup.sh文件

                                     修改JAVA_HOME路径(本机安装的路径)并注销之后的3行配置,如下:

[ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/usr/local/jdk1.8.0_191  
#[ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/usr/java
#[ ! -e "$JAVA_HOME/bin/java" ] && JAVA_HOME=/opt/taobao/java
#[ ! -e "$JAVA_HOME/bin/java" ] && unset JAVA_HOME

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值