zookeeper切换数据库连接

pom.xml添加:
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>

<!--导入本地ojdbc6.jar-->
<dependency>
<groupId>oracle</groupId>
<artifactId>oracle</artifactId>
<version>11g</version>
<scope>system</scope>
<systemPath>ojdbc6.jar所在位置</systemPath>
</dependency>


</dependencies>

一.使用zkclient创建znode节点,对节点数据的修改只能通过zkclient

public class ConnectDb {

    private static String url = null;
    private static String driverClass = null;
    private static String username = null;
    private static String password = null;

    public static Connection getConnection(String url, String driverClass, String username, String password)
            throws Exception {

        Class.forName(driverClass);

        Connection connection = DriverManager.getConnection(url, username, password);


        return connection;
    }


    public static void main(String[] args) throws Exception {


        String zkServers = "localhost:2181"; // ip:端口,多台机器之间用逗号(,)隔开


        final ZkClient zkClient = new ZkClient(zkServers, 10000, 5000);


        if (!zkClient.exists("/db")) {


            zkClient.createPersistent("/db");
            zkClient.createPersistent("/db/url", "jdbc:mysql://192.168.14.66:3306/work");
            zkClient.createPersistent("/db/driverClass", "com.mysql.jdbc.Driver");
            zkClient.createPersistent("/db/username", "root");
            zkClient.createPersistent("/db/password", "123456");
        }


        url = zkClient.readData("/db/url");
        driverClass = zkClient.readData("/db/driverClass");
        username = zkClient.readData("/db/username");
        password = zkClient.readData("/db/password");

        Connection connection = getConnection(url, driverClass, username, password);

        System.out.println(connection);

        // 监控/db节点
        zkClient.subscribeDataChanges("/db/url", new IZkDataListener() {
            // 当/user/zs节点被删除时触发
            public void handleDataDeleted(String arg0) throws Exception {

            }

            // 当/db/url节点被修改时触发
            public void handleDataChange(String arg0, Object arg1) throws Exception {
                url = zkClient.readData("/db/url");
                driverClass = zkClient.readData("/db/driverClass");
                username = zkClient.readData("/db/username");
                password = zkClient.readData("/db/password");

                Connection connection = getConnection(url, driverClass, username, password);
                System.out.println(connection);
            }
        });


        // 与server保持连接
        while (true) {
            TimeUnit.SECONDS.sleep(5);
        }
    }


}

public class ZkModify {

    public static void main(String[] args) {

        String   zkServers="localhost:2181";       
        ZkClient zkClient=new ZkClient(zkServers, 10000, 5000);

zkClient.writeData("/db/driverClass", "oracle.jdbc.OracleDriver");
        zkClient.writeData("/db/username", "food");
        zkClient.writeData("/db/password", "123456");
        zkClient.writeData("/db/url", "jdbc:oracle:thin:@localhost:1521:ORCL");
    }
}

二.使用zookeeper客户端或在eclipse上安装zookeeper插件添加znode节点
对节点数据的修改只能通过使用zookeeper客户端或在eclipse上安装的zookeeper插件


public class DbConnection {


    public static Connection getConnection(String url, String driverClass, String username, String password)
            throws Exception {


        Class.forName(driverClass);


        Connection connection = DriverManager.getConnection(url, username, password);


        return connection;
    }


