Cayenne 3.1 - setting datasource dynamically

前端 未结 1 868
日久生厌
日久生厌 2021-01-15 17:18

I\'m using Cayenne 3.1B2 at present as the persistence layer for some web services. There\'s a requirement for the services to expose one of several databases, all with the

相关标签:
1条回答
  • 2021-01-15 17:37

    I would create a single project with a DataMap and single DataNode. Delete its "DataSource Factory" as we'd be specifying it in the code (never tried this, if leaving "DataSource Factory" empty causes any problems on startup, you can set it to any of the provided choices, e.g. JNDIDataSourceFactory, with an understanding that this is just placeholder and will be ignored in runtime).

    Now start your 2 ServerRuntimes, each using the same single mapping project, but 2 distinct sets of properties for the DataSource. These properties cause Cayenne to ignore DataSource Factory set in XML.

    Module m1 = new Module() {
    
        @Override
        public void configure(Binder binder) {
            binder.bindMap(Constants.PROPERTIES_MAP)
                  .put(Constants.JDBC_DRIVER_PROPERTY, "com.my.Driver")
                  .put(Constants.JDBC_URL_PROPERTY, "jdbc://db1_url")
                  .put(Constants.JDBC_USERNAME_PROPERTY, "db1login")
                  .put(Constants.JDBC_PASSWORD_PROPERTY, "db1password");
        }
    };
    
    Module m2 = new Module() {
    
        @Override
        public void configure(Binder binder) {
            binder.bindMap(Constants.PROPERTIES_MAP)
                   .put(Constants.JDBC_DRIVER_PROPERTY, "com.my.Driver")
                   .put(Constants.JDBC_URL_PROPERTY, "jdbc://db2_url")
                   .put(Constants.JDBC_USERNAME_PROPERTY, "db2login")
                   .put(Constants.JDBC_PASSWORD_PROPERTY, "db2password");
        }
    };
    
    ServerRuntime r1 = new ServerRuntime("cayenne-project.xml", m1);
    ServerRuntime r2 = new ServerRuntime("cayenne-project.xml", m2);
    

    r1 and r2 should be application singletons, and you can create ObjectContexts from either one as appropriate for each request. If you are reusing ObjectContexts between requests (e.g. this is a mostly read-only app), you can create 2 contexts from r1 and r2 and also cache them.

    0 讨论(0)
提交回复
热议问题