Oracle DB - Непрерывность приложений - Как это проверить?

Как протестировать /POC концепция непрерывности приложений. Я попытался создать код для хранения соединений, чтобы приложение не могло получить соединения и пыталось получить его из пула. Я уверен, что это не правильный способ проверки целостности приложений, но я не знаю, как создать правильный сценарий.

Это единственный способ сбить БД в процессе транзакции?

Я использовал приведенный ниже код для имитации AC, где процедура вызывается 20 раз в 20 потоках с новым соединением каждый раз. Я создаю сценарий, в котором один поток переходит и ожидает подключения, время ожидания истекает, как то, что соединение не устанавливается вовремя, а затем удаляется, чтобы получить подключение, IS Это надлежащий тест переменного тока. (Ниже тестовый класс)

package com.ac;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;

import oracle.ucp.jdbc.PoolDataSourceFactory;
import oracle.ucp.jdbc.PoolDataSource;
import oracle.ucp.jdbc.ValidConnection;

import java.sql.ResultSet;

public class App {

    public static void main(String[] args) {
        try {
            new App().acSimulation();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public void acSimulation() throws Exception{

            final PoolDataSource  pds = PoolDataSourceFactory.getPoolDataSource();
            pds.setConnectionFactoryClassName("oracle.jdbc.replay.OracleDataSourceImpl");

            System.out.println("connection factory set");

            String URL = "jdbc:oracle:thin:@(DESCRIPTION = (TRANSPORT_CONNECT_TIMEOUT=3) (RETRY_COUNT=20)(FAILOVER=ON) " +
             " (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) (CONNECT_DATA = " +
             " (SERVER = DEDICATED) (SERVICE_NAME=orcl)))";
            System.out.println("Using URL\n" + URL);
            pds.setURL(URL);
            pds.setUser("system");
            pds.setPassword("oracle");

            pds.setInitialPoolSize(1);
            pds.setMinPoolSize(1);
            pds.setMaxPoolSize(3);
            pds.setConnectionWaitTimeout(10);
            // RAC Features
            pds.setConnectionPoolName("Application Continuity Pool");
            pds.setFastConnectionFailoverEnabled(true);
            // use srvctl config nodeapps to get the ONS ports on the cluster
//          pds.setONSConfiguration("nodes=192.168.100.30:6200,192.168.100.32:6200");

            System.out.println("pool configured, trying to get a connection");

//          final Connection conn = null;


            final Connection conn = pds.getConnection();

            if (conn == null || !((ValidConnection) conn).isValid())  {

              System.out.println("connection is not valid");
              throw new Exception ("invalid connection obtained from the pool");
            }

            if ( conn instanceof oracle.jdbc.replay.ReplayableConnection ) {
              System.out.println("got a replay data source");
            } else {
              System.out.println("this is not a replay data source. Why not?");
            }

            System.out.println("got a connection! Getting some stats if possible");
            oracle.ucp.jdbc.JDBCConnectionPoolStatistics stats = pds.getStatistics();
            System.out.println("\tgetAvailableConnectionsCount() " + stats.getAvailableConnectionsCount());
            System.out.println("\tgetBorrowedConnectionsCount() " + stats.getBorrowedConnectionsCount() );
            System.out.println("\tgetRemainingPoolCapacityCount() " + stats.getRemainingPoolCapacityCount());
            System.out.println("\tgetTotalConnectionsCount() " + stats.getTotalConnectionsCount());

            System.out.println(((oracle.ucp.jdbc.oracle.OracleJDBCConnectionPoolStatistics)pds.getStatistics()).getFCFProcessingInfo());

            System.out.println("Now working");

            int i=0;
            while(i < 20){
                new Runnable() {
                    public void run() {                     
                        try {
                            seperateInstance(conn, pds);
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
                }.run();
                i++;
            }
    }

    private void seperateInstance(Connection conn, PoolDataSource pds) throws SQLException{
        java.sql.CallableStatement cstmt = null;
        oracle.ucp.jdbc.JDBCConnectionPoolStatistics stats = pds.getStatistics();

            conn = pds.getConnection();

            cstmt = conn.prepareCall("{call P_M_emp(?,?)}");
            cstmt.setLong(1, 1);
            cstmt.setString(2, "TEST");
            cstmt.execute();
            System.out.println("Statement executed. Now closing down");
            System.out.println("Almost done! Getting some more stats if possible");

            stats = pds.getStatistics();
            System.out.println("\tgetAvailableConnectionsCount() " + stats.getAvailableConnectionsCount());
            System.out.println("\tgetBorrowedConnectionsCount() " + stats.getBorrowedConnectionsCount() );
            System.out.println("\tgetRemainingPoolCapacityCount() " + stats.getRemainingPoolCapacityCount());
            System.out.println("\tgetTotalConnectionsCount() " + stats.getTotalConnectionsCount());

            System.out.println(((oracle.ucp.jdbc.oracle.OracleJDBCConnectionPoolStatistics)pds.getStatistics()).getFCFProcessingInfo());
            try {
                Thread.currentThread().sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("Closing connection "+ conn);
            cstmt.close();
            conn.close();
            conn = null;

    }

}

Я получил код с сайта ниже и немного изменил, чтобы добавить темы и имитировать AC. Но я не могу получить воспроизводимый источник данных.

https://martincarstenbach.wordpress.com/2013/12/13/playing-with-application-continuity-in-rac-12c/

1 ответ

Чтобы проверить непрерывность приложения, вы можете убить сеансы на сервере, выполнив ALTER SYSTEM KILL SESSION 'sid,serial#' который будет имитировать сбой.

Другие вопросы по тегам