    public static void main(String[] args) throws Exception {


        String zkServers = "localhost:2181"; // ip:端口,多台机器之间用逗号(,)隔开


      final ZkClient  zkClient = new ZkClient(zkServers, 10000, 5000,new BytesPushThroughSerializer());


       
        byte[] url = zkClient.readData("/db/url");
        byte[] driverClass = zkClient.readData("/db/driverClass");
        byte[] username = zkClient.readData("/db/username");
        byte[] password = zkClient.readData("/db/password");

       Connection connection = getConnection(new String(url),new String(driverClass),new String(username),new String(password));

       System.out.println(connection);
       
        // 监控/db节点
        zkClient.subscribeDataChanges("/db/url", new IZkDataListener() {
            // 当/user/zs节点被删除时触发
            public void handleDataDeleted(String arg0) throws Exception {

            }

            // 当/db/url节点被修改时触发
            public void handleDataChange(String arg0, Object arg1) throws Exception {

                byte[] url = zkClient.readData("/db/url");
                byte[] driverClass = zkClient.readData("/db/driverClass");
                byte[] username = zkClient.readData("/db/username");
                byte[] password = zkClient.readData("/db/password");
                Connection connection = getConnection(new String(url),new String(driverClass),new String(username),new String(password));
                System.out.println(connection);
            }
        });

        // 与server保持连接
        while (true) {
            TimeUnit.SECONDS.sleep(5);
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyCAT是一种开源软件,是面向企业的“大型数据库集群”。MyCAT是一个强制数据库,可以替代MySQL,并支持事务和ACID。作为企业数据库的MySQL群集,MyCAT可以代替昂贵的Oracle群集。MyCAT还是一种新型的数据库,它看起来像是与内存缓存技术,NoSQL技术和HDFS大数据集成的SQL Server。作为一种新型的现代企业数据库产品,MyCAT与传统的数据库和新的分布式数据仓库相结合。总之,MyCAT是一种全新的数据库中间件。 Mycat的目标是以低成本将当前的独立数据库和应用程序平稳地迁移到云端,并解决由于数据存储和业务规模的快速增长而引起的瓶颈问题。 特性: 支持SQL92标准 遵守Mysql原生协议,跨语言,跨平台,跨数据库的通用中间件代理。 基于心跳的自动故障切换,支持读写分离,支持MySQL主从,以及galera cluster集群。 支持Galera for MySQL集群,Percona Cluster或者MariaDB cluster 基于Nio实现,有效管理线程,高并发问题。 支持数据的多片自动路由与聚合,支持sum,count,max等常用的聚合函数。 支持单库内部任意join,支持跨库2表join,甚至基于caltlet的多表join。 支持通过全局表,ER关系的分片策略,实现了高效的多表join查询。 支持多租户方案。 支持分布式事务(弱xa)。 支持全局序列号,解决分布式下的主键生成问题。 分片规则丰富,插件化开发,易于扩展。 强大的web,命令行监控。 支持前端作为mysq通用代理,后端JDBC方式支持Oracle、DB2、SQL Server、mongodb、巨杉。 支持密码加密 支持服务降级 支持IP白名单 支持SQL黑名单、sql注入攻击拦截 支持分表(1.6) 集群基于ZooKeeper管理,在线升级,扩容,智能优化,大数据处理(2.0开发版)。 优点: 1、基于阿里巴巴的开源项目Cobar,其稳定性,可靠性,出色的体系结构和性能以及许多成熟的用例使MyCAT有了良好的开端。站在巨人的肩膀上,MyCAT感到足够自信,可以走得更远。 2、MyCAT的基因整合了最好的开源项目和创新思想,使MyCAT领先于其他当前类似的开源项目,甚至超越了某些商业产品。 3、MyCAT支持强大的技术团队,该团队的参与者经验超过5年,其中包括一些高级软件工程师,架构师,DBA等。优秀的技术团队可确保Mycat的产品质量。 4、MyCAT不依赖任何商业公司。它与一些开源项目不同,后者的重要特征包含在其商业产品中,并使开源项目像装饰一样。   Mycat2 更新日志: v1.13 修复所有下推中带有错误联合的连接 修复生成的sql带有类型转换导致mysql运算不正确 修复黑客路由器损坏 修复黑客路由器响应int类型可能超出数字范围
对于ZooKeeper拒绝连接的问题,可能有几种可能的原因和解决方法。首先,您可以检查以下几点: 1. 检查ZooKeeper服务器是否正在运行:确保ZooKeeper服务器正在运行,并且没有出现任何错误或异常情况。 2. 检查ZooKeeper服务器配置:检查ZooKeeper服务器配置文件(通常是zoo.cfg),确保端口号、主机名和其他相关配置正确。 3. 检查防火墙设置:确保防火墙没有阻止与ZooKeeper服务器之间的连接。您可以尝试临时禁用防火墙,然后再次尝试连接。 4. 检查网络连接:确保您的网络连接正常,并且没有任何网络问题。您可以尝试使用其他网络连接或在不同的网络环境中进行连接。 如果以上方法都没有解决问题,您可以尝试以下进一步的排查步骤: 1. 检查ZooKeeper日志:查看ZooKeeper服务器的日志文件,看是否有任何错误或异常信息。日志文件通常位于ZooKeeper服务器的数据目录下。 2. 检查客户端配置:确保您的客户端配置正确,并且与ZooKeeper服务器的配置相匹配。您可以检查客户端代码或配置文件,确认是否有任何错误或不一致之处。 3. 检查权限设置:检查ZooKeeper服务器和客户端之间的权限设置。确保您具有足够的权限来连接到ZooKeeper服务器。您可以尝试使用具有更高权限的用户来进行连接。 如果问题仍然存在,您可以尝试重新启动ZooKeeper服务器,并确保所有依赖项和配置都正确无误。如果问题持续存在,您可以在相应的技术论坛或社区中寻求帮助,以获取更详细的解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值