From 44174a37cd502e7464b2fc8a87238ccce669d841 Mon Sep 17 00:00:00 2001 From: janhavigupta007 <46344506+janhavigupta007@users.noreply.github.com> Date: Mon, 16 Sep 2024 08:36:18 +0000 Subject: [PATCH] Go:Fix benchmarking code and improve response side performance (#2288) Signed-off-by: Janhavi Gupta --- go/benchmarks/benchmarking.go | 17 +++++++++++++---- go/src/lib.rs | 17 ++++++++--------- 2 files changed, 21 insertions(+), 13 deletions(-) diff --git a/go/benchmarks/benchmarking.go b/go/benchmarks/benchmarking.go index 68061bd1b8..141c480b1f 100644 --- a/go/benchmarks/benchmarking.go +++ b/go/benchmarks/benchmarking.go @@ -84,6 +84,8 @@ func executeBenchmarks(runConfig *runConfiguration, connectionSettings *connecti return nil } +var key_count int64 = 1 + func runSingleBenchmark(config *benchmarkConfig) error { fmt.Printf("Running benchmarking for %s client:\n", config.clientName) fmt.Printf( @@ -228,13 +230,13 @@ const ( func getActions(dataSize int) map[string]operations { actions := map[string]operations{ getExisting: func(client benchmarkClient) (string, error) { - return client.get(keyFromExistingKeyspace()) + return client.get(keyFromExistingKeyspace(getExisting)) }, getNonExisting: func(client benchmarkClient) (string, error) { return client.get(keyFromNewKeyspace()) }, set: func(client benchmarkClient) (string, error) { - return client.set(keyFromExistingKeyspace(), strings.Repeat("0", dataSize)) + return client.set(keyFromExistingKeyspace(set), strings.Repeat("0", dataSize)) }, } @@ -246,8 +248,15 @@ const ( sizeExistingKeyspace = 3000000 ) -func keyFromExistingKeyspace() string { - randNum, err := rand.Int(rand.Reader, big.NewInt(sizeExistingKeyspace)) +func keyFromExistingKeyspace(action string) string { + if action == set { + + if key_count < sizeNewKeyspace-1 { + key_count = key_count + 1 + } + return fmt.Sprint(key_count) + } + randNum, err := rand.Int(rand.Reader, big.NewInt(key_count)) if err != nil { log.Fatal("Error while generating random number for existing keyspace: ", err) } diff --git a/go/src/lib.rs b/go/src/lib.rs index 4a1c14c5a8..360d27d6e6 100644 --- a/go/src/lib.rs +++ b/go/src/lib.rs @@ -362,30 +362,29 @@ pub unsafe extern "C" fn command( let result: RedisResult> = match value { Value::Nil => Ok(None), Value::SimpleString(text) => { - let vec = text.chars().map(|b| b as c_char).collect::>(); + let vec = text.into_bytes(); let (vec_ptr, len) = convert_vec_to_pointer(vec); - command_response.string_value = vec_ptr; + command_response.string_value = vec_ptr as *mut c_char; command_response.string_value_len = len; Ok(Some(command_response)) } Value::BulkString(text) => { - let vec = text.iter().map(|b| *b as c_char).collect::>(); - let (vec_ptr, len) = convert_vec_to_pointer(vec); - command_response.string_value = vec_ptr; + let (vec_ptr, len) = convert_vec_to_pointer(text); + command_response.string_value = vec_ptr as *mut c_char; command_response.string_value_len = len; Ok(Some(command_response)) } Value::VerbatimString { format: _, text } => { - let vec = text.chars().map(|b| b as c_char).collect::>(); + let vec = text.into_bytes(); let (vec_ptr, len) = convert_vec_to_pointer(vec); - command_response.string_value = vec_ptr; + command_response.string_value = vec_ptr as *mut c_char; command_response.string_value_len = len; Ok(Some(command_response)) } Value::Okay => { - let vec = "OK".chars().map(|b| b as c_char).collect::>(); + let vec = String::from("OK").into_bytes(); let (vec_ptr, len) = convert_vec_to_pointer(vec); - command_response.string_value = vec_ptr; + command_response.string_value = vec_ptr as *mut c_char; command_response.string_value_len = len; Ok(Some(command_response)) }