-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
pathway_annotation error "An error occurred. Retrying......" #115
Comments
Hi @jw0531jung, Thank you for providing more details about the issue you're experiencing. I have a question that might help us troubleshoot: Are you currently located in mainland China? If you are in mainland China, this error could potentially be related to network connectivity issues. In such cases, some possible solutions include:
Network restrictions can sometimes interfere with the API calls that the package makes, leading to the error you're seeing. If you're not in mainland China, please let me know, and we can explore other potential causes and solutions. Best, |
Oh, I'm actually in South Korea, and since I work at a national research institute, it might be difficult to change the server or network. Also, the script didn't fail from the start. I was able to get results several times without any issues on the same day. My workflow is as follows:
In step 2, the MaAsLin2 results are successfully annotated, but the ALDEx2 results are not. With respect, |
Hi @jw0531jung, Thank you for reporting this issue. Based on the code in
# 1. First save your ALDEx2 results
saveRDS(ald_sig, "aldex2_results.rds")
# 2. Use this modified approach for annotation
annotate_with_retry <- function(daa_results) {
# Set longer timeout
options(timeout = 300)
# Configure httr settings
httr::set_config(httr::config(
ssl_verifypeer = FALSE,
timeout = 60,
retries = 3
))
# Try annotation in smaller batches
features <- unique(daa_results$feature)
batch_size <- 10
batches <- split(features, ceiling(seq_along(features)/batch_size))
results_list <- list()
for(batch in batches) {
batch_data <- daa_results[daa_results$feature %in% batch,]
tryCatch({
# Add delay between batches
Sys.sleep(2)
result <- pathway_annotation(
pathway = "KO",
daa_results_df = batch_data,
ko_to_kegg = TRUE
)
results_list[[length(results_list) + 1]] <- result
}, error = function(e) {
message("Error in batch: ", paste(batch, collapse=", "))
message("Error message: ", e$message)
})
}
# Combine results
do.call(rbind, results_list)
}
# 3. Run the modified function
annot <- annotate_with_retry(ald_sig)
# Create a simple caching mechanism
create_kegg_cache <- function(ko_ids) {
cache <- list()
for(ko in ko_ids) {
tryCatch({
Sys.sleep(1) # Rate limiting
result <- KEGGREST::keggGet(ko)
cache[[ko]] <- result
}, error = function(e) {
message("Failed to cache ", ko)
})
}
saveRDS(cache, "kegg_cache.rds")
return(cache)
}
# Use cached data
use_cached_annotation <- function(daa_results, cache_file = "kegg_cache.rds") {
if(file.exists(cache_file)) {
cache <- readRDS(cache_file)
# Process using cache
# ... annotation logic here ...
} else {
cache <- create_kegg_cache(unique(daa_results$feature))
}
}
# Check your connection to KEGG
test_kegg_connection <- function() {
tryCatch({
test_result <- KEGGREST::keggGet("ko:K00001")
return(TRUE)
}, error = function(e) {
message("KEGG connection failed: ", e$message)
return(FALSE)
})
} I'll consider implementing these improvements in the next version of ggpicrust2. Would you be interested in testing the beta version with these enhancements? Best regards, |
Hello, Chen!
I got significant functions from two sites using "pathway_daa" and I want to perform pathway annotation.
When I run the following code:
httr::set_config(httr::config(ssl_verifypeer = FALSE))
annot <- pathway_annotation(pathway = "KO", daa_results_df = ald_sig, ko_to_kegg = TRUE)
httr::set_config(httr::config(ssl_verifypeer = TRUE))
I encounter the error message "An error occurred. Retrying......" repeatedly, and I have to forcefully terminate R.
The ald_sig contains fewer than 50 features (ko#).
I am not using a loop, so I don't think "sleep" is necessary.
Could this issue be caused by running this code frequently?
I am comparing a total of 9 sites, so I have already run this script more than 15 times to get results,
but suddenly it is not executing anymore.
Here are the details about my computer and package versions:
Microsoft Windows 10 Enterprise (x64-based PC)
ggpicurst2 (v1.7.3)
R (v4.3.3)
Thank you!
The text was updated successfully, but these errors were encountered: