From 65a68ce365643b46acb7d9ee29b4800bcbb4261a Mon Sep 17 00:00:00 2001 From: ety001 Date: Thu, 29 Feb 2024 06:11:31 +0000 Subject: [PATCH 1/2] remove cache or decrease ttl --- hive/server/bridge_api/cursor.py | 34 ++++++++-------------- hive/server/common/helpers.py | 1 + hive/server/condenser_api/cursor.py | 39 +++++--------------------- hive/server/condenser_api/get_state.py | 4 +-- hive/server/condenser_api/tags.py | 4 +-- 5 files changed, 23 insertions(+), 59 deletions(-) diff --git a/hive/server/bridge_api/cursor.py b/hive/server/bridge_api/cursor.py index c46a17ed..d29f4a4e 100644 --- a/hive/server/bridge_api/cursor.py +++ b/hive/server/bridge_api/cursor.py @@ -428,30 +428,18 @@ async def pids_by_replies(db, start_author: str, start_permlink: str = '', parent_account = start_author sql = """ - SELECT id FROM hive_posts - WHERE author = :parent - AND is_deleted = '0' - ORDER BY id DESC - LIMIT 10000 - """ - - cache_key = "hive_posts-" + parent_account + "-is_deleted_0" - id_res = await db.query_all(sql, cache_key=cache_key, parent=parent_account) - if id_res == None or len(id_res) == 0: - return None - tmp_ids = [] - for el in id_res: - tmp_ids.append(str(el['id'])) - ids = ",".join(tmp_ids) + SELECT id FROM hive_posts + WHERE parent_id IN (SELECT id FROM hive_posts + WHERE author = :parent + AND is_deleted = '0' + ORDER BY id DESC + LIMIT 10000) %s + AND is_deleted = '0' + ORDER BY id DESC + LIMIT :limit + """ % seek - sql = """ - SELECT id FROM hive_posts - WHERE parent_id IN (%s) %s - AND is_deleted = '0' - ORDER BY id DESC - LIMIT :limit - """ % (ids, seek) - return await db.query_col(sql, limit=limit) + return await db.query_col(sql, parent=parent_account, start_id=start_id, limit=limit) async def pids_by_payout(db, account: str, start_author: str = '', start_permlink: str = '', limit: int = 20): diff --git a/hive/server/common/helpers.py b/hive/server/common/helpers.py index a5877d60..1adeaf55 100644 --- a/hive/server/common/helpers.py +++ b/hive/server/common/helpers.py @@ -40,6 +40,7 @@ async def wrapper(*args, **kwargs): if isinstance(e, AssertionError): log.error("ERR2: %s\n%s", repr(e), traceback.format_exc()) raise e + log.error("ERR0: %s\n%s", repr(e), traceback.format_exc()) raise e #return { # "error": { diff --git a/hive/server/condenser_api/cursor.py b/hive/server/condenser_api/cursor.py index ac444c81..1f63b6b0 100644 --- a/hive/server/condenser_api/cursor.py +++ b/hive/server/condenser_api/cursor.py @@ -20,8 +20,7 @@ async def get_post_id(db, author, permlink): """Given an author/permlink, retrieve the id from db.""" sql = ("SELECT id FROM hive_posts WHERE author = :a " "AND permlink = :p AND is_deleted = '0' LIMIT 1") - cache_key = "get_post_id_" + author + "_" + permlink - return await db.query_one(sql, a=author, p=permlink, cache_key=cache_key) + return await db.query_one(sql, a=author, p=permlink) async def get_child_ids(db, post_id): """Given a parent post id, retrieve all child ids.""" @@ -31,14 +30,12 @@ async def get_child_ids(db, post_id): async def _get_post_id(db, author, permlink): """Get post_id from hive db.""" sql = "SELECT id FROM hive_posts WHERE author = :a AND permlink = :p" - cache_key = "_get_post_id_" + author + "_" + permlink - return await db.query_one(sql, a=author, p=permlink, cache_key=cache_key) + return await db.query_one(sql, a=author, p=permlink) async def _get_account_id(db, name): """Get account id from hive db.""" assert name, 'no account name specified' - cache_key = "_get_account_id_" + name - _id = await db.query_one("SELECT id FROM hive_accounts WHERE name = :n", n=name, cache_key=cache_key) + _id = await db.query_one("SELECT id FROM hive_accounts WHERE name = :n", n=name) assert _id, "account not found: `%s`" % name return _id @@ -65,13 +62,8 @@ async def get_followers(db, account: str, start: str, follow_type: str, limit: i LIMIT :limit """ % seek - cache_key = "get_followers_" - cache_key = cache_key + to_string_without_special_char(account_id) + "_" - cache_key = cache_key + to_string_without_special_char(start_id) + "_" - cache_key = cache_key + to_string_without_special_char(state) - return await db.query_all(sql, account_id=account_id, start_id=start_id, - state=state, limit=limit, cache_key=cache_key) + state=state, limit=limit) async def get_followers_by_page(db, account: str, page: int, page_size: int, follow_type: str): @@ -88,14 +80,8 @@ async def get_followers_by_page(db, account: str, page: int, page_size: int, fol LIMIT :limit OFFSET :offset """ - cache_key = "get_followers_by_page_" - cache_key = cache_key + to_string_without_special_char(account_id) + "_" - cache_key = cache_key + to_string_without_special_char(state) + "_" - cache_key = cache_key + to_string_without_special_char(page*page_size) - return await db.query_all(sql, account_id=account_id, - state=state, limit=page_size, offset=page*page_size, - cache_key=cache_key) + state=state, limit=page_size, offset=page*page_size) async def get_following(db, account: str, start: str, follow_type: str, limit: int): """Get a list of accounts followed by a given account.""" @@ -119,13 +105,8 @@ async def get_following(db, account: str, start: str, follow_type: str, limit: i LIMIT :limit """ % seek - cache_key = "get_following_" - cache_key = cache_key + to_string_without_special_char(account_id) + "_" - cache_key = cache_key + to_string_without_special_char(start_id) + "_" - cache_key = cache_key + to_string_without_special_char(state) - return await db.query_all(sql, account_id=account_id, start_id=start_id, - state=state, limit=limit, cache_key=cache_key) + state=state, limit=limit) async def get_following_by_page(db, account: str, page: int, page_size: int, follow_type: str): @@ -142,14 +123,8 @@ async def get_following_by_page(db, account: str, page: int, page_size: int, fol LIMIT :limit OFFSET :offset """ - cache_key = "get_following_by_page_" - cache_key = cache_key + to_string_without_special_char(account_id) + "_" - cache_key = cache_key + to_string_without_special_char(state) + "_" - cache_key = cache_key + to_string_without_special_char(page*page_size) - return await db.query_all(sql, account_id=account_id, - state=state, limit=page_size, offset=page*page_size, - cache_key=cache_key) + state=state, limit=page_size, offset=page*page_size) async def get_follow_counts(db, account: str): diff --git a/hive/server/condenser_api/get_state.py b/hive/server/condenser_api/get_state.py index 242a2e39..9c23ed9a 100644 --- a/hive/server/condenser_api/get_state.py +++ b/hive/server/condenser_api/get_state.py @@ -282,7 +282,7 @@ async def _get_feed_price(db): price = await db.query_one( "SELECT usd_per_steem FROM hive_state", cache_key="_get_feed_price", - cache_ttl=1800) + cache_ttl=3) return {"base": "%.3f SBD" % price, "quote": "1.000 STEEM"} async def _get_props_lite(db): @@ -290,7 +290,7 @@ async def _get_props_lite(db): tmp = await db.query_one( "SELECT dgpo FROM hive_state", cache_key="_hive_state_dgpo", - cache_ttl=300) + cache_ttl=3) if tmp is None or tmp == '': return dict() diff --git a/hive/server/condenser_api/tags.py b/hive/server/condenser_api/tags.py index 9458344f..4e671626 100644 --- a/hive/server/condenser_api/tags.py +++ b/hive/server/condenser_api/tags.py @@ -15,7 +15,7 @@ async def get_top_trending_tags_summary(context): ORDER BY SUM(payout) DESC LIMIT 50 """ - return await context['db'].query_col(sql, cache_key='get_top_trending_tags_summary', cache_ttl=7200) + return await context['db'].query_col(sql, cache_key='get_top_trending_tags_summary', cache_ttl=5*60) @return_error_info async def get_trending_tags(context, start_tag: str = '', limit: int = 250): @@ -48,7 +48,7 @@ async def get_trending_tags(context, start_tag: str = '', limit: int = 250): """ % seek out = [] - for row in await context['db'].query_all(sql, limit=limit, start_tag=start_tag, cache_key="get_trending_tags_"+start_tag+"_"+limit, cache_ttl=3600): + for row in await context['db'].query_all(sql, limit=limit, start_tag=start_tag, cache_key="get_trending_tags_"+start_tag+"_"+limit, cache_ttl=5*60): out.append({ 'name': row['category'], 'comments': row['total_posts'] - row['top_posts'], From a7901d7179dd0a91b5d7c1033c5619081aef2179 Mon Sep 17 00:00:00 2001 From: ety001 Date: Thu, 29 Feb 2024 07:40:31 +0000 Subject: [PATCH 2/2] fix condenser_api.get_discussions_by_blog api when limit is more than real count --- hive/server/condenser_api/objects.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hive/server/condenser_api/objects.py b/hive/server/condenser_api/objects.py index d3142f55..8b5402db 100644 --- a/hive/server/condenser_api/objects.py +++ b/hive/server/condenser_api/objects.py @@ -146,7 +146,7 @@ def _condenser_post_object(row, truncate_body=0): post['promoted'] = "%.3f SBD" % row['promoted'] post['replies'] = [] - post['body_length'] = len(row['body']) + post['body_length'] = len(row['body']) if row['body'] is not None else '' post['active_votes'] = _hydrate_active_votes(row['votes']) post['author_reputation'] = rep_to_raw(row['author_rep'])