java - Cassandra 中的超时异常

标签 java exception cassandra

我使用 Cassandra 数据库来获取一些频繁请求的数据。以下是我的代码

 public Map<String,String> loadObject(ArrayList<Integer> tradigAccountList){

        com.datastax.driver.core.Session session;
        Map<String,String> orderListMap = new HashMap<>();
        List<ResultSetFuture> futures = new ArrayList<>();
        List<ListenableFuture<ResultSet>> Future;


        try {
            session =jdbcUtils.getCassandraSession();
            PreparedStatement statement = jdbcUtils.getCassandraPS(CassandraPS.LOAD_ORDER_LIST);

            for (Integer tradingAccount:tradigAccountList){
                futures.add(session.executeAsync(statement.bind(tradingAccount).setFetchSize(3000)));
            }


                        for (ResultSetFuture future : futures){

                            for ( Row row : future.get().all()){
                                orderListMap.put(row.getString("cliordid"),row.getString("ordermsg"));
                            }
                        }

        }catch (Exception e){
        }finally {
        }
        return orderListMap;
    }

我同时发送大约 30 个请求,我的查询如下:

“从 omsks_v1.ordersStringV1 中选择 cliordid、ordermsg,其中 tradacntid = ?”

每次运行此查询时,它大约会获取至少 30000 行。但是当我同时发送多个请求时,这将引发超时异常。

我的 Cassandra 集群有 2 个节点,每个节点有 32 个并发读写线程。请问谁能为我提供解决方案吗?

最佳答案

CREATE TABLE omsks_v1.ordersstringv1_copy1 (
    tradacntid int,
    cliordid text,
    ordermsg text,
    PRIMARY KEY (tradacntid, cliordid)
) WITH bloom_filter_fp_chance = 0.01
AND comment = ''
AND dclocal_read_repair_chance = 0.1
AND default_time_to_live = 0
AND gc_grace_seconds = 864000
AND max_index_interval = 2048
AND memtable_flush_period_in_ms = 0
AND min_index_interval = 128
AND read_repair_chance = 0.0
AND speculative_retry = '99.0PERCENTILE'
AND caching = {
    'keys' : 'ALL',
    'rows_per_partition' : 'NONE'
}
AND compression = {
    'sstable_compression' : 'LZ4Compressor'
}
AND compaction = {
    'class' : 'SizeTieredCompactionStrategy'
};

这是表架构

关于java - Cassandra 中的超时异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47179286/

相关文章:

java - 映射到 JsonProperty 时对 JSON 创建实践感到困惑

java - 如何使用 currentTimeMillis() 方法获取小部分执行时间

python - Python中频繁重复的try/except

java - 如何通过 Java 身份验证连接到 Cassandra 5.1

java - 核心连接数必须为正误差

java - 如何从文件中读取文本(文本语言不固定)并执行某些操作将其写入另一个文件中?

java - LIBGDX 为主菜单创建 Actor 和舞台

logging - Enterprise Library 5.0 - 将自定义标记添加到 TextFormatter

java - 我什么时候应该宣布 “throws”,什么时候不宣布? [复制]

ruby-on-rails - 如何开始使用像 cassandra 这样的 NoSql 数据库开发 rails/django 应用程序?